zoukankan      html  css  js  c++  java
  • 如何实现集群中的 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。

  • 相关阅读:
    JavaScript&DOM
    avalon.js的循环操作在表格中的应用
    merge()
    建立表空间以及用户
    SSI框架下,用jxl实现导出功能
    SQL递归查询实现组织机构树
    vue+webpack实践
    使用canvas绘制一片星空
    在canvas中使用html元素
    CSS3-transform 转换/变换
  • 原文地址:https://www.cnblogs.com/programb/p/13020037.html
Copyright © 2011-2022 走看看