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。

    Java Program!
  • 相关阅读:
    PAT:1069. The Black Hole of Numbers (20) AC
    PAT:1008. Elevator (20) AC
    PAT:1052. Linked List Sorting (25) 部分错误
    PAT:1032. Sharing (25) AC
    PAT:1059. Prime Factors (25) AC
    素数表(筛选法)
    PAT:1048. Find Coins (25)(双指针法) AC
    PAT:1048. Find Coins (25)(二分查找) AC
    iOS 9.0 设置状态栏颜色 和隐藏
    UIPageViewController用法
  • 原文地址:https://www.cnblogs.com/programb/p/13020738.html
Copyright © 2011-2022 走看看