多个项目,放在独立的tomcat上,并没有实现负载,要求实现静态化交给apache处理。
配置了3个tomcat通过jk和apache建立关系:
- tom1存放项目名:d1
- tom2存放项目名:news
- tom3存放项目名:root
环境:(一台win2003服务器,,zip版本5.5.26的tomcat装了3个,,jk是1.2.26的,apache2.2.×)
我的实现方式:
每个tomcat根目录下写个bat脚本,用于同一个机器上启动多个tomcat
D:\Program\Tomcat5.5.26\startup_proname.bat
set CATALINA_HOME=D:\Program\Tomcat5.5.26
bin/startup.bat
(此处只写一个tomcat的配置server.xml就不多说了,其他的也如此)
贴出我的配置文件,一共5个:
- mod_jk.conf
- workers2.properties
- uriworkermap-d1.properties
- uriworkermap-news.properties
- uriworkermap-root.properties
- httpd-vhosts.conf
mod_jk.conf
# Load mod_jk module. Specify the filename
# of the mod_jk lib you’ve downloaded and
# installed in the previous section
#加载mod_jk模块
LoadModule jk_module modules/mod_jk.so
# Where to find workers.properties
JkWorkersFile conf/workers2.properties
# Where to find uriworkermap.properties
JkMountFile conf/uriworkermap-root.properties
JkMountFile conf/uriworkermap-news.properties
JkMountFile conf/uriworkermap-d1.properties
# Where to put jk logs
JkLogFile logs/mod_jk.log
# Set the jk log level [debug/error/info]
JkLogLevel info
# Select the log format
JkLogStampFormat "[%a %b %d %H:%M:%S %Y] "
# JkOptions indicate to send SSL KEY SIZE,
JkOptions +ForwardKeySize +ForwardURICompat -ForwardDirectories
# JkRequestLogFormat set the request format
JkRequestLogFormat "%w %V %T"
#关掉主机Lookup,如果为on,很影响性能,可以有10多秒钟的延迟。
HostnameLookups Off
workers2.properties
worker.list=root-loadbalancer,news-loadbalancer,d1-loadbalancer
#主工程
worker.root.type=ajp13
worker.root.host=localhost
worker.root.port=9009
worker.root.lbfactor=1
worker.root-loadbalancer.type=lb
worker.root-loadbalancer.balance_workers=root
#新闻工程(news)
worker.news.type=ajp13
worker.news.host=localhost
worker.news.port=9019
worker.news.lbfactor=1
worker.news-loadbalancer.type=lb
worker.news-loadbalancer.balance_workers=news
#文件服务器工程(d1)
worker.d1.type=ajp13
worker.d1.host=localhost
worker.d1.port=9029
worker.d1.lbfactor=1
worker.d1-loadbalancer.type=lb
worker.d1-loadbalancer.balance_workers=d1
worker.status.type=status
uriworkermap-d1.properties
/*=d1-loadbalancer
!/*.gif=d1-loadbalancer
!/*.jpg=d1-loadbalancer
!/*.png=d1-loadbalancer
!/*.css=d1-loadbalancer
!/*.js=d1-loadbalancer
!/*.htm=d1-loadbalancer
!/*.html=d1-loadbalancer
uriworkermap-news.properties
/*=news-loadbalancer
!/*.gif=news-loadbalancer
!/*.jpg=news-loadbalancer
!/*.png=news-loadbalancer
!/*.css=news-loadbalancer
!/*.js=news-loadbalancer
!/*.htm=news-loadbalancer
!/*.html=news-loadbalancer
uriworkermap-root.properties
/*=root-loadbalancer
!/*.gif=root-loadbalancer
!/*.jpg=root-loadbalancer
!/*.png=root-loadbalancer
!/*.css=root-loadbalancer
!/*.js=root-loadbalancer
!/*.htm=root-loadbalancer
!/*.html=root-loadbalancer
httpd-vhosts.conf
#
# Virtual Hosts
#
# If you want to maintain multiple domains/hostnames on your
# machine you can setup VirtualHost containers for them. Most configurations
# use only name-based virtual hosts so the server doesn't need to worry about
# IP addresses. This is indicated by the asterisks in the directives below.
#
# Please see the documentation at
# <URL:http://httpd.apache.org/docs/2.2/vhosts/>
# for further details before you try to setup virtual hosts.
#
# You may use the command line option '-S' to verify your virtual host
# configuration.
#
# Use name-based virtual hosting.
#
NameVirtualHost *:80
#
# VirtualHost example:
# Almost any Apache directive may go into a VirtualHost container.
# The first VirtualHost section is used for all requests that do not
# match a ServerName or ServerAlias in any <VirtualHost> block.
#
#网站主工程
<VirtualHost *:80>
ServerAdmin sydney.sun@demo.com
DocumentRoot "D:\apache-tomcat-5.5.26-root\webapps\insurance"
ServerName *.demo.com
JkMountFile conf/uriworkermap-root.properties
ErrorLog logs/demo-error.log
CustomLog logs/demo-access.log common
DirectoryIndex index.jsp
<Directory "D:\apache-tomcat-5.5.26-root\webapps\insurance">
Options FollowSymLinks
AllowOverride None
order allow,deny
Allow from all
</Directory>
<IfModule mod_rewrite.c>
Rewriteengine on
#配置满足什么条件进行重写
RewriteCond %{HTTP_HOST} ^[a-z0-9\-]+\.demo\.com$
RewriteCond %{HTTP_HOST} !^www.demo.com
RewriteCond %{HTTP_HOST} !^bbs.demo.com
RewriteCond %{HTTP_HOST} !^d1.demo.com
RewriteCond %{HTTP_HOST} !^news.demo.com
RewriteCond %{REQUEST_URI} !(\.css|\.js|\.jpg|\.gif|\.png|\.html|\.htm)$
RewriteRule ^/(.*)$ /%{HTTP_HOST}/$1
#网站后台进行二级域名解析
RewriteRule ^/manage\.demo\.com/?$ /panel/login.do [L,PT]
#频道的首页进行二级域名解析
RewriteRule ^/zx\.demo\.com/?$ /advisory/index.do [L,PT]
RewriteRule ^/bid\.demo\.com/?$ /bid/bid_index.do [L,PT]
RewriteRule ^/job\.demo\.com/?$ /job/job_index.do [L,PT]
RewriteRule ^/download\.demo\.com/?$ /download/downloadIndex.do [L,PT]
RewriteRule ^/ts\.demo\.com/?$ /complain/complain_index.do [L,PT]
RewriteRule ^/video\.demo\.com/?$ /shipin/videoIndex.do [L,PT]
RewriteRule ^/yellow\.demo\.com/?$ /yellow/yellow_index.do [L,PT]
RewriteRule ^/fun\.demo\.com/?$ /fun/index.do [L,PT]
#空间会员进行泛域名解析
RewriteRule ^/([a-z0-9\-]+)\.demo\.com/?$ /space/index.do?SLD=$1 [L,PT]
RewriteRule ^/([a-z0-9\-]+)\.demo\.com/space(/(.*))*$ /space/$2?SLD=$1&%{QUERY_STRING} [L,PT]
</IfModule>
</VirtualHost>
#保险新闻工程
<VirtualHost *:80>
ServerAdmin sydney.sun@demo.com
DocumentRoot "D:\apache-tomcat-5.5.26-news\webapps\news"
ServerName news.demo.com
JkMountFile conf/uriworkermap-news.properties
ErrorLog logs/news-error.log
CustomLog logs/news-access.log common
DirectoryIndex index.jsp
<Directory "D:\apache-tomcat-5.5.26-news\webapps\news">
Options FollowSymLinks
AllowOverride None
order allow,deny
Allow from all
</Directory>
</VirtualHost>
#文件服务器工程
<VirtualHost *:80>
ServerAdmin sydney.sun@demo.com
DocumentRoot "D:\apache-tomcat-5.5.26-d1\webapps\d1"
ServerName d1.demo.com
JkMountFile conf/uriworkermap-d1.properties
ErrorLog logs/d1-error.log
CustomLog logs/d1-access.log common
DirectoryIndex index.jsp
<Directory "D:\apache-tomcat-5.5.26-d1\webapps\d1">
Options FollowSymLinks
AllowOverride None
order allow,deny
Allow from all
</Directory>
</VirtualHost>
最后一个配置了,强调:我这里是3个项目分别用了3个tomcat,主要工程root实现了二级域名,其他两个功能有相应的域名
现在运行了2,3天时间发现偶尔会有异常,打不开现象,重启下影响不大,不过不知道原因很痛苦!
tomcat日志:
2008-10-28 13:18:59 org.apache.jasper.compiler.TldLocationsCache processWebDotXml
警告: Internal Error: File /WEB-INF/web.xml not found
2008-10-28 13:50:22 org.apache.jk.core.MsgContext action
警告: Error sending end packet
java.net.SocketException: Software caused connection abort: socket write error
分享到:
相关推荐
JK模块包含两个部分:mod_jk.so(Apache加载的动态链接库)和worker.properties(配置文件,定义了Apache与Tomcat实例间的映射关系)。 **配置步骤:** 1. **安装Apache和Tomcat:** 首先确保安装了Apache ...
`sticky_session`设置为1表示启用会话粘滞,即同一个用户在一段时间内会被定向到同一台Tomcat服务器,以保持会话状态的一致性。 在实际部署中,为了最大化系统可用性和性能,建议每个Tomcat实例部署在独立的物理或...
通过使用 mod_jk 这一模块,我们可以实现 Apache 和 Tomcat 之间的高效通信。mod_jk 是一个负载均衡器和反向代理,它能够帮助我们在多个应用服务器之间分发 HTTP 请求。本文将详细介绍 mod_jk 的不同版本及其与 ...
在IT领域,特别是Web服务架构中,通过使用Tomcat、Apache和JK代理模块实现集群与负载均衡是一种常见的优化策略,旨在提升系统性能、稳定性和可用性。以下是对标题“tomcat+apache+jk集群和负载均衡”以及描述...
"Apache+Tomcat7+jk负载均衡"的组合就是一种常见的解决方案,它通过Apache HTTP Server作为前端代理服务器,利用JK模块(mod_jk)将请求分发到多台后端的Tomcat7应用服务器上,实现负载均衡和故障转移。下面我们将...
Apache 2.2.22、JK模块与Tomcat 7是构建高性能Web服务集群的关键组件。Apache HTTP服务器作为前端负载均衡器,通过JK模块(也称为mod_jk)与后端的Tomcat应用服务器进行通信,实现动态内容的处理。这种架构允许你将...
Apache+Tomcat+JK是一个常见的Web服务器和应用服务器集群解决方案,用于实现负载均衡和高可用性。这个配置中,Apache作为前端反向代理服务器,Tomcat作为后端的应用服务器,而JK模块是Apache与Tomcat之间的连接器,...
mod_jk是Apache的一个模块,用于在Apache和Tomcat之间建立连接,实现负载平衡。首先确保已安装mod_jk模块,并将其加载到Apache中。例如,在Windows环境下,将`mod_jk_2.0.46.dll`复制到Apache的`modules`目录下,并...
在worker.properties中,可以通过配置多个worker来实现负载均衡,每个worker代表一个Tomcat实例。当一个worker出现故障时,mod_jk会自动将请求转发给其他健康的worker,实现故障转移。 4. **优化与监控** - **...
1. **负载均衡**:`mod_jk`可以配置为将请求分散到多个Tomcat实例,实现负载均衡,提高系统可用性。 2. **会话持久性**:可以设置会话持久性,确保用户在一个Tomcat实例上创建的会话可以在其他实例上继续。 3. **...
Apache 代理实现整合多个 Tomcat 是一种常见的 web 服务器架构策略,它允许通过单一的 Apache 服务器来管理和分发来自不同 Tomcat 实例的请求。这样做的好处包括简化对外服务的 URL、负载均衡以及集中化的安全管理。...
Apache2.4、Tomcat8.0以及JK模块的结合使用是实现Web服务器与应用服务器之间负载均衡的一种常见方案。Apache作为前端服务器处理静态资源请求,而动态内容(如Java Web应用)则由Tomcat这样的Java应用服务器处理。JK...
在这个过程中,JK模模块(mod_jk)起到了关键作用,它是一个Apache模块,允许Apache与Tomcat之间进行通信。 首先,我们来详细了解一下Apache HTTP Server 2.2.4。这是Apache服务器的一个旧版本,但依然在许多系统中...
Apache和Tomcat是两种常用的Web服务器和应用服务器。...总之,整合Apache和Tomcat使用mod_jk是一种常见的做法,它能充分利用两者的优势,提供高效、稳定的服务。了解和掌握mod_jk的配置是提升Web服务器性能的关键步骤。
1. 确保所有软件(Apache、Tomcat、Java、mod_jk)的版本兼容。 2. 下载并安装Apache、Tomcat、Java和mod_jk模块。确保mod_jk模块与Apache版本匹配。 3. 安装完成后,备份`httpd.conf`以防误改导致Apache无法启动。 ...
mod_jk是Apache的负载均衡模块,通过它,我们可以将HTTP请求分发到多个Tomcat实例,实现集群化。下载并解压这个文件,然后将`mod_jk.so`动态链接库添加到Apache的`modules`目录下。 配置mod_jk涉及以下步骤: 1. *...
通过上述步骤,我们成功在一机双Tomcat环境中配置了一个基于Apache+Tomcat的服务器集群。这种方式不仅能够显著提升系统的稳定性和性能,还能实现资源的有效利用。对于处理高并发访问场景或需要提供不间断服务的应用...
总结来说,整合Apache和Tomcat使用JK模坓主要是为了优化性能和稳定性,通过JK模坓的配置,我们可以灵活地管理多个Tomcat子站,同时利用Apache处理静态资源,减轻Tomcat的压力。这一过程涉及编译JK模块、配置Apache和...
Apache、Tomcat以及mod_jk模块组成的集群架构是一种常见的高性能Web服务器和应用服务器组合,用于处理高并发和负载均衡的场景。在这个配置中,Apache作为前端服务器,通过mod_jk模块与后端的Tomcat应用服务器进行...