`
zyycaesar
  • 浏览: 93977 次
  • 性别: 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集群配置详解 把Apache安装为运行在80端口的Windows服务,安装成功后在系统服务列表中可以看到Apache2.2服务。对于已安装IIS的机器,在启动Apache服务之前必须首先停止IIS Admin服务,不然会因为端口...

    Apache + Tomcat集群配置详解

    Apache + Tomcat集群配置详解

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

    Apache+Tomcat负载均衡与集群配置详解 网上很多资料,但是很多不完整,或者仅有负载均衡或者只有集群,本文是建立实践通过的基础上

    Apache2.2.11 + Tomcat 6.0.20 集群配置详解

    最新Apache2.2.11 + Tomcat 6.0.20 集群配置详解,版主亲测试,并且布署了真实的项目进行了测试,session 成功共享。欢迎大家下载。

    apache +tomcat集群 ajp_proxy实际操作

    apache安装,配置;tomcat下载,配置,设置为服务,有详解

    Apache Tomcat 集群 配置详解(真实项目)

    该文档是我综合了无数相关文档,在我公司项目实施成功后总结的一套文档,经历了数次改动,希望能指引大家少走弯路。 如有表述不清的地方请联系我:QQ:603678227 共同进步。

    tomcat集群

    Apache+Tomcat集群配置详解,rar是我测试的例子

    Windows 下使用 Apache + Tomcat 实现Web集群环境(负载均衡/反向代理)

    下载完成后,将压缩包解压到位,并将多余的 ...2、安装配置 Apache 环境。 3、安装配置 Tomcat 集群环境。 具体的详细操作步骤及参数详解请参考: https://blog.csdn.net/hello_world_qwp/article/details/79698334

    Tomcat技术资源

    apache+Tomcat负载平衡设置详解,Linux_Apache+Tomcat集群配置,Tomcat工作原理,tomcat技术文档,tomcat配置手册

    tomcat—apache集群虚拟主机

    tomcat—apache集群虚拟主机配置详解!

    Nginx+Tomcat搭建高性能负载均衡集群的实现方法

    一、 目标实现高性能负载均衡的Tomcat集群: 二、步骤 1、首先下载Nginx,要下载稳定版: 2、然后解压两个Tomcat,分别命名为apache-tomcat-6.0.33-1和apache-tomcat-6.0.33-2: 3、然后修改这两个Tomcat的...

    Apache2.2以上版本与Tomcat整合配置及负载均衡实现

    下面是实现2个tomcat实现负载均衡,如果只有一个则可删除一个 apache2.2以上版本,无需使用jk_mod来集成tomcat,直接使用ajp,很方便。 修改apache配置文件httpd.conf 启用mod_proxy_ajp 代码如下: #LoadModule ...

    Nginx+Tomcat高性能负载均衡集群搭建教程

    其占有内存少,并发能力强,在同类型的网页服务器中表现较好。...在这里我们采用集群部署方式,使用多个Tomcat,反向代理使用Nginx。 架构如下: 准备工作 apache-tomcat-7.0.61 nginx-1.12.2 Redis-x64-3.2.10

    JAVA web.xml配置详解

    -- 配置集群的时候,要用到,在这篇文章:“apache+tomcat集群、负载均衡及session复制”里的第三条(http://jiajun.javaeye.com/admin/blogs/278586) --&gt; &lt;!-- context-param 元素用来设定web站台的环境...

    tomcat6_apache2.2_ajp 负载均衡加集群实战分享

    tomcat服务器:均配置相同的应用。 1.集群名:balancer://tomcatcluster 2.三台集群服务器ip: IP_1:192.168.1.31 IP_2:192.168.1.32 IP_3:192.168.1.33 3.测试应用程序test文件夹放在tomcat6的webapps目录下 操作...

    用apache和tomcat搭建集群(负载均衡)

    一、集群和负载均衡的概念 (一)集群的概念  集群(Cluster)是由两台或多台节点机(服务器)构成的一种松散耦合的计算节点集合,为用户提供网络服务或应用程序(包括数据库、Web服务和文件服务等)的单一客户视图,...

    nginx+tomcat实现Windows系统下的负载均衡搭建教程

    刚入行没多久就听过‘负载均衡’的大名,到现在因为工作接触的少,所以没什么太多的认识。但自己又对其非常的好奇,所以前两天通过查资料,在...下载地址:https://tomcat.apache.org/download-80.cgi (这是8.0版本

Global site tag (gtag.js) - Google Analytics