`
zyycaesar
  • 浏览: 94404 次
  • 性别: Icon_minigender_1
  • 来自: 北京
社区版块
存档分类

Apache + Tomcat集群配置详解 (2)

阅读更多

四、Tomcat配置

 

    如果仅仅为了配置一个可用的集群,Tomcat的配置将会非常简单。分别打开t1和t2的server.xml配置文件,对于t1,尽量采用默认的设置,而对t2作较大改动以避免与t1冲突。如果t2和t1不在同一台服务器上运行,对于端口就不需做改动。

 

    首先是配置关闭端口,找到<Server port="8005" shutdown="SHUTDOWN">,t1不变,把t2改为9005。

 

    下面配置Connector的端口,找到non-SSL HTTP/1.1 Connector,即tomcat单独工作时的默认Connector,保留t1默认配置,在8080端口侦听,而把t2设置为在9080端口侦听。

 

    往下找到AJP 1.3 Connector,<Connector port="8009" protocol="AJP/1.3" redirectPort="8443" />,这是tomcat接收从Apache过来的ajp连接请求时使用的端口,保留t1默认设置,把t2端口改为9009。注意,这里的端口对应Apache httpd.conf中BalancerMember中配置的ajp连接端口。

 

    继续向下配置引擎,找到<Engine name="Catalina" defaultHost="localhost">,去掉这段或改为注释,把上方紧挨的<Engine name="Catalina" defaultHost="localhost" jvmRoute="jvm1">注释符去掉,对于t2,去掉注释符并把jvm1改为jvm2。这里的jvmRoute对应Apache httpd.conf中BalancerMember中配置的route参数。

 

    向下找到<Cluster className="org.apache.catalina.ha.tcp.SimpleTcpCluster"/>,打开注释,这里的配置是为了可以在集群中的所有tomcat节点间共享会话(Session)。如果仅仅为了获得一个可用的tomcat集群,Cluster只需要这么配置就可以了,对于更多的Cluster配置笔者将另文解释。

 

    server.xml的配置修改完毕,下一步需要对具体的应用进行配置。在webapps目录下新建test目录,在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>");
  String dataName = request.getParameter("dataName");
 
  if (dataName != null && dataName.length() > 0) {
     String dataValue = request.getParameter("dataValue");
     session.setAttribute(dataName, dataValue);
  } 
 
  out.print("<b>Session 列表</b>"); 
 
  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>

 

     在test目录下继续新建WEB-INF目录和web.xml,在<web-app>节点下加入<distributable />,这一步非常重要,是为了通知tomcat服务器,当前应用需要在集群中的所有节点间实现Session共享。如果tomcat中的所有应用都需要Session共享,也可以把conf/context.xml中的<Context>改为<Context distributable="true">,这样就不需对所有应用的web.xml再进行单独配置。

 

    启动t1,待t1启动完成后再启动t2。再次访问http://localhost,可以看到小猫页面。访问http://localhost/test/test.jsp。可以看到包括服务器地址,端口,sessionid等信息在内的页面。

    

    注意这里的sessionid,与平常的sessionid相比多了小数点和后面的部分,这里的jvm1即处理当前请求tomcat服务器的jvmRoute,通过这里可以知道是集群中的哪一个服务器处理了当前请求。在文本框中输入名称和值,点击按钮,信息就保存到了Session中,并且显示到页面上。不断点击按钮,可以发现输入的信息并未丢失,而且sessionid小数点之前的部分保持不变,而小数点后面的字符不停的变化,表明是由不同的tomcat服务器处理了这些请求。这样就实现了负载均衡,并且集群中的不同节点间可以实现会话的共享。此时如果停止一个tomcat服务器t2,Apache将会自动把后续请求转发到集群中的其他服务器即t1。重启t2后,Apache会自动侦测到t2的状态为可用,然后会继续在t1和t2间进行负载均衡。

 

    如果需要向集群中增加节点,首先需要对tomcat作类似配置,然后修改Apache httpd.conf,增加BalancerMember,指向新增的tomcat即可。

分享到:
评论
21 楼 chinalian 2015-12-22  
zenghong237 写道
楼主啊。在一台机器上测试通过,可是当部署在两台机器上的时候session不会共享啊


Receiver address不能填写auto,填写具体的IP就可以了。
<Receiver className="org.apache.catalina.tribes.transport.nio.NioReceiver"
                      address="172.28.1.53"
20 楼 Silence安吉尔 2015-08-24  
19 楼 myprincejava 2014-10-13  
我想问一下,负载均衡+集群都配置成功了,demo session也可以复制,但是把web项目copy进去。session有时候会丢失。这种情况是什么原因呢?
18 楼 Allen_J_Will 2014-07-29  

感谢楼主提供这么好的文章
17 楼 一绿青苔 2014-06-14  
为什么局域网内可以访问,放到服务器上,配置之后,本机没有问题,其他机器访问就无法访问了,为啥呢?
16 楼 jianghg2010 2014-02-26  
不错,讲得很好,简单易懂!
15 楼 xumin_wlt 2013-07-02  
您好,按照这个配置我已经配置成功了,但是如何将静态资源放到apache的映射目录下呢?该如何设置呢?现在的静态资源都在tomcat下面。
14 楼 YoungQQ 2012-11-19  
好贴,我也按楼主说的试试。
13 楼 BackJoker 2012-02-02  
楼主理解深刻,强顶。。。
12 楼 mojinchuan 2012-01-13  
7 楼 zah5897 2010-09-27   引用
我的是apache 2.2.16  tomcat 6.0.26按照Lz的配置完全通过,上面说没有配置通过的估计是有些地方配置错了所导致的,我之前也有session不能共享的情况,后来来回找了几遍终于通过了
-------------、
7楼的zah5897兄弟,你好,你说的后来来回找了几遍 找出来是哪里配置错了,能具体说一下吗。多谢分享
11 楼 mojinchuan 2012-01-13  
apache-tomcat-6.0.35.zip
httpd-2.2.21-win32-x86-no_ssl
版本分别是以上
10 楼 mojinchuan 2012-01-13  
9 楼 zenghong237 2011-01-11   引用
楼主啊。在一台机器上测试通过,可是当部署在两台机器上的时候session不会共享啊
------------
我也遇到这个问题。
9 楼 zenghong237 2011-01-11  
楼主啊。在一台机器上测试通过,可是当部署在两台机器上的时候session不会共享啊
8 楼 nicholasjiajia 2010-12-03  
好帖 谢谢!!!
7 楼 zah5897 2010-09-27  
我的是apache 2.2.16  tomcat 6.0.26按照Lz的配置完全通过,上面说没有配置通过的估计是有些地方配置错了所导致的,我之前也有session不能共享的情况,后来来回找了几遍终于通过了
6 楼 haiyangyiba 2010-06-29  
感谢楼主。
5 楼 ddh9504 2010-04-19  
根据楼主的两篇贴子,我做了个例子,完全通过,感谢楼主无私分享!
4 楼 fangin 2010-04-13  
我测试的结果是负载均衡可实现。session复制可实现。但现象和楼主描述的有点出入,
sessionid第一次进入页面后就不再变化,小数点前和小数点后都不会变化
3 楼 xiejin2008 2009-12-14  
楼主刚刚重新测试,下载tomcat5版本,发现tomcat5中是可以是实现session复制的.

tomcat1 和tomcat2是Apache Tomcat Version 6.0.20


在这样的集群条件下面,均衡负载时可以实现的,但是并没有实现session的共享.





tomcat3 和tomcat4是Apache Tomcat Version 5.5.28

在这样的集群条件下面,均衡负载时可以实现的,并且可以实现session的共享.


发现两个版本的tomcat中 conf/server.xml里面的文件内容不一样

主要是这段:

        <Cluster className="org.apache.catalina.cluster.tcp.SimpleTcpCluster"
                 managerClassName="org.apache.catalina.cluster.session.DeltaManager"
                 expireSessionsOnShutdown="false"
                 useDirtyFlag="true"
                 notifyListenersOnReplication="true">

            <Membership
                className="org.apache.catalina.cluster.mcast.McastService"
                mcastAddr="228.0.0.4"
                mcastPort="45564"
                mcastFrequency="500"
                mcastDropTime="3000"/>

            <Receiver .....................

以上这段是tomcat5里面的.

一下这段是tomcat6里面的:
<Cluster className="org.apache.catalina.ha.tcp.SimpleTcpCluster"/>

仅仅就这一句话,没有那么多详细的配置内容.



2 楼 xiejin2008 2009-12-14  
我用的tomcat6版本,apache2.2 均衡负载可以实现,点击按钮,后面的jvm1,jvm2不停地的交换显示,但是前面的sessionID总是变化的,所以并没有成功设置成session共享,请求楼主,可能哪个地方存在问题呢?

相关推荐

    apache+tomcat集群配置

    ### Apache+Tomcat集群配置详解 #### 基础篇 ##### 1.1 系统部署 在本文档的基础篇中,首先介绍了系统部署的相关步骤。为了搭建一个基于Apache和Tomcat的集群环境,作者提供了以下具体的操作指导: 1. **测试...

    Apache+Tomcat集群配置

    ### Apache+Tomcat集群配置详解 #### 一、技术基础 Apache和Tomcat均属于Apache基金会旗下的开源项目,二者在Web服务领域各自扮演着重要的角色。Apache是一款强大的HTTP Web服务器,支持多种操作系统(如Windows、...

    apache+tomcat集群文档

    - 本文档针对Apache Tomcat集群配置进行了详尽的说明,特别适合新手入门学习,通过本文档能够快速掌握Apache Tomcat集群的基本概念、搭建步骤及注意事项。 #### 知识点详解: ##### 一、集群基础知识 1. **学习...

    Apache+Tomcat+Linux集群和负载均衡

    - 通过浏览器访问`http://172.16.116.1/index.jsp`,检查是否能够成功访问,并观察日志文件确认请求是否被正确地分发至Tomcat集群中的不同节点。 #### 四、注意事项 1. **权限问题**: 确保所有操作均以具有足够...

    Apache+Tomcat集群和负载均衡的资料

    ### Apache+Tomcat集群与负载均衡配置详解 #### 一、环境说明 为了实现Apache与Tomcat集群的负载均衡,我们需要准备以下环境: 1. **服务器配置**:四台服务器,其中一台安装Apache,三台安装Tomcat。 - Apache...

    apache+tomcat集群.doc

    ### Apache + Tomcat 集群配置详解 #### 背景介绍 随着互联网应用规模的不断增大,单台服务器已经难以满足日益增长的服务需求。为了提高系统的可用性与性能,构建一个高可用且高性能的应用架构变得尤为重要。在这种...

    apache+tomcat+jk集群

    在“apache+tomcat+jk集群”这一主题中,我们将深入探讨如何通过Apache、Tomcat以及JK模块的结合,实现负载均衡和集群配置,从而提升系统的性能和稳定性。 ### Apache的角色 Apache是一款广泛使用的开源Web服务器...

    apache+tomcat集群的基本配置(简明)

    ### Apache+Tomcat集群的基本配置详解 #### 一、引言 随着互联网应用的日益增长,单个服务器已经无法满足高并发访问的需求。为了提高系统的可用性和扩展性,集群技术应运而生。Apache作为一款优秀的Web服务器软件,...

    Apache+Tomcat负载均衡与集群配置详解

    Apache+Tomcat负载均衡与集群配置是提升Web应用性能和高可用性的重要手段。这篇文章将详细介绍如何使用Apache作为前端负载均衡器,与多台Tomcat服务器配合构建集群环境。 首先,我们要理解负载均衡的基本概念,它是...

Global site tag (gtag.js) - Google Analytics