翻翻过去那场雪
分两种情况:一. 如果用户001在客户端A登录, 然后在客户端B登录, 系统强制A下线.二. 如果用户001在客户端A登录, 然后在客户端B登录, 提示001已经登录, 禁止其登录.下面介绍下我对方案二的看法:在集群的情况下, 需要使用中心的cache集群(比如memcached). 为了达到一个时刻一个用户仅有一个会话, 需要做一个userId(用户在系统的唯一标识, 或者memberId之类的)的缓存. 下面几个问题需要注意: 1. 当用户登录时, 首先需要查询当前用户对应的userId在缓存中是否已经存在. 如果存在, 拒绝登录 2. userId在缓存中的超时时间应该和session保持一致. 当访问系统时, 同时也需要延长userId的生命周期. 可以每N分钟刷新一次. 3. 当系统退出时, 在清除session的同时也需要清除userId. 4. 存在的问题: 如果客户端是浏览器. 在用户001在浏览器A登录后, 以非常规的方式登出, 比如关闭浏览器而不是点击登出按钮, 此时服务中userId的缓存任然存在, 用户无法在其他浏览器中登录, 只能等到缓存失效后方能登录. 基于这个原因. 我推荐选择方案一