我想设置一个包含两个节点的简单Tomcat集群。
我有两个虚拟机是同一本地网络的成员,可以看到对方。Tomcat集群配置问题:两个节点不能彼此同步
在(在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>
当我开始都雄猫,我的应用程序启动并运行,但不会对会话进行复制(我需要登录在两次)。
任何想法我做错了什么?
P.S .:我还没有任何负载平衡器。它看起来像tomcat集群使用广播,并不需要任何证书节点。请在这里纠正我,如果我错了。
此群集在哪里运行?你有没有确认这两个实例互相看到? – chrylis
chrylis:我试图弄清楚,thx的提示。 – Roman
我问过这个设置,因为有些虚拟机环境(特别是Amazon EC2)对广播/多播的支持有限,并且仅仅因为你可以建立一个明确的连接并不意味着发现机制会起作用。 – chrylis