由于负载均衡服务器可能会将请求分发到集群任何一台服务器上,所以保证每次请求能够获得正确的session比单机时复杂。

集群环境下,session管理的主要几种手段

1.session复制

session复制是早期的企业级的使用比较多的一种服务器集群session管理机制。应用服务器开启web容器的session复制功能,在集群中的几台服务器之间同步session对象,使得每台服务器上都保存所有的session信息,这样任何一台宕机都不会导致session的数据丢失,服务器使用session时,直接从本地获取。

这种方式在应用集群达到数千台的时候,就会出现瓶颈,每台都需要备份session,出现内存不够用的情况。

2.session绑定

利用hash算法,比如nginx的ip_hash,使得同一个Ip的请求分发到同一台服务器上。

这种方式不符合对系统的高可用要求,因为一旦某台服务器宕机,那么该机器上的session也就不复存在了,用户请求切换到其他机器后么有session,无法完成业务处理。

3.利用cookie记录session(最普遍的做法)

session记录在客户端,每次请求服务器的时候,将session放在请求中发送给服务器,服务器处理完请求后再将修改后的session响应给客户端。这里的客户端就是cookie。

利用cookie记录session的也有缺点,比如受cookie大小的限制,能记录的信息有限;每次请求响应都需要传递cookie,影响性能,如果用户关闭cookie,访问就不正常。但是由于

cookie的简单易用,可用性高,支持应用服务器的线性伸缩,而大部分要记录的session信息比较小,因此事实上,许多网站或多或少的在使用cookie记录session。

4.session服务器(最安全的做法)

session服务器可以解决上面的所有的问题,利用独立部署的session服务器(集群)统一管理session,服务器每次读写session时,都访问session服务器。

这种解决方案事实上是应用服务器的状态分离,分为无状态的应用服务器和有状态的session服务器,然后针对这两种服务器的不同特性分别设计架构。

对于有状态的session服务器,一种比较简单的方法是利用分布式缓存(memcached), 数据库等。在这些产品的基础上进行包装,使其符合session的存储和访问要求。

如果业务场景对session管理有比较高的要求,比如利用session服务基层单点登录(sso),用户服务器等功能,需要开发专门的session服务管理平台。

最新文章

  1. Flexbox——快速布局神器
  2. css3360度旋转动画
  3. Java导入证书失败Keystore was tampered with, or password was incorrect
  4. Linux系统目录/bin /sbin /usr/bin /usr/sbin和/lib /usrlib的一些分析
  5. ajax.js
  6. net大型分布式电子商务架构
  7. openlayer的凸包算法实现
  8. C语言老司机学Python (四)
  9. Spring官方文档下载
  10. C# 实现Jwtbearer Authentication
  11. BIM 相关资料
  12. piwik custom variables
  13. python + selenium webdriver 自动化测试 之 环境异常处理 (持续更新)
  14. mysql 权限管理介绍
  15. CentOS7服务器上搭建Gitlab
  16. Windows Phone 修改系统定义的资源颜色
  17. vue2 自定义全局组件(Loading加载效果)
  18. CSS3不一样的下拉选择框
  19. $Android制作和使用Nine-Patch图片
  20. nginxif多条件结合判断(实现限速)

热门文章

  1. 【如何入门ACM】
  2. bzoj 4565 字符合并
  3. Intent详解以及实例
  4. UITextField的使用总结
  5. nginx 流量拷贝模块 ngx_http_mirror_module 安装试用
  6. C51 一个非常有用的位操作 --- 其中一位置 0 其它位不变
  7. form表单中name和id区别
  8. 64位linux下rpm安装mysql的5.5.55版本
  9. EXCEL类型库的添加
  10. Jenkins的用户管理