Tomcat Cluster为什么在单机上能够Session同步但是在多机上就不行?-问答-阿里云开发者社区-阿里云

开发者社区> 问答> 正文
阿里云
为了无法计算的价值
打开APP
阿里云APP内打开

Tomcat Cluster为什么在单机上能够Session同步但是在多机上就不行?

2016-03-04 10:06:25 1884 1

特别奇怪的现象!

我用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)
  • 小旋风柴进
    2019-07-17 18:51:51
    已采纳

    1、session是基于系统机器的,即一个机器就一个session.
    2、单机器是木有问题的,因为都在同一个session中。
    3、多机器就涉及到了session共享的问题,你可以谷歌session共享问题找到答案。(普遍做法:使用一台公共的server用于session,如弄个server,使用redis来保存session)

    0 0
相关问答

0

回答

启动Tomcat报错Unsupported major.minor version xxx

2021-10-28 12:08:23 278浏览量 回答数 0

1

回答

启动tomcat报错?报错

2020-06-22 19:54:15 205浏览量 回答数 1

1

回答

启动Tomcat 报错?报错

2020-06-22 18:39:27 180浏览量 回答数 1

1

回答

C3P0这是报的啥错。。。启动tomcat就报错?报错

2020-06-14 20:21:45 419浏览量 回答数 1

1

回答

启动tomcat报错?报错

2020-06-09 14:04:09 173浏览量 回答数 1

1

回答

strus2启动tomcat报错,哪位大神可以指点下!?报错

2020-06-07 22:05:50 208浏览量 回答数 1

1

回答

Kylin启动时Tomcat报错,7070后台无法访问?报错

2020-06-05 15:59:29 1912浏览量 回答数 1

1

回答

winserver2008启动tomcat 报错

2017-02-25 12:18:50 1833浏览量 回答数 1

1

回答

NetBeans启动tomcat报错问题

2016-05-31 16:19:07 2318浏览量 回答数 1

1

回答

C3P0问题,启动tomcat就报错,求助。

2016-05-31 17:01:21 1811浏览量 回答数 1
2709
文章
6591
问答
问答排行榜
最热
最新
相关电子书
更多
低代码开发师(初级)实战教程
立即下载
阿里巴巴DevOps 最佳实践手册
立即下载
冬季实战营第三期:MySQL数据库进阶实战
立即下载