配置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
发现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由用户浏览器本地管理,淘宝即采用此模式。