• 如何实现集群中的 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!
  • 相关阅读:
    225. 用队列实现栈
    232. 用栈实现队列
    459.重复的子字符串(简单)
    28. 实现 strStr()(简单)
    剑指 Offer 58
    541. 反转字符串 II(简单)
    浏览器渲染页面的过程、重绘、重排以及页面优化
    隐藏一个元素的几种方法
    当我们在浏览器中输入一个URL后,发生了什么?
    Object.create() 和 new Object()、{} 的区别
  • 原文地址:https://www.cnblogs.com/programb/p/13020738.html
Copyright © 2020-2023  润新知