集群环境下,必然需要考虑用户和会话的问题,如果不加处理的话,一旦后端IP轮询切换,session也就断了。所以就有了4种方案。先说下session的问题,tomcat在启动时就会创建一个session,当会话越多的时候,session也就越多。而session在tomcat中属于重量级对象。一个没有任何内容的空session就需要消耗1.5K的内存存储空间
1.tomcat自带的方案,session复制,笨重低效,基本上是淘汰的方案。
2.nginx第三方扩展的sticky粘滞,把会话和后端IP绑定,比较简单,但个人感觉不是很可靠。
3.基于redis等nosql的session集中存储,tomcat配置也比较简单。这种最流行,但仍然存在以下问题:(1)redis有单点,并且增加了系统复杂度。(2)用来连接redis的jedis性能不稳定,高并发下很容易挂,这点看到过不少反馈。
4.纯cookie,不使用session,天然分布式。存在的问题:(1)cookie需要加解密,性能消耗要考虑,而且不能存太多东西,序列化本身消耗也不少。(2)每次请求都会带上cookie,包括JS和CSS等请求,浪费宽带,除非部署了CDN或专用服务器。
究竟哪种方案更好呢?
1,放弃使用session,就算同步策略非常优秀,但是造成的网络风暴不可避免
2,sticky粘滞会导致无法热切换,存在运维问题
3,如果是jedis的锅,是否有代替方案,因为目前redis等KV工具还是广泛使用的,如果担心单点问题,可以仿照osc的j2cache自己弄一个redis + db
4,结合业务,看下面总结
总结:结合业务
如果每次请求都需要获取当前认证用户的较多相关信息,ID哈希后查DB是一个好办法,但如果是并发高的系统,只能寻找redis等代替方案
版权声明:本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《阿里云开发者社区用户服务协议》和《阿里云开发者社区知识产权保护指引》。如果您发现本社区中有涉嫌抄袭的内容,填写侵权投诉表单进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。