码迷,mamicode.com
首页 > 其他好文 > 详细

分布式session实现

时间:2018-06-06 18:30:09      阅读:170      评论:0      收藏:0      [点我收藏+]

标签:重分布   session丢失   系统性能   导致   数据   简便   为什么   需要   优点   

1.为什么要做分布式session

  前段时间在做hibernate和docker集成时,在web项目落地时遭遇session粘性的困扰,同一个用户的申请落到不同服务端时,会发生session丢失的问题,由此引发分布式session的必要。

2.如何实现session共享

  1.在服务端做session同步,保证每个负载服务端的session数据相同

    优点:代码改造方便

    缺点:占用网络传输,降低系统性能;session容量占用,不利于服务端水平扩展

  2.客户端保存session,使得每次请求都携带相同session

    优点:降低服务端存储

    缺点:占用请求网络传输,每次都携带session;网络传输session并不安全,存在泄漏、篡改、窃取等安全隐患

  3.指定hash算法,将请求固定分配到指定服务端

    优点:不需要修改代码;负载均匀;

    缺点:当服务端重分布或者重启时,有可能导致session的丢失,导致访问出错

  4.后端缓存存储session

    优点:无网络传输;有利于扩展

    缺点:增加插件,需要修改代码

3.总结

  “端存储”不是一种常规思路,常规情况下,第三种和第四种方案是较为安全简便,代价也较低的方案

分布式session实现

标签:重分布   session丢失   系统性能   导致   数据   简便   为什么   需要   优点   

原文地址:https://www.cnblogs.com/garfieldcgf/p/8323527.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!