虽然网上有很多关于tomcat 集群的文章, 但是当自己动手搭建的时候还是觉得有必要写明些细节问题;
关于如何session 共享, 如何开启集群的原理就不做多余的解释, 网上很多很多了,下面开始正题……
这里用的apache-server 和tomcat + mod_jk(一个apache-server的额外服务插件)来 搭建的
apache-server, 和apache-tomcat 具体东西到apache官网上下载;
设置tomcat:
1、修改tomcat的 端口:
<Server port="8008" shutdown="SHUTDOWN">;
<Connector port="8092" protocol="HTTP/1.1" connectionTimeout="20000" redirectPort="8443" />;
<Connector port="8013" protocol="AJP/1.3" redirectPort="8443" />;
保证3个端口都不一样,并且每个tomcat相对应的端口也都不一样;
2、 放开这句的注释(在tomcat 的server.xml)当中
<Engine name="Catalina" defaultHost="localhost" jvmRoute="jvm1"> // 为当前运行时的jvm 给个别名, 方便其他地方调用
3、 放开这句的注释(在tomcat server.xml)当中
<Cluster className="org.apache.catalina.ha.tcp.SimpleTcpCluster"/> // 集群的关键设置地方,这里是tomcat 默认的设置 http负载均衡url重定向 的集群处理方式
// 默认情况下 所用的网段 244.0.0.8 内的所有tomcat 项目 都在集群范围(可通过配置更换)
设置apache-server:
1、下载mod_jk-1.2.31-httpd-2.2.3.so,我用的是2.2.X 的版本, 所以选择了这个;
2、在apache 的conf 目录下新建一个mod_jk.conf, workers.properites 文件内容如下:
mod_jk.conf 内容:
LoadModule jk_module modules/mod_jk-1.2.31-httpd-2.2.3.so
JkWorkersFile conf/workers.properties
#指定那些请求交给tomcat处理,"controller"为在workers.propertise里指定的负载分配控制器名
JkMount /* controller
workers.properties内容:
#server
worker.list = controller
#========tomcat1========
worker.tomcat1.port=1009
worker.tomcat1.host=localhost
worker.tomcat1.type=ajp13
worker.tomcat1.lbfactor = 1
#========tomcat2========
worker.tomcat2.port=2009
worker.tomcat2.host=localhost
worker.tomcat2.type=ajp13
worker.tomcat2.lbfactor = 1
#========tomcat3========
worker.tomcat3.port=3009
worker.tomcat3.host=localhost
worker.tomcat3.type=ajp13
worker.tomcat3.lbfactor = 1
#========controller,负载均衡控制器========
worker.controller.type=lb
worker.controller.balanced_workers=jvm1,jvm2,jvm3
worker.controller.sticky_session=0
worker.controller.sticky_session_force=1
项目:
在集群项目中, web.xml 文件里面要有 <distributable/> // session 共享的
在tomcat中,在context.xml文件里面 把开头标签修改为 <context distributable="true">
特别注意:在运行集群环境的时候,一定要是在联网状态下,不然会出现cluster 无法初始化等情况;而且有些情况下使用无线也不行,所以尽量使用有线吧;
在重新启动apache 和tomcat的时候,要把进程里面的httpd.exe 杀掉,不然每次重启都不会生效,严重影响测试!!!
至于性能方面的问题,还有待研究。。。
关于如何session 共享, 如何开启集群的原理就不做多余的解释, 网上很多很多了,下面开始正题……
这里用的apache-server 和tomcat + mod_jk(一个apache-server的额外服务插件)来 搭建的
apache-server, 和apache-tomcat 具体东西到apache官网上下载;
设置tomcat:
1、修改tomcat的 端口:
<Server port="8008" shutdown="SHUTDOWN">;
<Connector port="8092" protocol="HTTP/1.1" connectionTimeout="20000" redirectPort="8443" />;
<Connector port="8013" protocol="AJP/1.3" redirectPort="8443" />;
保证3个端口都不一样,并且每个tomcat相对应的端口也都不一样;
2、 放开这句的注释(在tomcat 的server.xml)当中
<Engine name="Catalina" defaultHost="localhost" jvmRoute="jvm1"> // 为当前运行时的jvm 给个别名, 方便其他地方调用
3、 放开这句的注释(在tomcat server.xml)当中
<Cluster className="org.apache.catalina.ha.tcp.SimpleTcpCluster"/> // 集群的关键设置地方,这里是tomcat 默认的设置 http负载均衡url重定向 的集群处理方式
// 默认情况下 所用的网段 244.0.0.8 内的所有tomcat 项目 都在集群范围(可通过配置更换)
设置apache-server:
1、下载mod_jk-1.2.31-httpd-2.2.3.so,我用的是2.2.X 的版本, 所以选择了这个;
2、在apache 的conf 目录下新建一个mod_jk.conf, workers.properites 文件内容如下:
mod_jk.conf 内容:
LoadModule jk_module modules/mod_jk-1.2.31-httpd-2.2.3.so
JkWorkersFile conf/workers.properties
#指定那些请求交给tomcat处理,"controller"为在workers.propertise里指定的负载分配控制器名
JkMount /* controller
workers.properties内容:
#server
worker.list = controller
#========tomcat1========
worker.tomcat1.port=1009
worker.tomcat1.host=localhost
worker.tomcat1.type=ajp13
worker.tomcat1.lbfactor = 1
#========tomcat2========
worker.tomcat2.port=2009
worker.tomcat2.host=localhost
worker.tomcat2.type=ajp13
worker.tomcat2.lbfactor = 1
#========tomcat3========
worker.tomcat3.port=3009
worker.tomcat3.host=localhost
worker.tomcat3.type=ajp13
worker.tomcat3.lbfactor = 1
#========controller,负载均衡控制器========
worker.controller.type=lb
worker.controller.balanced_workers=jvm1,jvm2,jvm3
worker.controller.sticky_session=0
worker.controller.sticky_session_force=1
项目:
在集群项目中, web.xml 文件里面要有 <distributable/> // session 共享的
在tomcat中,在context.xml文件里面 把开头标签修改为 <context distributable="true">
特别注意:在运行集群环境的时候,一定要是在联网状态下,不然会出现cluster 无法初始化等情况;而且有些情况下使用无线也不行,所以尽量使用有线吧;
在重新启动apache 和tomcat的时候,要把进程里面的httpd.exe 杀掉,不然每次重启都不会生效,严重影响测试!!!
至于性能方面的问题,还有待研究。。。