天天看點

Apache負載均衡+Tomcat叢集(轉)

目标: 使用 apache 和 tomcat 配置一個可以應用的 web 網站,要達到以下要求: 1 、  Apache 做為 HttpServer ,後面連接配接多個 tomcat 應用執行個體,并進行負載均衡。 2 、  為系統設定 Session 逾時時間,包括 Apache 和 tomcat 3 、  為系統屏蔽檔案清單,包括 Apache 和 tomcat 注:本例程以一台機器為例子,即同一台機器上裝一個apache和4個Tomcat。 一、前期準備工作:安裝用的程式(前提保證已安裝了JDK1.5以上的版本) APAHCE 2.2.8 下載下傳:apache_2.2.8-win32-x86-no_ssl.msi TOMCAT6.0.14 下載下傳:apache-tomcat-6.0.14.zip直接解壓。 二、安裝過程 APAHCE 安裝目錄:D:/Apache。 四個TOMCAT目錄:自行解壓到(D:/Tomcat叢集伺服器/)下。分别為tomcat6.0,tomcat6.01,tomcat6.02,tomcat6.03 這幾個安裝過程就不詳細說明了。 三、配置 1 、Apache配置 1.1 、httpd.conf配置 修改APACHE的配置檔案D:/Apache /conf/httpd.conf 将以下Module的注釋去掉,這裡并沒有使用mod_jk.so進行apache和tomcat的連結,從2.X以後apache自身已內建了mod_jk.so的功能。隻需簡單的把下面幾行去掉注釋,就相當于以前用mod_jk.so比較繁瑣的配置了。這裡主要采用了代理的方法,就這麼簡單。

LoadModule proxy_module modules/mod_proxy.so 

LoadModule proxy_connect_module modules/mod_proxy_connect.so 

LoadModule proxy_ftp_module modules/mod_proxy_ftp.so 

LoadModule proxy_http_module modules/mod_proxy_http.so 

LoadModule proxy_ajp_module modules/mod_proxy_ajp.so 

LoadModule proxy_balancer_module modules/mod_proxy_balancer.so 再找到 <IfModule dir_module></IfModule> 加上index.jsp修改成 <IfModule dir_module> DirectoryIndex index.html index.jsp </IfModule> 1.1.1、   在最下面加入 ProxyRequests Off <proxy balancer://cluster> BalancerMember ajp://127.0.0.1:8009 loadfactor=1 route=jvm1 BalancerMember ajp:// 127.0.0.1:9009 loadfactor=1 route=jvm2 BalancerMember ajp:// 127.0.0.1:9001 loadfactor=1 route=jvm3 BalancerMember ajp:// 127.0.0.1:9003 loadfactor=1 route=jvm4 </proxy> 上面的四個BalancerMember成員是我們配置的tomcat叢集。後面會說明的。 1.2 、httpd-vhosts.conf設定 接下來進行虛拟主機的設定。APACHE的虛拟主機設定如下: 首先要修改 conf/httpd.conf找到(#Include conf/extra/httpd-vhosts.conf) 把注釋去掉。 # Virtual hosts Include conf/extra/httpd-vhosts.conf 在檔案(extra/httpd-vhosts.conf)最下面加入 <VirtualHost *:80>          ServerAdmin [email protected]          ServerName localhost          ServerAlias localhost          ProxyPass / balancer://cluster/ stickysession=jsessionid nofailover=On          ProxyPassReverse / balancer://cluster/ </VirtualHost> 其中的域名和路徑根據你自己情況設定 然後再設定TOMCAT虛拟主機 2  配置 tomcat 2.1.   配置 server 的關閉 我們需要在一台機器上跑 4 個不同的 tomcat ,需要修改不同的 tomcat 的關閉口,避免出現端口被占用的情況。其中tomcat6.0用預設值,不修改。其他三個修改。在tomcat6.01/conf, tomcat6.02/conf下和tomcat6.03/conf下的 server.xml 中找到 server, 将: <Server port="8005" shutdown="SHUTDOWN"> 改為 <Server port="XXXX" shutdown="SHUTDOWN"> XXXX  在這裡表示不同的端口:我的其它三個 tomcat 分别使用 9005,8006 , 9007    2.2.  配置 Engine   把原來的配置注釋掉,把下面一句去掉注釋。并标明jvmRoute="jvm2". <Engine name="Standalone" defaultHost="localhost" jvmRoute="jvm2">         以下是原來的配置。 <!-- <Engine name="Catalina" defaultHost="localhost">  --> 其他(tomcat6.02和tomcat6.03)也要同樣 配置。注意:jvmRoute配置不要一樣。 <Engine name="Standalone" defaultHost="localhost" jvmRoute="jvm3">  <Engine name="Standalone" defaultHost="localhost" jvmRoute="jvm4">  2.3.  配置 Connector 原來的預設配置。 <!-- Define an AJP 1.3 Connector on port 8009 --> <Connector port="8009" protocol="AJP/1.3" redirectPort="8443" /> 這裡是apache和tomcat連結的關鍵,前台apache就是通過AJP協定與tomcat進行通信的,以完成負載均衡的作用。也可以用HTTP協定。大家注意它們是如何連接配接通信的,上面的紅色部分(port="8009")就是連接配接的接口了。 把其他三個tomcat的<Connector port="XXX" />port分别改成與上面 <proxy balancer://cluster>      # 與tomcat6.0對應,route與<Engine jvmRoute="jvm1">對應。 BalancerMember ajp://127.0.0.1:8009 loadfactor=1 route=jvm1 # 與tomcat6.01對應,route與<Engine jvmRoute="jvm2">對應。 BalancerMember ajp:// 127.0.0.1:9009 loadfactor=1 route=jvm2 # 與tomcat6.02對應,route與<Engine jvmRoute="jvm3">對應。 BalancerMember ajp:// 127.0.0.1:9001 loadfactor=1 route=jvm3 # 與tomcat6.03對應,route與<Engine jvmRoute="jvm4">對應。 BalancerMember ajp:// 127.0.0.1:9003 loadfactor=1 route=jvm4 </proxy> 中的端口對應,tomcat6.01 的ajp端口port:9009. tomcat6.02 的ajp端口port:9001。tomcat6.03的ajp端口port:9003.一定要與上面的一緻。同時也要把redirectPort的值改成唯一的,確定四個tomcat的都不一樣。 2.5. 配置Cluster(每個tomcat中都要修改) 原來的配置。 <Cluster className="org.apache.catalina.ha.tcp.SimpleTcpCluster"/> 修改為以下的代碼:<Receiver port=”XX”/>port也要保證唯一性。 <Cluster className="org.apache.catalina.ha.tcp.SimpleTcpCluster"  channelSendOptions="6"> <Manager className="org.apache.catalina.ha.session.BackupManager" expireSessionsOnShutdown="false" notifyListenersOnReplication="true" mapSendOptions="6"/> <!-- <Manager className="org.apache.catalina.ha.session.DeltaManager" expireSessionsOnShutdown="false" notifyListenersOnReplication="true"/> --> <Channel className="org.apache.catalina.tribes.group.GroupChannel"> <Membership className="org.apache.catalina.tribes.membership.McastService" address="228.0.0.4" port="45564" frequency="500" dropTime="3000"/> <Receiver className="org.apache.catalina.tribes.transport.nio.NioReceiver" address="auto" port="5001" selectorTimeout="100" maxThreads="6"/> <Sender className="org.apache.catalina.tribes.transport.ReplicationTransmitter"> <Transport className="org.apache.catalina.tribes.transport.nio.PooledParallelSender"/> </Sender> <Interceptor className="org.apache.catalina.tribes.group.interceptors.TcpFailureDetector"/> <Interceptor className="org.apache.catalina.tribes.group.interceptors.MessageDispatch15Interceptor"/> <Interceptor className="org.apache.catalina.tribes.group.interceptors.ThroughputInterceptor"/> </Channel> <Valve className="org.apache.catalina.ha.tcp.ReplicationValve" filter=".*/.gif;.*/.js;.*/.jpg;.*/.png;.*/.htm;.*/.html;.*/.css;.*/.txt;"/> <Deployer className="org.apache.catalina.ha.deploy.FarmWarDeployer" tempDir="/tmp/war-temp/" deployDir="/tmp/war-deploy/" watchDir="/tmp/war-listen/" watchEnabled="false"/> <ClusterListener className="org.apache.catalina.ha.session.ClusterSessionListener"/> </Cluster> 這個設定是主要用以tomcat的叢集。 四、啟動服務,測試tomcat自帶的例子 1 、測試apache和tomcat協作。 先在每個tomcat中的/webapps/ROOT下的index.jsp下面加上以下的測試代碼部分:(X代表不同的tomcat的輸出不同的資訊),把index.html删除,以免影響測試效果。在最後面的加上.即</table></body>之間。 <%       System.out.println("tomcat6.0X  deal  with  request"); %> 然後再通過http://  127.0.0.1 來通路一下,就會出現大家熟悉的貓貓。 然後再通過分别通路 http://  127.0.0.1:8080, http:// 127.0.0.1:9080,http:// 127.0.0.1:8081,http://127.0.0.1:9002它們通路的内容和上面的http:// 127.0.0.1 是一樣的。 這樣就說明apache和TOMCAT整合成功! 2 、測試均衡器 通過http://  127.0.0.1 多次通路,要想看到真正的效果,必須用一些壓力測試工具,可用微軟Microsoft Web Application Stress Tool進行簡單壓力測試,不然你靠不停重新整理是展現不出來的,你隻會在一個tomcat的控制台有輸出結果。隻用用壓力測試工具模拟大量使用者同時通路,你會發現四個tomcat控制台均有打出控制資訊,說明均衡器工作正常。

本文出自 “魏傑的技術專欄” 部落格,請務必保留此出處http://weijie.blog.51cto.com/340746/68195