Tomcat群集配置

大型的企业应用每天都需要承受巨大的访问量,在着巨大访问量的背后有数台服务器支撑着,如果一台服务器崩溃了,那么其他服务器可以使企业应用继续运行,用户对服务器的运作是透明化的,如何实现这种透明化呢?由如下问题需要解决。 一.Session的复制 二.如何将请求发送到正常的服务器 针对以上问题,可以使用群集和负载均衡来解决,整体架构如下: (图片来自:onjava.com) 中间由一台服务器做负载均衡(Load Balancer),它将所有请求,根据一定的负载均衡规则发送给指定的群集服务器(Cluster),群集服务器拥有着相同的状态和相同的应用程序,并且他们的Session是相互复制的,这样,不管访问哪台服务器都具有相同的结果,即使一台服务器崩溃掉以后,可以由其他集群服务器继续负责应用程序的运行。 Tomcat中如何配置群集我们假设有如下场景,一台负载均衡服务器负责请求的均衡,群集服务器A和群集服务器B组成一个群集,当某个群集服务器崩溃后,另外一台继续负责应用程序的运行。一. 配置Tomcat5.5.12群集服务器A 修改Tomcat配置文件server.xml 1.群集服务器A的端口号与B不冲突,即使Server Port,Connector,Coyote/JK2 AJP Connector的端口号唯一 2.在Host元素下增加以下内容:

 

3.修改Web应用程序配置文件web.xml 在web.xml文件中元素下增加以下内容:

二. 配置Tomcat5.5.12群集服务器B 与群集服务器A配置基本相同,唯一不同的地方就是server.xml文件中 tcpListenAddress应为本机地址,如果两台群集服务器在一台机器上,则端口号要不同 注意:B的其他端口不要与A冲突。 三. 群集服务器具体配置结果 配置参数 群集服务器 A 群集服务器B Server Port 9005 10005 Connector 9080 10080 Coyote/JK2 AJP Connector 9009 10009 Cluster mcastAddr 228.0.0.4 228.0.0.4 Cluster mcastPort 45564 45564 tcpListenAddress 本机IP地址 本机IP地址 Cluster tcpListenPort 4001 4002 Mcast* 用于广播,所有群集服务器需要填写相同的配置 tcpListen* 本机的IP,群集服务器启动时,会将自己的IP和端口号广播出去,其他群集服务器收到后,响应广播发出者。 四. 测试群集启动群集服务器A,再启动群集服务器B会显示群集服务器的信息,表示群集服务器配置成功 五. 配置负载均衡服务器Apache2.2.3 现在虽然群集已经有了相同的状态,但需要不同的IP地址才能访问到服务器A与B,现在我们配置一台负载均衡服务器来实现统一的入口访问,和负载的均衡。下载Apache服务器2.2.3。修改httpd.conf文件将以下Module的注释去掉 LoadModule proxy_module modules/mod_proxy.so LoadModule proxy_balancer_module modules/mod_proxy_balancer.so LoadModule proxy_http_module modules/mod_proxy_http.so 并增加以下元素 ProxyRequests Off ProxyPass /helloworld balancer://mycluster stickysession=jsessionid nofailover=On BalancerMember http://10.10.13.145:9080 BalancerMember http://10.10.13.145:10080 smax=1 loadfactor=20 SetHandler balancer-manager Order Deny,Allow Deny from all Allow from all SetHandler server-status Order Deny,Allow Deny from all Allow from all 其中 ProxyPass /helloworld balancer://mycluster stickysession=jsessionid nofailover=On BalancerMember http://10.10.13.145:9080 BalancerMember http://10.10.13.145:10080 smax=1 loadfactor=20 ProxyPass为代理转发的Url,即将所有访问/helloworld的请求转发到群集balancer://mycluster BalancerMember为群集的成员,即群集服务器A或B,负载均衡服务器会根据均衡规则来将请求转发给BalancerMember。 配置好后,启动Apahce服务器,访问localhost/hellworld就会看到群集服务器中应用返回的结果。恭喜你,负载均衡和群集已经配置成功了。 参考文档: Clustering and Load Balancing in Tomcat 5, Part 1 by Srini Penchikala Clustering and Load Balancing in Tomcat 5, Part 2 by Srini Penchikala Apache Tomcat 5.5 Document Apache Http Server Document

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值