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 杀掉,不然每次重启都不会生效,严重影响测试!!!

至于性能方面的问题,还有待研究。。。
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章