为了账号安全,请及时绑定邮箱和手机立即绑定

在微服务下如何实现session共享?

在微服务下如何实现session共享?

偶然的你 2018-12-12 15:11:09
在微服务下如何实现session共享
查看完整描述

1 回答

?
湖上湖

TA贡献2003条经验 获得超2个赞

通过组播的方式进行集群间的共享

比如tomcat目前就具备这样的功能,优点是web容器自身支持,配置简单,适合小型网站。缺点是当一台机器的上的 session变更后会将变更的数据以组播的形式分发给集群间的所有节点,对网络和所有的web容器都是存在开销。集群越大浪费越严重。不能做到线性的扩 展。

 利用NFS等一些共享存储来共享Session数据

大致就是有一台公共的NFS服务器做共享服务器,当然也可以采用数 据库,所有的Web服务器都把session数据写到共享存储介质上,也都要来这台服务器获取session数据,通过这样的方式来实现Session数 据的共享。

相比前面组播的方式来说,网络开销较小。缺点是受制于存储设备的依赖,如果存储设备down掉,就无法工作了,要做好主备同步等一些容灾措施。 另外,当访问量过大时,磁盘的IO也是一个非常大的问题。

利用Memcache来存储共享Session数据

这可能也是目前 互联网中比较流行的一种用法。所有Web服务器都把Session写入到memcache,也都从memcache来获取。

memcache本身就是一个 分布式缓存,便于扩展。网络开销较小,几乎没有IO。性能也更好。缺点,受制于Memcache的容量(除非你有足够内存存储),如果用户量突然增多 cache由于容量的限制会将一些数据挤出缓存,另外memcache故障或重启session会完全丢失掉。

完全用cookie

将 用户的session数据全部存放在cookie中,很多大型站点都在这么干。优点是服务器架构也变得简单,每台web服务器都可以很独立。

没有网络开销 和对磁盘IO,服务器重启也不会导致数据的丢失。缺点,cookie过于庞大会耗费单位页面的下载时间,所以要尽量保持cookie的精简。



查看完整回答
反对 回复 2019-01-10
  • 1 回答
  • 0 关注
  • 2036 浏览
慕课专栏
更多

添加回答

举报

0/150
提交
取消
意见反馈 帮助中心 APP下载
官方微信