首页   注册   登录
V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
华为云
V2EX  ›  程序员

负载均衡后的 Session 同步问题有什么成熟的好用的方案?

  •  
  •   aricch · 157 天前 · 3102 次点击
    这是一个创建于 157 天前的主题,其中的信息可能已经有所发展或是发生改变。

    各位老铁,nginx 做负载均衡 反代到 tomcat 后的用户 Session 同步 有什么成熟的好用的方案?

    42 回复  |  直到 2018-03-16 12:10:08 +08:00
        1
    uqf0663   157 天前   ♥ 2
    存 redis 里
        2
    autumnshine   157 天前
    spring session
        3
    liwl   157 天前
    存 redis 里
        5
    fzleee   157 天前
    使用一致性哈希算法负载均衡,这样就可以避免 session 同步
        6
    aricch   157 天前
    @uqf0663
    @autumnshine
    @liwl
    @linyinma 都看过相应 方案,也自己试过 Memcached,结果发现大量不同同步的情况,各位 有没有实际用过,以及遇到过有哪些坑儿?
        7
    aricch   157 天前
    @fzleee 求详解
        8
    realityone   157 天前 via iPhone
    最简单加密存到 cookie 里
        9
    af463419014   157 天前
    存 redis +1
        10
    Moker   157 天前
    Reids 或者 JWT ?
        11
    z1154505909   157 天前
    存 redis+2
        12
    pathbox   157 天前 via iPhone
    用 ip hash 负载算法 或者就是用 redis 存
        13
    wentx   157 天前
    存 redis +10086
        14
    gouchaoer   157 天前   ♥ 1
    不可以用 ip hash,因为 ip 会变
        15
    yy120345   157 天前
    redis
        16
    novacn   157 天前
    spring session
        17
    baiy   157 天前
    session 一致性架构设计实践
    http://mp.weixin.qq.com/s/NnnqVrC9-Jekwy3Opmvy_w
        18
    aricch   157 天前
    @realityone 有些信息不想存本地

    @gouchaoer 对,不能用 ip,尤其是移动应用,分分钟 wifi 到 4G,互相切换 。
    @all 推荐 redis 的,有坑儿吗?稳定吗?
        19
    q397064399   157 天前
    首推 Redis Spring 有相应的接口 一行代码都不用写,Redis 可以考虑购买 阿里云的 Redis 集群,避免宕机
        20
    nicevar   157 天前   ♥ 1
    关注一下,这个问题不是上面一堆人的一句存 redis 那么简单,实际情况很复杂,与业务上有很大的关系,比如请求是否是无标识单向的,一台 session 服务器宕机之后这部分用户处理问题,同步成本开销等等,楼主搞定了记得分享一下
        21
    kenshin912   157 天前 via iPhone
    ip_hash
    或者 Redis
        22
    aricch   157 天前
    @novacn
    @q397064399 你俩说的是同一个东西吗?

    @baiy
    @nicevar 感谢
        23
    TZ   157 天前
    看来都是用 redis 的
        24
    binux   157 天前
    加密,存用户那
        25
    hambut   157 天前
    JWT
        26
    likuku   157 天前
    @nicevar memcached 差不多 10 年前就有日本人搞出来双向自动同步的简单集群分支。
        27
    fzleee   157 天前
    @aricch 参见 @baiy 回复文章链接的第三节,反向代理 hash 一致性
        28
    q397064399   157 天前
    @nicevar #20
    https://mp.weixin.qq.com/s/NnnqVrC9-Jekwy3Opmvy_w


    无标识单向,不明白是什么 请指教。

    Session 服务器宕机? Redis 有集群,master 节点挂了 还有 slave,Redis 还有一致性 hash
    可用性是完全可以保证的,后端存 Session 存 Token 基本上都是采取集中式的处理,,
    这样 web 服务 可以水平扩展,但实际上 web 服务扩展 看不到什么卵用,,
    之前的一个项目,压力全在 DB 上,即使水平扩展 web 服务 也是看不到什么卵用的,
    搞 web 还是 把数据库搞明白,该填的 都得填了
        29
    vance   157 天前
    1.Nginx 一致性 Hash 2.Redis 管理 3.不用 Session
        30
    night98   157 天前 via Android
    最近新开项目搭框架的时候也遇到了这个问题,目前比较主流的方案就是 redis 共享 session,使用 springboot+springsession 的话一行代码就解决了,其他的就是 jwt,相当于用户信息加密保存到 c 端,每次请求带上这个数据即可,优点是服务器无 session 化,经过对比后我选的是 redis 共享的方案,比较方便
        31
    janxin   157 天前
    我来说一个不一样的,cookies 植入后端服务器信息(没必要写 ip 域名),前端负载均衡根据 cookie 选择。不保证请求均衡,可支持水平伸缩。
        32
    RubyJack   157 天前
    客户端方案是用 JWT 这类,服务端方案就是 Session 集中存储
        33
    wucao219101   157 天前
    Spring Seession + Redis 用的很舒服

    http://xxgblog.com/2016/09/29/spring-session-redis/
        34
    vibbow   157 天前
    同时存本机和共享数据库里。
    LB 做 sticky session。

    这样绝大多数情况都不会牵扯到 session 共享
    一旦一个机子掉了,请求被打到另一台服务器上,也可以通过共享数据库取出 session
        35
    jasonchn   157 天前 via Android
    @janxin 这样的话,负载均衡本身还要实现高可用,要考虑负载均衡之间同步 server id 表的问题。
        36
    gandofyan   157 天前
    spring session + apache Geode 集群

    低延迟, 高并发和一致性都可以保证
        37
    jorneyr   157 天前
    JWT 挺好的
        38
    janxin   157 天前
    @jasonchn #35 无论什么样的方案,入口总是要可用的,server_id 表同步方式也有很多
        39
    1762628386   157 天前
    都别一句话完事啊 有没有大佬结合自己使用中的场景讲讲的
        40
    aricch   156 天前
    @fzleee ip_hash 不行的,换 ip 了就不一定在登录那台服务器上了。
        41
    aricch   156 天前
    @vance
    @night98
    @wucao219101
    @RubyJack
    @wucao219101
    @vibbow
    @gandofyan
    @jorneyr
    @1762628386
    @q397064399
    @likuku
    @TZ
    @binux
    @hambut 各位感谢,准备用 Redis 再实践一下。
    @janxin 感谢新思路
        42
    JRay   156 天前
    存 redis +1
    关于   ·   FAQ   ·   API   ·   我们的愿景   ·   广告投放   ·   鸣谢   ·   实用小工具   ·   552 人在线   最高记录 3762   ·  
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.1 · 19ms · UTC 21:31 · PVG 05:31 · LAX 14:31 · JFK 17:31
    ♥ Do have faith in what you're doing.
    沪ICP备16043287号-1