0
点赞
收藏
分享

微信扫一扫

面试问题:redis系列

陆公子521 2022-03-19 阅读 62

memcached 与 redis 的区别?

如何实现集群中的 session 共享存储?

Session 是运行在一台服务器上的,所有的访问都会到达我们的唯一服务器上,
这样我们可以根据客户端传来的 sessionID,来获取 session,或在对应 Session
不存在的情况下(session 生命周期到了/用户第一次登录),创建一个新的
Session;但是,如果我们在集群环境下,假设我们有两台服务器 A,B,用户
的请求会由 Nginx 服务器进行转发(别的方案也是同理),用户登录时,Nginx
将请求转发至服务器 A 上,A 创建了新的 session,并将 SessionID 返回给客户
端,用户在浏览其他页面时,客户端验证登录状态,Nginx 将请求转发至服务器
B,由于 B 上并没有对应客户端发来 sessionId 的 session,所以会重新创建一
个新的 session,并且再将这个新的 sessionID 返回给客户端,这样,我们可以
想象一下,用户每一次操作都有 1/2 的概率进行再次的登录,这样不仅对用户体
验特别差,还会让服务器上的 session 激增,加大服务器的运行压力。
为了解决集群环境下的 seesion 共享问题,共有 4 种解决方案:
1.粘性 session
粘性 session 是指 Ngnix 每次都将同一用户的所有请求转发至同一台服务器上,即将用户与
服务器绑定。
2.服务器 session 复制
即每次 session 发生变化时,创建或者修改,就广播给所有集群中的服务器,使所有的服务
器上的 session 相同。
3.session 共享
缓存 session,使用 redis, memcached。
4.session 持久化
将 session 存储至数据库中,像操作数据一样才做 session。

举报

相关推荐

0 条评论