Java Tomcat群集配置问题:两个节点彼此不同步

Java Tomcat群集配置问题:两个节点彼此不同步,java,tomcat,virtual-machine,cluster-computing,Java,Tomcat,Virtual Machine,Cluster Computing,我想建立一个由两个节点组成的简单Tomcat集群。 我有两个虚拟机,它们是同一个本地网络的成员,可以看到彼此 在这两个Tomcats中,集群配置部分(在server.xml中)类似: <Cluster className="org.apache.catalina.ha.tcp.SimpleTcpCluster" channelSendOptions="8"> <Manager className="org.apache.catalina.ha.sessi

我想建立一个由两个节点组成的简单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时,我的应用程序已经启动并运行,但是会话没有被复制(我必须登录两次)

知道我做错了什么吗


附言:我还没有任何负载平衡器。看起来tomcat集群使用广播,不需要任何特定节点。如果我错了,请在这里纠正我。

Tomcat文档站点,您确实需要为粘性会话配置负载平衡器。请检查最后一点:


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

此集群在哪里运行?你能确认这两个实例是否相互看到了吗?chrylis:我正在努力弄清楚,thx为提示。我询问了有关设置的问题,因为一些VM环境(尤其是Amazon EC2)对广播/多播的支持有限,仅仅因为你可以建立一个明确的连接并不意味着一个发现机制就能工作。我真的不明白最后一条的意思。如果我们使用粘性会话,为什么需要会话共享?