Nginx + Tomcat配置负载均衡

 所有的Tomcat webapp的web.xml加上<distributable />

(例如/usr/local/apache-tomcat-6.0.35/webapps/ROOT/WEB-INF\web.xml )

 实现tomcat的session复制。

原文: http://blog.csdn.net/kongxx/article/details/5516152  根据实际测试情况做过修改。

1. 安装Nginx和Tomcat,(Nginx可以从 http://nginx.org/en/download.html下载,tomcat可以从 http://tomcat.apache.org/download-60.cgi下载) 在这里假定Nginx安装在axs3-nginx,tomcat分别安装在axs3-r1和axs3-r2上; 2. 修改/etc/nginx/nginx.conf文件,    
  1. http  
  2. …  
  3.   upstream axs3-nginx  
  4.       server 172.16.86.161:8080 weight=1;  
  5.       server 172.16.86.162:8080 weight=2;  
  6.    
  7.   server  
  8.       …  
  9.        listen  80;
  10.        server_name   axs3-nginx;
  11.       location  
  12.           proxy_pass http://axs3-nginx 
  13.        
  14.       …  
  15.    
  16. …  
  17.  

3. 确定nginx和两台tomcat可以互访,并且两个tomcat机器在一个网段内;4. 确定两台tomcat多播已经打开,在Linux机器上可以使用cat /proc/net/dev_mcast检查,如果文件存在基本上就是打开了;另外确定两台tomcat机器的/etc/hosts文件中包含“xxx.xxx.xxx.xxx     hostname”比如“172.16.86.161        axs3-r1”或“172.16.86.162     axs3-r2”;

 
5. 修改两个tomcat的conf/server.xml文件,对Engine节点分别添加jvmRoute=”tomcat1”和jvmRoute=”tomcat2”,并添加以下内容:
      <Engine name=”Catalina” defaultHost=”localhost” jvmRoute=”tomcat1”> 

 
  1. <Cluster className=“org.apache.catalina.ha.tcp.SimpleTcpCluster”   
  2.     channelSendOptions=“6”>  
  3.       
  4.       
  5.     <Manager className=“org.apache.catalina.ha.session.DeltaManager”  
  6.         expireSessionsOnShutdown=“false”  
  7.         notifyListenersOnReplication=“true”/>  
  8.     <!–  
  9.     <Manager className=“org.apache.catalina.ha.session.BackupManager”  
  10.         expireSessionsOnShutdown=“false”  
  11.         notifyListenersOnReplication=“true”  
  12.         mapSendOptions=“6”/>  
  13.     –>  
  14.     <Channel className=“org.apache.catalina.tribes.group.GroupChannel”>  
  15.         <Membership className=“org.apache.catalina.tribes.membership.McastService”  
  16.             address=“228.0.0.5”  
  17.             port=“45564”  
  18.             frequency=“500”  
  19.             dropTime=“3000”/>  
  20.         <Receiver className=“org.apache.catalina.tribes.transport.nio.NioReceiver”  
  21.             address=“172.16.86.161”  
  22.             port=“4009”  
  23.             selectorTimeout=“100”  
  24.             maxThreads=“6”/>  
  25.         <Sender className=“org.apache.catalina.tribes.transport.ReplicationTransmitter”>  
  26.             <Transport className=“org.apache.catalina.tribes.transport.nio.PooledParallelSender”/>  
  27.         </Sender>  
  28.         <Interceptor className=“org.apache.catalina.tribes.group.interceptors.TcpFailureDetector”/>  
  29.         <Interceptor className=“org.apache.catalina.tribes.group.interceptors.MessageDispatch15Interceptor”/>  
  30.     </Channel>  
  31.     <Valve className=“org.apache.catalina.ha.tcp.ReplicationValve” filter=“.*/.gif;.*/.js;.*/.jpg;.*/.png;.*/.htm;.*/.html;.*/.css;.*/.txt;”/>  
  32.       
  33.     <ClusterListener className=“org.apache.catalina.ha.session.JvmRouteSessionIDBinderListener”/>  
  34.     <ClusterListener className=“org.apache.catalina.ha.session.ClusterSessionListener”/>  
  35. </Cluster>  

 

6. 所有的Tomcat webapp的web.xml加上(例如/usr/local/apache-tomcat-6.0.35/webapps/ROOT/WEB-INF\web.xml ) 实现tomcat的session复制。  


7.修改文件/usr/local/apache-tomcat-6.0.35/conf/web.xml,代码如下,    

        <welcome-file-list>
        <welcome-file>test.jsp</welcome-file>

        <welcome-file>index.html</welcome-file>

        </welcome-file-list>


 8. 在两个Tomcat的webapps/ROOT目录下各创建一个test.jsp文件,代码如下:

  1. <html>  
  2. <head>  
  3.     <title></title>  
  4. </head>  
  5. <body>  
  6. <%  
  7.     String mydata request.getParameter(“mydata”);  
  8.     if (mydata != null && mydata.length() != 0)  
  9.         session.setAttribute(“mydata”, mydata);  
  10.      
  11.       
  12.     out.println(“request.getLocalAddr(): ” request.getLocalAddr());  
  13.     out.println(“<br/>“);  
  14.     out.println(“request.getLocalPort(): ” request.getLocalPort());  
  15.     out.println(“<br/>“);  
  16.     out.println(“Session ID: ” session.getId());  
  17.     out.println(“<br/>“);  
  18.       
  19.     out.println(“mydata: ” session.getAttribute(“mydata”));  
  20. %>  
  21. <form>  
  22.     <input type=text size=20 name=“mydata”>  
  23.     <br>  
  24.     <input type=submit>  
  25. </form>  
  26. </body>  
  27. </html>  


9. 启动Tomcat和Nginx,访问 http://axs3-nginx参考资料: http://nginx.org/en
http://wiki.nginx.org/Main  


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值