• 如何实现集群中的 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。

    Java Program!
  • 相关阅读:
    python之路_爬虫之selenium模块
    python之路_爬虫之requests模块补充
    扩展中国剩余定理讲解
    扩展中国剩余定理讲解
    bzoj3225 [Sdoi2008]立方体覆盖——扫描线
    差分约束讲解
    CF917C Pollywog —— 状压DP + 矩乘优化
    斜率优化讲解
    AC自动机讲解
    BZOJ2870—最长道路tree
  • 原文地址:https://www.cnblogs.com/programb/p/13020738.html
Copyright © 2020-2023  润新知