一直以来都在javaeye潜水,得到了很多人的经验分享,这两天在学习tomcat配置集群的过程中,积累了一点东西觉得应该与大家分享。关于Tomcat和Apache的连接方式,请参阅
http://www.ibm.com/developerworks/cn/opensource/os-lo-apache-tomcat/index.html。详细的配置过程,不再重复描述,请先看看罗代均
http://hi.baidu.com/luodaijun/blog/item/5bbe4cfb5ffef864034f56a1.html,我把配置过程中几个不同和关键的地方重点提出来。
软件版本有所不同,罗列如下:
Apache :apache_2.2.11-win32-x86-openssl-0.9.8i.msi 1个
Tomcat: apache-tomcat-6.0.14.zip 2个
mod_jk: mod_jk-1.2.27-httpd-2.2.10.so 1个
我准备了两台机器,192.1168.1.5 192.168.1.3,你也可以在一台机器上进行测试。
把apache和tomcat安装好以后,配置过程中有如下一些地方改动或者改进。
2.修改Apache配置文件http.conf
引入mod_jk时候,可以使用
Include conf/mod_jk.conf 可以不使用全路径引入,方便管理。
3.在http.conf同目录下新建 workers.properties文件,内容如下
#========tomcat1========
worker.tomcat1.port=8009 #ajp13 端口号,在tomcat下server.xml配 置,默认8009
worker.tomcat1.host=localhost #tomcat的主机地址,如不为本机,请填写ip地址
worker.tomcat1.type=ajp13
worker.tomcat1.lbfactor = 1 #server的加权比重,值越高,分得的请求越多
#========tomcat2========
worker.tomcat2.port=9009 #ajp13 端口号,在tomcat下server.xml配置,
worker.tomcat2.host=192.168.1.3 #tomcat的主机地址,如不为本机,请填写ip地址
worker.tomcat2.type=ajp13
worker.tomcat2.lbfactor = 1 #server的加权比重,值越高,分得的请求越多
#========controller,负载均衡控制器========
worker.controller.type=lb
worker.controller.balanced_workers=tomcat1,tomcat2 #指定分担请求的tomcat
worker.controller.sticky_session=false #worker.controller.sticky_session=1
以上要说明的是原文中worker.controller.sticky_session=1,等同于worker.controller.sticky_session=true.此处指定集群是否需要会话复制,如果设为true,则表明为会话粘性,不进行会话复制,当某用户的请求第一次分发到哪台Tomcat后,后继的请求会一直分发到此Tomcat服务器上处理;如果设为false,则表明需求会话复制。
这就是说,如果你要想进行均衡负载,并在192.168.1.5和192.168.1.3两台机器的Tomcat实例上实现集群全局session复制,此处值要设置成false。
第二部分,配置集群
把server.xml中注释部分
<!-- <Cluster className="org.apache.catalina.ha.tcp.SimpleTcpCluster"/>-->
替换如下cluster配置内容:
<Cluster className="org.apache.catalina.ha.tcp.SimpleTcpCluster"
channelSendOptions="8">
<!--
<Manager className="org.apache.catalina.ha.session.BackupManager"
expireSessionsOnShutdown="false"
notifyListenersOnReplication="true"
mapSendOptions="8"/> -->
<!-- -->
<Manager className="org.apache.catalina.ha.session.DeltaManager"
expireSessionsOnShutdown="false"
notifyListenersOnReplication="true"/>
<Channel className="org.apache.catalina.tribes.group.GroupChannel">
<Membership className="org.apache.catalina.tribes.membership.McastService"
address="228.0.0.4"
port="45564"
frequency="500"
dropTime="3000"/>
<Receiver className="org.apache.catalina.tribes.transport.nio.NioReceiver"
address="auto"
port="4000"
autoBind="100"
selectorTimeout="5000"
maxThreads="6"/>
<!-- timeout="60000"-->
<Sender className="org.apache.catalina.tribes.transport.ReplicationTransmitter">
<Transport className="org.apache.catalina.tribes.transport.nio.PooledParallelSender" />
</Sender>
<Interceptor className="org.apache.catalina.tribes.group.interceptors.TcpFailureDetector"/>
<Interceptor className="org.apache.catalina.tribes.group.interceptors.MessageDispatch15Interceptor"/>
<Interceptor className="org.apache.catalina.tribes.group.interceptors.ThroughputInterceptor"/>
</Channel>
<Valve className="org.apache.catalina.ha.tcp.ReplicationValve"
filter=""/>
<Valve className="org.apache.catalina.ha.session.JvmRouteBinderValve"/>
<Deployer className="org.apache.catalina.ha.deploy.FarmWarDeployer"
tempDir="/tmp/war-temp/"
deployDir="/tmp/war-deploy/"
watchDir="/tmp/war-listen/"
watchEnabled="false"/>
<ClusterListener className="org.apache.catalina.ha.session.JvmRouteSessionIDBinderListener"/>
<ClusterListener className="org.apache.catalina.ha.session.ClusterSessionListener"/>
</Cluster>
按罗君一文配置完后,请分别启动两个tomcat(启动一个tomcat,等它完全启动后,再启动另外一个tomcat),再启动apache。启动完成后,其中一个tomcat的控制台信息片段如下:
2009-1-28 14:47:12 org.apache.catalina.ha.session.DeltaManager start
??: [color=red]Starting clustering manager at
2009-1-28 14:47:12 org.apache.catalina.ha.session.DeltaManager getAllClusterSess
ions
??: Manager [localhost#], requesting session state from org.apache.catalina.tr
ibes.membership.MemberImpl[tcp://3645A51F0B7E4CA:4001,3645A51F0B7E4CA,4001, aliv
e=29031,id={112 55 65 24 117 66 68 118 -122 -5 -53 2 -35 -90 -8 -95 }, payload={
}, command={}, domain={}, ]. This operation will timeout if no session state has
been received within 60 seconds.[/color]2009-1-28 14:47:12 org.apache.catalina.tribes.group.interceptors.ThroughputInter
ceptor report
??: ThroughputInterceptor Report[
Tx Msg:1 messages
Sent:0.00 MB (total)
Sent:0.00 MB (application)
Time:0.02 seconds
Tx Speed:0.03 MB/sec (total)
TxSpeed:0.03 MB/sec (application)
Error Msg:0
Rx Msg:1 messages
Rx Speed:0.00 MB/sec (since 1st msg)
Received:0.00 MB]
2009-1-28 14:47:12 org.apache.catalina.ha.session.DeltaManager waitForSendAllSes
sions
??: Manager [localhost#]; session state send at 09-1-28 ??2:47 received in 2
65 ms.
2009-1-28 14:47:12 org.apache.catalina.ha.session.JvmRouteBinderValve start
??: JvmRouteBinderValve started
2009-1-28 14:47:12 org.apache.coyote.http11.Http11Protocol start
??: Starting Coyote HTTP/1.1 on http-8000
2009-1-28 14:47:12 org.apache.jk.common.ChannelSocket init
??: JK: ajp13 listening on /0.0.0.0:8009
2009-1-28 14:47:12 org.apache.jk.server.JkMain start
??: Jk running ID=0 time=0/31 config=null
2009-1-28 14:47:12 org.apache.catalina.startup.Catalina start
??: Server startup in 2818 ms
红色部分显示了当前配置使用的className="org.apache.catalina.ha.session.DeltaManager"是一个全局session复制使用的控制器,把session在集群的所有tomcat进行复制。而在大型系统中使用全局session复制是不合适的,应该使用className="org.apache.catalina.ha.session.BackupManager"实现tomcat配对session复制,如tomcat1和tomcat2配对时,在workers.properties中配置实现tomcat2作为tomcat1的后备,当tomcat1当掉时候tomcat2接受发给tomcat1的请求和session内容。详情请参考tomcat的官方workers.properties configuration说明。
测试负载均衡与session复制时候,可以在界面上和tomcat后台看到。
其中一个tomcat后台打印片段,另外一个没有拷贝下来,省略。
2009-1-28 14:47:12 org.apache.catalina.ha.session.JvmRouteBinderValve start
??: JvmRouteBinderValve started
2009-1-28 14:47:12 org.apache.coyote.http11.Http11Protocol start
??: Starting Coyote HTTP/1.1 on http-8000
2009-1-28 14:47:12 org.apache.jk.common.ChannelSocket init
??: JK: ajp13 listening on /0.0.0.0:8009
2009-1-28 14:47:12 org.apache.jk.server.JkMain start
??: Jk running ID=0 time=0/31 config=null
2009-1-28 14:47:12 org.apache.catalina.startup.Catalina start
??: Server startup in 2818 ms
55 = 55
gg = gg
44 = 44
55 = 55
gg = gg
11 = 11
77 = 77
- 大小: 52 KB
分享到:
相关推荐
在Windows环境下,Apache2.2和Tomcat6的组合是一个常见的Web服务器架构,用于搭建集群、实现负载均衡和处理session共享。Apache作为前端反向代理服务器,负责分发请求到后端的多个Tomcat实例,以提高应用的可用性和...
Apache+Tomcat+Linux集群和均衡负载(Session同步复制
在IT行业中,集成Apache2.2与Tomcat6是一个常见的任务,这主要涉及到Web服务器与应用服务器的联合部署,以实现动态和静态内容的高效分发。Apache2.2是一个强大的HTTP服务器,常用于处理静态内容,而Tomcat6则是一个...
Apache2.2与Tomcat6集群配置是一种常见的Web服务架构,用于提高网站的可用性和可扩展性。在Windows环境下,这种配置可以实现负载均衡,确保即使单个服务器出现故障,整个系统仍然能继续运行,同时分散请求以降低单一...
Apache2.2与Tomcat6.0的组合可以构建一个高效、可靠的负载均衡服务器系统,以分散客户端请求到多个后端应用服务器,提高整体服务的可用性和响应速度。以下是搭建和配置的关键步骤及知识点: 1. **Apache2.2安装配置...
apache2.2+tomcat7
- 负载均衡:如果负载较大,可以配置多个Tomcat实例,使用Apache的负载均衡模块分发请求。 - Caching:使用缓存模块如mod_expires和mod_cache,提高静态内容的响应速度。 - JNDI资源:在Tomcat中配置JNDI资源,使...
"两台服务器上做Apache2.2+Tomcat6.0+mod_jk的负载均衡"是一个典型的分布式系统架构,旨在通过在多台服务器之间分配工作负载来提高系统的稳定性和性能。下面将详细介绍这个配置涉及的知识点: 1. **Apache ...
Apache2.2与Tomcat5.5的整合配置是一个常见的任务,特别是在那些希望利用Apache作为前端服务器处理静态内容,而将动态请求转发给Tomcat处理的环境中。这种配置可以提高服务器性能并优化资源分配。 首先,我们需要...
Apache+Tomcat+JK 实现集群负载均衡是一种常见的Web服务器和应用服务器的部署方式,它能够提高系统的可用性和响应速度,实现服务的高并发处理。本文将详细介绍如何配置这一环境。 首先,我们需要准备以下软件: 1. ...
Apache2.2+Tomcat集群 只是一个简单的集群例子,所用到的Apache,Tomcat压缩文件里都有
Apache 2.2 和 Tomcat 6.0 的负载均衡配置是提高Web应用程序性能和可扩展性的重要技术。在高流量环境下,通过将工作负载分散到多个Tomcat实例上,可以确保服务的稳定性和响应速度,同时避免单一服务器过载。下面我们...
Apache+Tomcat+JK是一个常见的Web服务器和应用服务器集群解决方案,用于实现负载均衡和高可用性。这个配置中,Apache作为前端反向代理服务器,Tomcat作为后端的应用服务器,而JK模块是Apache与Tomcat之间的连接器,...
在"Apache2.2+tomcat7+jk+jdk1.6"的配置中,session组播复制和粘性session是解决session共享问题的核心策略。Session组播复制是指当一个用户在集群中的某个节点创建或更新session时,这个session的信息会被广播到...