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 殺掉,不然每次重啓都不會生效,嚴重影響測試!!!
至於性能方面的問題,還有待研究。。。
關於如何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 殺掉,不然每次重啓都不會生效,嚴重影響測試!!!
至於性能方面的問題,還有待研究。。。
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.