由于项目服务器用的阿里云的ECS,Memcached也采用的阿里云。多个tomcat集群的session都存储在一个云memcached中。
配置步骤如下:
一、tomcat增加memcached支持的lib包
主要用到以下9个jar包,去http://code.google.com/p/memcached-session-manager可以下载(当然需要fanqiang)。
asm-3.2.jarkryo-1.04.jarkryo-serializers-0.11.jarmemcached-session-manager-1.9.2.jarmemcached-session-manager-tc7-1.9.2.jarminlog-1.2.jarmsm-kryo-serializer-1.8.2.jarreflectasm-1.01.jarspymemcached-2.10.3.jar
把以上9个jar包放到tomcat/lib目录下。
二、配置tomcat同步session到memcached中
有两种模式:sticky和no-sticky
sticky:负载均衡会根据用户会话,每次都分配到同一个集群节点上。用户每次获取会话数据都是从tomcat里面取得,tomcat会备份一个session到memcached。 这样可以保持获取session的最高效。 no-sticky:负载均衡不会管用户会话,而是按每次连接分别分发的方式,会话都保持在memcached上,每次读写都在memcached上。由于会远程访问数据,所以效率会低一些,但是这种却是最符合集群或集中缓存预期效果的。我采用的是no-sticky模式,编辑tomcat下的conf目录下的context.xml文件,在<Context>与</Context>中增加如下内容:
配置完成以后重启tomcat,使配置生效。
三、测试session共享是否生效
在第一个tomcat实例中的webapps/ROOT目录下新建test.jsp页面,内容如下
<%@ page language="java" %>TomcatA TomcatA
Session ID | <% session.setAttribute("abc","abc"); %><%= session.getId() %> |
Created on | <%= session.getCreationTime() %> |
同样在第二个tomcat实例中的webapps/ROOT目录下新建test.jsp页面,内容如下:
<%@ page language="java" %>TomcatB TomcatB
Session ID | <% session.setAttribute("abc","abc"); %><%= session.getId() %> |
Created on | <%= session.getCreationTime() %> |
在上层的nginx中配置负载均衡及反向代理如上两个tomcat(过程略)
最终测试效果如下,可以看到,session共享成功,另外也可以去memcached中看到存储的session。