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.总结

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

最新文章

  1. windows 下wamp环境1 配置之apache的安装
  2. PHP的Tag标签
  3. CentOS 7 使用经验(更新中)
  4. Invoke与BeginInvoke
  5. 【FSFA 读书笔记】Ch 2 Computer Foundatinons(2)
  6. 屏蔽电信流氓广告造成的诡异的问题--Android WebView 长时间不能载入页面
  7. 两台机子的repcached Memcache 的安装与实验
  8. Unity 消息发送机制 解析
  9. JVM菜鸟进阶高手之路五
  10. 蓝鲸 CTF web——密码泄露
  11. Oracle 11gR1 RAC存储迁移方案
  12. [原创]Delphi XE10 dxLayoutControl 控件应用指南
  13. 重磅:Spring Boot 2.0 正式发布!
  14. IT人如何打造个性化的个人网站(在线简历)
  15. 51Nod 1001 数组中和等于K的数对
  16. webpack、npm、nginx常用命令
  17. 要想找出包含“w”的名字
  18. avalon.js 文字显示更多与收起
  19. 【Android】11.4 Fragment及其生命周期
  20. 【题解】MUTC2013idiots

热门文章

  1. 硬盘 SMART 检测参数详解[转]
  2. java debugger
  3. Chris Richardson微服务实战系列
  4. Android开发环境搭建篇详尽的教程实例汇
  5. Android 加载大图
  6. 用“网建”平台发手机短信的C#代码
  7. [na]IP分片抓包实验
  8. 文档 - STOMP Over WebSocket
  9. U盘启动ubuntu 12.04
  10. 精通Docker的50个必备教程、工具、资源