简介
今天解决了,nginx实现tomcat集群,常见的session共享问题。总结一下,简单来说就是通过负载均衡之后,用户第一次请求的tomcat和第二次请求的tomcat基本不是同一个,但是你在第一次请求放在session中的值只有一个tomcat拥有,第二个请求的那个tomcat里面是没有的。这样就出现了用户不停登入的情况。
解决方式:复制session信息(因为我的集群服务器少,所以用这种方式快速便捷)
什么是复制session信息?
原理:就是有几个tomcat,就复制几个session,只要有一个tomcat中的session发生变化,其他tomcat中的session跟着复制变化,保证所有用户的session在所有的tomcat中都存在而且相同。这样一来无论用户的请求被分配到哪个tomcat都是无所谓的,因为所有的tomcat中都有他们存放的session。
实现:
1、修改sever.xml文件:将Cluster的注释去掉
2、打开自己项目的web.xml(不是tomcat/conf/web.xml),增加distributable标签。
在web.xml文件的</web-app>之前添加
<!-- session共享配置 -->
<distributable />
优点:实现简单,没有什么花里胡哨的操作。如果集群的tomcat不多,而且用户没有那么多的时候可以选择这种方式。
缺点:只要Session数据有变化,就需要将数据同步到所有其他机器上,机器越多,同步带来的网络带宽开销就越大;当用户很多时,每台机器用于保存Session数据的内容占用会很严重。