当一个传统的Web项目需要从单点扩张成为集群式时候,需要考虑的一个问题:分布式Session的实现。通常分布式session有三种解决方式,现对三种方式进行简单记录:
1.session广播
顾名思义,广播就是在集群里的所有服务器将他们的session向其他服务器进行同步,使得每一台服务器上都有其他服务器的session信息,这样,不管请求进入那个服务器,都可以获取session信息。这种方式从理解和实现方面都比较简单,同时避免了单点故障引起的session丢失问题。但是因为广播是多台服务器同步的过程,会有一定的延时性,所以只适用于集群规模小,网络开销小的情况。
2.粘性session
这是一种指定session的方法,在集群的路由处对所有的请求做出指定服务器的分发,使得某个携带session的请求每次都进入同一台后端服务器。这种方式没有额外的网络开销,适用于中等规模的集群,但是由于每条请求都对应一个服务器,所以当有服务器Down机时,相应的session会丢失,出现单点故障。
3.缓存集中式管理
将session信息单独取出,所有的session信息都放在指定缓存中进行集中式管理,所有携带session的请求都会先进入这里处理,然后向后端服务器进行相应的分发。通常使用的缓存有memcache、redis等。这种方式使用于大型集群,方便增加集群节点,但稳定性性依赖于缓存的稳定性,需要有合理的写入策略,避免缓存失效后session丢失。
时间: 2024-10-23 19:55:08