zoukankan      html  css  js  c++  java
  • 分布式系统session一致性解决方案

      在单机系统中,不存在Session共享问题,但是在分布式系统中,我们必须实现session共享机制,使得多台应用服务器之间会话统一,如果不进行Session共享会出现数据不一致,比如:会导致请求落到不同服务器要重复登录的情况。

     解决方案

    1.session复制
    原理:任何一个服务器上的session发生改变(增删改),该节点会把这个 session的所有内容序列化,然后广播给所有其它节点,不管其他服务器需不需要session,以此来保证Session同步。

    优点可容错,各个服务器间session能够实时响应。
    缺点:

    • 大量的session的同步需要数据传输,占内网带宽,有时延,拖慢服务器性能。

    • 有更多web-server时,容易造成网络风暴。

     

    2. 客户端存储
    将session存储到浏览器cookie中。每次请求服务器的时候,将session放在请求中发送给服务器,服务器处理完请求后再将修改后的session响应给客户端。
    缺点:

    • 数据存储在端上,并在网络传输,存在泄漏、篡改、窃取等安全隐患。
    • session存储的数据大小受cookie限制。

    3. 粘性session

    原理:粘性Session是指将用户锁定到某一个服务器上,例如用户第一次请求时,负载均衡器(nginx)将用户的请求转发到了A服务器上,如果负载均衡器设置了粘性Session的话,那么用户以后的每次请求都会转发到A服务器上,相当于把用户和A服务器粘到了一块,这就是粘性Session机制。

    优点:简单,不需要对session做任何处理。

    缺点:

    • 如果服务器出现故障,一部分session会丢失,会产生业务影响,例如部分用户重新登录。
    • 如果服务器水平扩展,rehash后session重新分布,也会有一部分用户路由不到正确的session。

    4. 后端统一集中存储

    原理:将session存储在一个单独的服务器的存储层,数据库或者缓存,一般用redis/memchache缓存。

    优点:服务器出现问题,session不会丢失。

    缺点:如果网站的访问量很大,把session存储到数据库中,会对数据库造成很大压力,还需要增加额外的开销维护数据库。

    refer:https://www.cnblogs.com/yumingxing/p/9505512.html

  • 相关阅读:
    SQL 数据库中将某表中的一列数据拆分作为查询条件
    SQL数据库导入数据时提示未在本地计算机上注册“Microsoft.ACE.OLEDB.12.0”提供程序。 (System.Data)
    SQL常用内置函数
    SQL常用语句
    关于网页中鼠标双击文字选中设置
    SQL数据库查询列的类型及长度
    ASP. NET MVC项目 使用iTextSharp将网页代码生成PDF文件
    eslint-config-airbnb vs prettier vs standard
    windows批处理(bat脚本)
    python日志库loguru
  • 原文地址:https://www.cnblogs.com/-wenli/p/11991288.html
Copyright © 2011-2022 走看看