Tomcat集群

配置Tomcat集群

多台服务器中,如何实现Session共享?现以Tomcat集群为例,学习一下。

 

软件环境:apache-tomcat-6.0.14 + apache_2.2.4-win32-x86-no_ssl.msi

 

以下是我在动手之前及动手之后总结的问题一览:

 

1、如何实现负载均衡。

 

2、如何实现Session共享。

 

3、如何对外提供服务,即可以通过局域网IP访问。

 

一、安装apache_2.2.4-win32-x86-no_ssl.msi。自行选择安装目录,如:J:\Apache2.2。Windows安装后,Apache会变成系统自启动服务,任务栏右下角显示Apache Monitor图标。

 

二、复制四份apache-tomcat-6.0.14,分别命名为:apache-tomcat-6.0.14-A,apache-tomcat-6.0.14-B,apache-tomcat-6.0.14-C,apache-tomcat-6.0.14-D。

 

 

三、修改配置文件:

 

1) 修改J:\Apache2.2\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_ajp_module modules/mod_proxy_ajp.so

LoadModule proxy_balancer_module modules/mod_proxy_balancer.so

LoadModule proxy_connect_module modules/mod_proxy_connect.so

LoadModule proxy_http_module modules/mod_proxy_http.so

LoadModule proxy_ftp_module modules/mod_proxy_ftp.so

其次,找到<IfModule dir_module></IfModule>加上index.jsp修改成 

<IfModule dir_module> 
DirectoryIndex index.html index.jsp 
</IfModule> 

再次,找到【# Virtual hosts】,取消后续注释:

Include conf/extra/httpd-vhosts.conf

最后,在httpd.conf最末尾添加:

ProxyRequests Off 

ProxyPass / balancer://cluster/

<proxy balancer://cluster> 

BalancerMember ajp://127.0.0.1:8009 loadfactor=1 route=jvm1

BalancerMember ajp://127.0.0.1:8019 loadfactor=1 route=jvm2 

BalancerMember ajp://127.0.0.1:8029 loadfactor=1 route=jvm3

BalancerMember ajp://127.0.0.1:8039 loadfactor=1 route=jvm4 

 

</proxy>

 

2) 修改conf/extra/httpd-vhosts.conf,在文件最后添加:

<VirtualHost *:80> 

 ServerAdmin yourserver

 ServerName localhost 

 ServerAlias localhost 

 ProxyPass / balancer://cluster/ stickysession=jsessionid nofailover=On lbmethod=bytraffic

 ProxyPassReverse / balancer://cluster/ 

</VirtualHost>

 

3) 修改Tomcat的server.xml

Tomcat-A:修改的最少,其中:

a、Engine选择【<Engine name="Standalone" defaultHost="localhost" jvmRoute="jvm1">】,注释【<Engine name="Catalina" defaultHost="localhost">】

b、Cluster选择【<Cluster className="org.apache.catalina.ha.tcp.SimpleTcpCluster"/>】,取消注释即可,可以根据网上具体配置实现Cluster的不同方式,此处使用简单方式,没有其他配置。

Tomcat-B:改为

a、<Server port="8015" shutdown="SHUTDOWN">

b、<Connector port="8180" protocol="HTTP/1.1" 

c、<Connector port="8019" protocol="AJP/1.3" redirectPort="8443" />

d、<Engine name="Standalone" defaultHost="localhost" jvmRoute="jvm2">类比Tomcat-A

e、<Cluster className="org.apache.catalina.ha.tcp.SimpleTcpCluster"/>类比Tomcat-A

Tomcat-C:

a、<Server port="8025" shutdown="SHUTDOWN">

b、<Connector port="8280" protocol="HTTP/1.1" 

c、<Connector port="8029" protocol="AJP/1.3" redirectPort="8443" />

d、<Engine name="Standalone" defaultHost="localhost" jvmRoute="jvm3">类比Tomcat-A

e、<Cluster className="org.apache.catalina.ha.tcp.SimpleTcpCluster"/>类比Tomcat-A

Tomcat-D:

a、<Server port="8035" shutdown="SHUTDOWN">

b、<Connector port="8380" protocol="HTTP/1.1" 

c、<Connector port="8039" protocol="AJP/1.3" redirectPort="8443" />

d、<Engine name="Standalone" defaultHost="localhost" jvmRoute="jvm4">类比Tomcat-A

e、<Cluster className="org.apache.catalina.ha.tcp.SimpleTcpCluster"/>类比Tomcat-A

 

四、测试Apache负载均衡

a) 修改Tomcat中webapps\Root\index.jsp文件,根据不同Tomcat分别添加以下内容(在</table>和</body>之间,红色部分可变):

<% 

      System.out.println("tomcat6.0-A deal with request"); 

%>

b) 通过浏览器访问http://localhost/ 不停刷新,可以看到不同Tomcat的console都有输出。则说明:Apache服务器根据配置实现集群的负载均衡。

 

五、实现Session共享

a) 在Tomcat中webapps中添加test目录,并创建test.jsp文件,内容如下:

<%@ page contentType="text/html; charset=GBK" %>

<%@ page import="java.util.*" %>

<html><head><title>Cluster App Test</title></head>

<body>

Server Info:

<%

out.println(request.getLocalAddr() + " : " + request.getLocalPort()+"<br>");%>

<%

  out.println("<br> ID " + session.getId()+"<br>");

  // 如果有新的 Session 属性设置

  String dataName = request.getParameter("dataName");

  if (dataName != null && dataName.length() > 0) {

     String dataValue = request.getParameter("dataValue");

     session.setAttribute(dataName, dataValue);

  }

  out.println("<b>Session 列表</b><br>");

  System.out.println("============================");

  Enumeration e = session.getAttributeNames();

  while (e.hasMoreElements()) {

     String name = (String)e.nextElement();

     String value = session.getAttribute(name).toString();

     out.println( name + " = " + value+"<br>");

         System.out.println( name + " = " + value);

   }

%>

  <form action="test.jsp" method="POST">

    名称:<input type=text size=20 name="dataName">

     <br>

    值:<input type=text size=20 name="dataValue">

     <br>

    <input type=submit>

   </form>

</body>

</html>

b) 为test项目添加WEB-INF文件夹,web.xml文件,内容如下:

<web-app xmlns="http://java.sun.com/xml/ns/j2ee" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" 

    xsi:schemaLocation="http://java.sun.com/xml/ns/j2ee http://java.sun.com/xml/ns/j2ee/web-app_2_4.xsd" version="2.4"> 

       <display-name>TomcatDemo</display-name> 

       <distributable/> 

</web-app>

 

六、测试Tomcat集群Session共享

使用浏览器访问:http://localhost/test/test.jsp


Tomcat集群
 
Tomcat集群
 
Tomcat集群
 
Tomcat集群
  发现SessionId及每次提交到Session中内容在4台服务中得到共享。

 

七、对外提供服务,局域网内可访问

如果局域网内其他IP主机无法访问该服务,只能通过本地localhost 或者 127.0.0.1访问,请从以下找原因

a) 是否关闭防火墙,或者添加对该服务访问的入网规则,简单直白的方式是关闭防火墙。

b) httpd.conf中【Listen 80】不要【Listen 127.0.0.1】

c) httpd-vhosts.conf中【<VirtualHost *:80>】不要【<VirtualHost 127.0.0.1:80> 】

 

以上内容参考了以下内容:

1、http://www.iteye.com/topic/1017961

2、http://jiajun.iteye.com/blog/278586

3、http://itemdetail.iteye.com/blog/792671

 

PS:

个人总结:一般分布式系统的session管理分为三种:1.复制;上述样例即属于此种情况,弊端是存在明显瓶颈,多台主机之间相互复制session信息,急剧增加网络压力。2.设置专门session主机,其他主机通过网络连接共享session。3.将session信息通过cookie由用户浏览器本地管理,淘宝即采用此模式。