1、目的:为了高可用,需要搭建两个web容器构成集群(比如两个tomcat 、两个nginx),并且需要用户无感知(即会话需要共享)
2、解决方案:
2.1 会话信息不能采用j2ee自带的session变量来存储,采用redis来存储(或者任何第三方的共享来存储)
2.2用户登入成功之后,在后台生成一个UUID的唯一码,并把信息写入到redis(key为uuid,value为用户的信息,过期时间为12小时(可以根据业务需要改变)),同时在用户浏览器的cookie写入uuid
2.3用户的每次浏览器点击(或者请求),浏览器都会自动把cookie加入请求的头部,后端代码这边读取request 的head,取出uuid,然后去redis上校验用户是否已经登入即可。
3、进一步的优化方案
上述方案的弊端是每次用户的请求都会去请求redis,会导致redis压力较大。可以在用户登入成功之后,也设置session的值(request.getSession().setAttribute("XXX", XXXX))
,然后用户每次的请求都先读取session里面的值,session没有值才去读取redis上的内容(同时也设置一次session,防止下一次又去读取redis)。