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 殺掉,不然每次重啓都不會生效,嚴重影響測試!!!

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