首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >Spring security 3并发会话控制在tomcat集群环境中不起作用

Spring security 3并发会话控制在tomcat集群环境中不起作用
EN

Stack Overflow用户
提问于 2012-11-21 18:34:40
回答 1查看 2.7K关注 0票数 3

Spring security的并发会话控制在Tomcat7集群环境中不能正常工作,但在非集群environment.Sessions中工作良好,在tomcat中也可以复制。

集群配置:

代码语言:javascript
复制
<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负载均衡配置:

代码语言:javascript
复制
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>

如果能得到进一步的帮助,我们将不胜感激。

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2012-11-21 20:01:47

缺省的SessonRegistry是一个内存中的实现,所以在每个JVM中都有一个不同的JVM,它不知道其他的。

您需要以在VM之间共享数据的方式实现SessionRegistry接口。这可以使用SQL数据库、memcached、redis或任何最适合您的情况。

编写好类后,reference manual将展示如何使用显式的SessionRegistry bean配置并发控制。

票数 4
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/13491335

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档