apache 2.2 + tomcat 6 + jdk 6 实现负载均衡,session复制(windows 单 pc)

这两天学习 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

#########################


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值