这两天学习 apache + tomcat 负载均衡及session复制,特写博文一篇,用以记录交流..
部分内容转载自 : http://www.iteye.com/topic/1017961
一.准备:apache 2.2 , tomcat 6 ,JDK 6(后边会说明),mod_jk-1.2.31-httpd-2.2.3.so
环境: windows 一台PC 两个tomcat
方式一:mod_jk
图片走起~
1.安装多个tomcat:简单方法,下载安装版本tomcat:
tomcat 需要的 jre 路径
重复以上步骤,在增加一个 tomcat 服务(端口必须不一样)
2.两个tomcat 目录 分别为 c:\apache\tomcat1,c:\apache\tomcat2
在每个tomcat 目录下 conf\Catalina\localhost目录下建立一
个cluster.xml文件,其内容为:
<?xml version="1.0" encoding="UTF-8"?>
<Context docBase="c:/apache/Cluster"
privileged="true" antiResourceLocking="false" antiJARLocking="false"
distributable="true">
</Context>
3.启动tomcat 服务,根据不同端口号访问
地址如:localhost:8080/cluster/test2.jsp
地址如:localhost:8081/cluster/test2.jsp
成功启动,则部署成功。
4.配置
#######以下引用
修改Apache配置
1、修改httpd.conf
我的Apache安装在c:\apach\httpd,找到conf目录下的httpd.conf,在文件的最后一行添加
include "c:\apach\httpd\conf\mod_jk.conf"
2、新建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 /*.jsp controller
3、将下载的JK插件mod_jk-1.2.31-httpd-2.2.3.so复制到Apache安装目录的modules目录下。
4、新建并编辑workers.properties文件,内容如下:
#server
worker.list = controller
#========tomcat1========
worker.tomcat1.port=11009
worker.tomcat1.host=localhost
worker.tomcat1.type=ajp13
worker.tomcat1.lbfactor = 1
#========tomcat2========
worker.tomcat2.port=12009
worker.tomcat2.host=localhost
worker.tomcat2.type=ajp13
worker.tomcat2.lbfactor = 1
#========tomcat3========
worker.tomcat3.port=13009
worker.tomcat3.host=192.168.0.80 //在我的虚拟机中的,可以算远程的吧
worker.tomcat3.type=ajp13
worker.tomcat3.lbfactor = 1
#========controller,负载均衡控制器========
worker.controller.type=lb
worker.controller.balanced_workers=tomcat1,tomcat2,tomcat3
worker.controller.sticky_session=false ##是否配置 粘性session(及将session绑定在某tomcat上,session不会复制)
worker.controller.sticky_session_force=1 ## 若默认tomcat 无反应,是否将请求转到其他tomcat
#worker.controller.sticky_session=1
这里可以配置任意多个Tomcat,此处配置了3个Tomat服务器,2个本地,1个远程,所以为了它们都能够顺利启动起来,
本地的服务器端口都是不同的,如果Tomcat不再同一机器上,没必要改端口的。
配置Tomcat
配置3个Tomcat服务器,将Tomcat解压后复制3份,我将每个文件夹分别命名为Tomcat1,Tomcat2和Tomcat3,
修改每一份的server.xml配置,将Tomcat1中修改部分如下图:
Tomcat2中以上部分的server.xml为:
Tomcat3中以上部分的server.xml为:
因为Tomat3在远程服务器,所以没必要改端口的,而我先进行的本地集群测试后将Tomcat3复制到远程服务器,
所以这3个Tomcat端口都不同。
AJP13的connector的poat和jvmRoute名称和workers.properties中配置对应。
由于截图面积有限,还需要保证本地2个本地Tomcat配置server的port,connector为http1.1的port都不相同。
### 引用结束
5 修改Cluster 节点
将上图 <Cluster className="org.apache.catalina.ha.tcp.SimpleTcpCluster"/> 注释掉(不修改,
本地session复制存在Bug),修改为
<Cluster className="org.apache.catalina.ha.tcp.SimpleTcpCluster"
channelSendOptions="6">
<Manager className="org.apache.catalina.ha.session.BackupManager"
expireSessionsOnShutdown="false"
notifyListenersOnReplication="true"
mapSendOptions="6"/>
<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="4000"
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;"/>
<ClusterListener className="org.apache.catalina.ha.session.ClusterSessionListener"/>
</Cluster>
另外 tomcat 也需修改,并修改文件中 Receiver 节点中的 port ,其余不变。
建立test项目,需要在项目的web.xml中添加<distributable/>
建立test2.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="test2.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>
上面的测试页面就不解释了,很好理解。
6. session 测试测试如原帖,但结果不大相同。
测试步骤如下
1)启动两个tomcat 服务,顺序随意,不启动apache服务
2) 通过tomcat1/bin/tomcat1.exe,
omcat2/bin/tomcat2.exe 启动tomcat服务,
启动apache服务
访问地址:localhost/cluster/test2.jsp
访问路径,刷新刷新:
带参数:
关闭tomcat2:
继续刷新,session依然存在
以上测试,应该可以判断 负载均衡成功,session复制应该也成功了,
至于route值为什么不变化,还没弄清楚,请路过大神解惑
(ps;关闭tomcat1,通过tomcat2访问 ,route依然是.tomcat1)
################铛铛铛铛(异常错误)
1. apache 日志 :connect to 127.0.0.1:11009 failed (errno=61) --->
检查server.xml 及 httpd.conf,workers.properties
2. 通过exe文件启动 tomcat是 无法集群 错误信息:
unable to process request in nioreceiver,xxxxxxxxx
原因尚未研究,解决方法 :使用tomcat7的同学 搭配使用jdk7 ,
使用tomcat6的搭配使用jdk6
3.留空待补充
结束: windows 环境下一台pc 多tomcat 集群测试,
基本达到目标,实现负载均衡,session复制(?待研究,
请路过大神瞅瞅)
至此,暂时完结
推荐博文:http://www.cnblogs.com/peter9/archive/2011/12/18/2362138.html
http://www.iteye.com/topic/1017961
http://yulinyyb001.iteye.com/blog/1308609
#########################