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

分布式session实现方式

时间:2017-05-10 14:40:40      阅读:170      评论:0      收藏:0      [点我收藏+]

标签:分布式   session   集群   

    当一个传统的Web项目需要从单点扩张成为集群式时候,需要考虑的一个问题:分布式Session的实现。通常分布式session有三种解决方式,现对三种方式进行简单记录:

    1.session广播

    顾名思义,广播就是在集群里的所有服务器将他们的session向其他服务器进行同步,使得每一台服务器上都有其他服务器的session信息,这样,不管请求进入那个服务器,都可以获取session信息。这种方式从理解和实现方面都比较简单,同时避免了单点故障引起的session丢失问题。但是因为广播是多台服务器同步的过程,会有一定的延时性,所以只适用于集群规模小,网络开销小的情况。

    2.粘性session

    这是一种指定session的方法,在集群的路由处对所有的请求做出指定服务器的分发,使得某个携带session的请求每次都进入同一台后端服务器。这种方式没有额外的网络开销,适用于中等规模的集群,但是由于每条请求都对应一个服务器,所以当有服务器Down机时,相应的session会丢失,出现单点故障。

    3.缓存集中式管理

    将session信息单独取出,所有的session信息都放在指定缓存中进行集中式管理,所有携带session的请求都会先进入这里处理,然后向后端服务器进行相应的分发。通常使用的缓存有memcache、redis等。这种方式使用于大型集群,方便增加集群节点,但稳定性性依赖于缓存的稳定性,需要有合理的写入策略,避免缓存失效后session丢失。

本文出自 “塞上名猪” 博客,请务必保留此出处http://zuohao1990.blog.51cto.com/6057850/1924025

分布式session实现方式

标签:分布式   session   集群   

原文地址:http://zuohao1990.blog.51cto.com/6057850/1924025

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