3

我想建立一个包含两个节点的简单 Tomcat 集群。
我有两个虚拟机,它们是同一个本地网络的成员,并且可以互相看到。

在两个 Tomcats 集群配置部分(在 server.xml 中)是相似的:

    <Cluster className="org.apache.catalina.ha.tcp.SimpleTcpCluster" channelSendOptions="8">
        <Manager className="org.apache.catalina.ha.session.DeltaManager" expireSessionsOnShutdown="false" notifyListenersOnReplication="true"/>
        <Channel className="org.apache.catalina.tribes.group.GroupChannel">
          <Membership className="org.apache.catalina.tribes.membership.McastService" address="228.0.0.4" port="41166" frequency="500" dropTime="3000"/>
          <Receiver className="org.apache.catalina.tribes.transport.nio.NioReceiver" address="auto" port="4000" autoBind="100" selectorTimeout="5000" 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"/>
        </Channel>
        <Valve className="org.apache.catalina.ha.tcp.ReplicationValve" filter=""/>
        <Valve className="org.apache.catalina.ha.session.JvmRouteBinderValve"/>
        <Valve className="org.jasig.cas.client.tomcat.v7.StaticUriLogoutValve" logoutUri="/j_spring_cas_security_logout"/>
        <ClusterListener className="org.apache.catalina.ha.session.JvmRouteSessionIDBinderListener"/>
        <ClusterListener className="org.apache.catalina.ha.session.ClusterSessionListener"/>
    </Cluster>

当我启动两个 Tomcat 时,我的应用程序已启动并正在运行,但会话没有被复制(我必须登录两次)。

任何想法我做错了什么?

PS:我还没有任何负载均衡器。看起来tomcat集群使用广播并且不需要任何certral节点。如果我错了,请在这里纠正我。

4

1 回答 1

-1

Tomcat 记录您确实需要为粘性会话配置负载平衡器的站点。请检查最后一个要点:http: //tomcat.apache.org/tomcat-6.0-doc/cluster-howto.html#Cluster_Basics

看起来广播实际上并不是在集群中的节点之间广播会话。

于 2013-09-26T20:43:52.143 回答