tomcat 集群负载均衡

虽然网上有很多关于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 杀掉,不然每次重启都不会生效,严重影响测试!!!

至于性能方面的问题,还有待研究。。。
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值