特别奇怪的现象!
我用xen开了两个虚拟机,想要让它们之间Session同步。
按照官方的指导教程配置完成之后,Session怎么也不能同步。
但如果只用一个虚拟机上面运行两个Tomcat,打开不同的端口,这种状态下Session就能同步?
我感觉问题发生在跨机器之间数据包没收到。
难道是组播的问题?或者防火墙?不过防火墙我已经彻底关掉了啊。(debian没自带防火墙)
粘一段关于Cluster配置的代码(其实跟官方文档几乎一模一样):
<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="45564" 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>
<Value className="org.apache.catalina.ha.tcp.ReplicationValve" filter=""/>
<Value className="org.apache.catalina.ha.session.JvmRouteBinderValve"/>
<Deployer className="org.apache.catalina.ha.deploy.FarmWarDeployer" tempDir="/tmp/war-temp/" deployDir="/tmp/war-deploy/" watchDir="/tmp/war-listen/" watchEnabled="false"/>
<ClusterListener className="org.apache.catalina.ha.session.ClusterSessionListener"/>
</Cluster>
1、session是基于系统机器的,即一个机器就一个session.
2、单机器是木有问题的,因为都在同一个session中。
3、多机器就涉及到了session共享的问题,你可以谷歌session共享问题找到答案。(普遍做法:使用一台公共的server用于session,如弄个server,使用redis来保存session)
请问,你的问题解决了吗?我也遇到了同样的问题,1台机器2个tomcat用cluster可以session复制,同样的配置2台机器就不好用了。求帮助!