5imobi 发表于 2015-8-1 12:17:34

apache tomcat 6集群负载和session复制(转)

  来源:http://jackandroid.javaeye.com/blog/627147
  
  无意间看到tomcat 6集群的内容,就尝试配置了一下,还是遇到很多问题,特此记录。apache服务器和tomcat的连接方法其实有三种:JK、http_proxy和ajp_proxy。本文主要介绍最为常见的JK。
  环境:PC2台:pc1(IP 192.168.88.118)安装了apache和tomcat
  pc2(IP 192.168.88.168)安装了tomcat
  系统 win xp sp3
  1.安装tomcat、apache服务器及版本对应的JK
  这里需要注意的是JK版本必须与apache服务器版本号对应,可以直接从我参考附件下载。apache_home表示apache服务器安装目录.
  2.配置apache服务器
  2.1 httpd.conf文件
  apache_home目录下的conf/httpd.conf文件中添加



Xml代码 http://jackandroid.javaeye.com/javascripts/syntaxhighlighter/clipboard_new.swf?clipboard=LoadModule%20jk_module%20modules%2Fmod_jk-1.2.26-httpd-2.2.4.so%0AJkWorkersFile%20conf%2Fworkers.properties%0AJkMount%20%2F*%20lbcontroller%20
[*]LoadModule jk_module modules/mod_jk-1.2.26-httpd-2.2.4.so
[*]JkWorkersFile conf/workers.properties
[*]JkMount /* lbcontroller   
  具体的说明如下:



Xml代码 http://jackandroid.javaeye.com/javascripts/syntaxhighlighter/clipboard_new.swf?clipboard=LoadModule%20jk_module%20modules%2Fmod_jk-1.2.26-httpd-2.2.4.so
[*]LoadModule jk_module modules/mod_jk-1.2.26-httpd-2.2.4.so
  表示载入JK模块。



Xml代码 http://jackandroid.javaeye.com/javascripts/syntaxhighlighter/clipboard_new.swf?clipboard=JkWorkersFile%20conf%2Fworkers.properties
[*]JkWorkersFile conf/workers.properties
  tomcat实例配置,具体参见2.2。



Xml代码 http://jackandroid.javaeye.com/javascripts/syntaxhighlighter/clipboard_new.swf?clipboard=JkMount%20%2F*%20lbcontroller%20
[*]JkMount /* lbcontroller   
  设置apache分发器,/*表示apache将所有文件都由分发器lbcontroller 进行分发,你可以自行设置*.jsp,*.do等
   2.2 workers.properties文件

  在apache_home下conf目录中新建workers.properties文件,输入以下内容



Xml代码 http://jackandroid.javaeye.com/javascripts/syntaxhighlighter/clipboard_new.swf?clipboard=worker.list%3Dlbcontroller%0A%0A%23Tomcat1%E5%AE%9E%E4%BE%8B%E9%85%8D%E7%BD%AE%0Aworker.tomcat1.host%3D192.168.88.118%0Aworker.tomcat1.port%3D8009%0Aworker.tomcat1.type%3Dajp13%0A%23%E5%88%86%E5%8F%91%E6%9D%83%E9%87%8D%20%E5%80%BC%E8%B6%8A%E5%A4%A7%E8%B4%9F%E8%BD%BD%E8%B6%8A%E5%A4%A7%0Aworker.tomcat1.lbfactor%20%3D%201%0A%0A%23Tomcat2%E5%AE%9E%E4%BE%8B%E9%85%8D%E7%BD%AE%0Aworker.tomcat2.host%3D192.168.88.168%0Aworker.tomcat2.port%3D9009%0Aworker.tomcat2.type%3Dajp13%0A%23%E5%88%86%E5%8F%91%E6%9D%83%E9%87%8D%20%E5%80%BC%E8%B6%8A%E5%A4%A7%E8%B4%9F%E8%BD%BD%E8%B6%8A%E5%A4%A7%0Aworker.tomcat2.lbfactor%20%3D%201%0A%0A%23%E8%B4%9F%E8%BD%BD%E5%9D%87%E8%A1%A1%E5%88%86%E5%8F%91%E6%8E%A7%E5%88%B6%E5%99%A8%0Aworker.lbcontroller.type%3Dlb%0Aworker.lbcontroller.balance_workers%3Dtomcat1%2Ctomcat2%0Aworker.lbcontroller.sticky_session%3DTrue
[*]worker.list=lbcontroller
[*]
[*]#Tomcat1实例配置
[*]worker.tomcat1.host=192.168.88.118
[*]worker.tomcat1.port=8009
[*]worker.tomcat1.type=ajp13
[*]#分发权重 值越大负载越大
[*]worker.tomcat1.lbfactor = 1
[*]
[*]#Tomcat2实例配置
[*]worker.tomcat2.host=192.168.88.168
[*]worker.tomcat2.port=9009
[*]worker.tomcat2.type=ajp13
[*]#分发权重 值越大负载越大
[*]worker.tomcat2.lbfactor = 1
[*]
[*]#负载均衡分发控制器
[*]worker.lbcontroller.type=lb
[*]worker.lbcontroller.balance_workers=tomcat1,tomcat2
[*]worker.lbcontroller.sticky_session=True
  在这里



Xml代码 http://jackandroid.javaeye.com/javascripts/syntaxhighlighter/clipboard_new.swf?clipboard=worker.list%3Dlbcontroller
[*]worker.list=lbcontroller
  内容即为httpd.conf文件中的分发器名称。需要注意的内容是,tomcat实例名称



Xml代码 http://jackandroid.javaeye.com/javascripts/syntaxhighlighter/clipboard_new.swf?clipboard=worker.tomcat1.host%3D....%0A...%0Aworker.tomcat2.host%3D....%0A...
[*]worker.tomcat1.host=....
[*]...
[*]worker.tomcat2.host=....
[*]...
  在这里就是tomcat1和tomcat2必须与之后tomcat中的server.xml中jvmRoute值一致。
  3.tomcat集群配置
  配置每个tomcat目录下的server.xml文件,具体修改内容如下
  3.1 Engine配置
  修改前



Xml代码 http://jackandroid.javaeye.com/javascripts/syntaxhighlighter/clipboard_new.swf?clipboard=%3CEngine%20name%3D%22Catalina%22%20defaultHost%3D%22localhost%22%3E
[*]
  修改后



Xml代码 http://jackandroid.javaeye.com/javascripts/syntaxhighlighter/clipboard_new.swf?clipboard=%20%3CEngine%20name%3D%22Catalina%22%20defaultHost%3D%22localhost%22%20%20jvmRoute%3D%22tomcat1%22%20%3E
[*]
  具体tomcat中jvmRoute的值根据在workers.properties的配置,注意IP地址、tomcat实例名称和jvmRoute值必须一一对应。
  3.2 Connector配置
  修改前



Xml代码 http://jackandroid.javaeye.com/javascripts/syntaxhighlighter/clipboard_new.swf?clipboard=%20%20%20%20%3CConnector%20port%3D%228009%22%20protocol%3D%22AJP%2F1.3%22%20redirectPort%3D%228443%22%20%2F%3E
[*]
  修改后



Xml代码 http://jackandroid.javaeye.com/javascripts/syntaxhighlighter/clipboard_new.swf?clipboard=%20%20%20%20%3CConnector%20port%3D%229009%22%20protocol%3D%22AJP%2F1.3%22%20redirectPort%3D%228443%22%20%2F%3E
[*]
  这里tomcat的port值必须与在workers.properties中的port值一致。
  3.3 Cluster配置
  修改前



Xml代码 http://jackandroid.javaeye.com/javascripts/syntaxhighlighter/clipboard_new.swf?clipboard=%3C!--%0A%3CCluster%20className%3D%22org.apache.catalina.ha.tcp.SimpleTcpCluster%22%20%3E%0A--%3E
[*]
  修改后,去掉注释并添加一些内容如下



Xml代码 http://jackandroid.javaeye.com/javascripts/syntaxhighlighter/clipboard_new.swf?clipboard=%20%20%20%3CCluster%20className%3D%22org.apache.catalina.ha.tcp.SimpleTcpCluster%22%20%20channelSendOptions%3D%228%22%3E%20%20%20%0A%20%20%20%20%20%20%20%20%20%0A%20%20%20%20%20%20%20%20%20%20%3CManager%20className%3D%22org.apache.catalina.ha.session.DeltaManager%22%20%20%0A%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20expireSessionsOnShutdown%3D%22false%22%20%20%0A%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20notifyListenersOnReplication%3D%22true%22%2F%3E%20%20%20%0A%20%20%0A%20%20%20%20%20%20%20%20%20%20%3CChannel%20className%3D%22org.apache.catalina.tribes.group.GroupChannel%22%3E%20%20%20%0A%20%20%20%20%20%20%20%20%20%20%20%20%3CMembership%20className%3D%22org.apache.catalina.tribes.membership.McastService%22%20%20%0A%20%20%20%20%20%20%20%20%20%20%20%20%09%20%20%20%20%20%20%20%20%20address%3D%22228.0.0.4%22%20%20%0A%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20port%3D%2245564%22%20%20%0A%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20frequency%3D%22500%22%20%20%0A%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20dropTime%3D%223000%22%2F%3E%20%20%20%0A%20%20%20%20%20%20%20%20%20%20%20%20%3CReceiver%20className%3D%22org.apache.catalina.tribes.transport.nio.NioReceiver%22%20%20%0A%20%20%20%20%20%20%20%20%20%20%20%20%09%20%20%20%20%20%20%20%20address%3D%22auto%22%0A%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20port%3D%224001%22%20%20%0A%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20autoBind%3D%22100%22%20%20%0A%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20selectorTimeout%3D%225000%22%20%20%0A%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20maxThreads%3D%226%22%2F%3E%20%20%20%0A%20%20%20%20%20%20%20%20%20%20%20%20%3C!--%20timeout%3D%2260000%22--%3E%20%20%20%0A%20%20%20%20%20%20%20%20%20%20%20%20%3CSender%20className%3D%22org.apache.catalina.tribes.transport.ReplicationTransmitter%22%3E%20%20%20%0A%20%20%20%20%20%20%20%20%20%20%20%20%20%20%3CTransport%20className%3D%22org.apache.catalina.tribes.transport.nio.PooledParallelSender%22%20%2F%3E%20%20%20%0A%20%20%20%20%20%20%20%20%20%20%20%20%3C%2FSender%3E%20%20%20%0A%20%20%20%20%20%20%20%20%20%20%20%20%3CInterceptor%20className%3D%22org.apache.catalina.tribes.group.interceptors.TcpFailureDetector%22%2F%3E%20%20%20%0A%20%20%20%20%20%20%20%20%20%20%20%20%3CInterceptor%20className%3D%22org.apache.catalina.tribes.group.interceptors.MessageDispatch15Interceptor%22%2F%3E%20%20%20%0A%20%20%20%20%20%20%20%20%20%20%20%20%3CInterceptor%20className%3D%22org.apache.catalina.tribes.group.interceptors.ThroughputInterceptor%22%2F%3E%20%20%20%0A%20%20%20%20%20%20%20%20%20%20%3C%2FChannel%3E%20%20%20%0A%20%20%0A%20%20%20%20%20%20%20%20%20%20%3CValve%20className%3D%22org.apache.catalina.ha.tcp.ReplicationValve%22%20%20%0A%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20filter%3D%22%22%2F%3E%20%20%20%0A%20%20%20%20%20%20%20%20%20%20%3CValve%20className%3D%22org.apache.catalina.ha.session.JvmRouteBinderValve%22%2F%3E%20%20%20%0A%20%20%0A%20%20%20%20%20%20%20%20%20%20%3CClusterListener%20className%3D%22org.apache.catalina.ha.session.JvmRouteSessionIDBinderListener%22%2F%3E%20%20%20%0A%20%20%20%20%20%20%20%20%20%20%3CClusterListener%20className%3D%22org.apache.catalina.ha.session.ClusterSessionListener%22%2F%3E%20%20%20%0A%20%20%20%20%20%20%20%20%3C%2FCluster%3E
[*]   
[*]      
[*]            
[*]
[*]            
[*]            
[*]            
[*]            
[*]            
[*]               
[*]            
[*]            
[*]            
[*]            
[*]            
[*]
[*]            
[*]            
[*]
[*]            
[*]            
[*]      
  上述配置跟tomcat官方建议的配置,去掉了



Xml代码 http://jackandroid.javaeye.com/javascripts/syntaxhighlighter/clipboard_new.swf?clipboard=%20%3CDeployer%20className%3D%22org.apache.catalina.ha.deploy.FarmWarDeployer%22%0A%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20tempDir%3D%22%2Ftmp%2Fwar-temp%2F%22%0A%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20deployDir%3D%22%2Ftmp%2Fwar-deploy%2F%22%0A%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20watchDir%3D%22%2Ftmp%2Fwar-listen%2F%22%0A%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20watchEnabled%3D%22false%22%2F%3E
[*]
  如果不去掉这部分,则tomcat启动会报"FarmWarDeployer can only work as host cluster subelement!."
  3.4 session复制配置
  tomcat集群中的session管理,主要有两种方式:
  1).粘性session
  表示从同一窗口发来的请求都将有集群中的同一个tomcat进行处理。配置方式是在上面workers.properties文件中



Xml代码 http://jackandroid.javaeye.com/javascripts/syntaxhighlighter/clipboard_new.swf?clipboard=worker.lbcontroller.sticky_session%3DTrue%26nbsp%3B
[*]worker.lbcontroller.sticky_session=True   
  粘性session的好处在不会在不同的tomcat上来回跳动处理请求,但是坏处是如果处理该session的tomcat崩溃,那么之后的请求将由其他tomcat处理,原有session失效而重新新建一个新的session,这样如果继续从session取值,会抛出nullpointer的访问异常。
  2).session复制
  session复制是指tomcat彼此之间通过组播方式将session发到各个tomcat实例上,如果其中一个访问出错,则另外tomcat仍然具有有效的session内容,从而能正常接管其session。坏处是当tomcat实例很多,或者用户在session中有大量操作时,组播发送的信息量十分惊人。session复制配置则是在发布的web应用程序中的web.xml中添加



Xml代码 http://jackandroid.javaeye.com/javascripts/syntaxhighlighter/clipboard_new.swf?clipboard=%20%3Cdistributable%2F%3E
[*]
  此外,session复制所需的JDK必须是JDK 5.0及其以上版本。
  4.测试
  1) 先启动apache服务器httpd
  2) 启动名为tomcat2的服务器

在浏览器中输入访问地址http://localhost/test/index.html

可以看到请求被转发到了tomcat2进行处理
  3)启动tomcat 1 ,界面如下

可以发现,tomcat1启动后搜索到了tomcat2实例,并进行了session复制。在tomcat2的控制台也可以找到如下输出

4)关闭tomcat 2,后继续刷新url访问。tomcat1控制台中输出的session 依然与之前tomcat2中的一致,并且在session中保存的属性值仍然有效。
  5.问题
  上面的配置是在两台不同的配置上进行,tomcat负载和session复制都成功了。但是如果在同一台机子上配置,则session复制总是不能成功,搜索了很多解决方式都不正确。
页: [1]
查看完整版本: apache tomcat 6集群负载和session复制(转)