Spring安全性的并发会话控制在tomcat 7集群环境中无法正常工作,但在非集群环境中工作正常。还会在tomcat中复制.Sessions也会在tomcat中复制。
群集配置:
<Cluster channelSendOptions="6" className="org.apache.catalina.ha.tcp.SimpleTcpCluster">
<Manager className="org.apache.catalina.ha.session.DeltaManager" expireSessionsOnShutdown="false" notifyListenersOnReplication="true"/>
<Channel className="org.apache.catalina.tribes.group.GroupChannel">
<Membership address="228.0.0.9" className="org.apache.catalina.tribes.membership.McastService" dropTime="3000" frequency="500" port="45564"/>
<Receiver address="auto" autoBind="100" className="org.apache.catalina.tribes.transport.nio.NioReceiver" maxThreads="6" port="5008" selectorTimeout="5000"/>
<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"/>
<Deployer className="org.apache.catalina.ha.deploy.FarmWarDeployer" deployDir="/tmp/war-deploy/" tempDir="/tmp/war-temp/" watchDir="/tmp/war-listen/" watchEnabled="false"/>
<ClusterListener className="org.apache.catalina.ha.session.JvmRouteSessionIDBinderListener"/>
<ClusterListener className="org.apache.catalina.ha.session.ClusterSessionListener"/>
</Cluster>
apache负载平衡配置:
ProxyPass / balancer://domain.foo.net/ lbmethod=byrequests stickysession=JSESSIONID|jsessionid nofailover=Off maxattempts=15
ProxyPreserveHost On
<Proxy balancer://domain.abcprocure.net>
BalancerMember http://127.0.0.1:8888 max=250 min=45 keepalive=On route=tc02
BalancerMember http://127.0.0.1:8080 max=250 min=45 keepalive=On route=tc01
</Proxy>
将不胜感激。
答案 0 :(得分:4)
默认的SessonRegistry
是一个内存实现,所以你在每个JVM中都会有一个不同的,而不会意识到其他的。
您需要以在VM之间共享数据的方式实现SessionRegistry
接口。这可以使用SQL数据库,memcached,redis或任何最适合您情况的内容。
一旦编写了类,reference manual就会显示如何使用显式SessionRegistry
bean配置并发控制。