tomcat 集群中 session 共享的三种方法: 1、使用 filter 方法存储 2、使用 tomcat sessionmanager 方法存储 3.使用 terracotta 服务器共享 前两种均需要使用 memcached 或redis 存储 session ,最后一种使用 terracotta 服务器共享。 建议使用 redis,不仅仅因为它可以将缓存的内容持久化,还因为它支持的单个对象比较大,而且数据类型丰富, 不只是缓存 session,还可以做其他用途,一举几得啊。
1、使用 filter 方法存储 这种方法比较推荐,因为它的服务器使用范围比较多,不仅限于tomcat ,而且实现的原理比较简单容易控制。 可以使用memcached-session-filter 官方网址:http://code.google.com/p/memcached-session-filter/ 官方介绍:解决集群环境下javaweb容器session共享,使用filter拦截器和memcached实现。在tomcat 6和websphere8测试通过,现网并发2000,日PV量1100万。 暂不支持sessionevent包括create destory 和 attribute change 东西很不错,体积很小,不过这个东东要和spring 一起使用,而且要求存储到 memcached 的对象要实现 java 的序列化接口 大家也知道,java本身的序列化性能也很一般。 我将其简单扩展了一下,不再依赖spring ,并且利用 javolution 实现序列化,缓存的对象不再有限制。 暂时没有发现 redis的实现,后面将自己实现使用 redis 存储并且序列化使用 kyro ,详细情况有时间再单独写出来。
2、使用 tomcat sessionmanager 方法存储 这种方法服务器只能使用 tomcat,但网上有针对 memcached 和 redis 实现,直接配置就行了。 memcached 实现: 网址:http://code.google.com/p/memcached-session-manager/ 修改 tomcat 的 conf 目录下的context.xml 文件: <ManagerclassName="de.javakaffee.web.msm.MemcachedBackupSessionManager" memcachedNodes="n1:localhost:11211n2:localhost:11212" failoverNodes="n2" requestUriIgnorePattern=".*\.(png|gif|jpg|css|js)$" sessionBackupAsync="false" sessionBackupTimeout="100" transcoderFactoryClass="de.javakaffee.web.msm.serializer.javolution.JavolutionTranscoderFactory" copyCollectionsForSerialization="false" />
以上是以 1.3 版为例子,需要用的jar 包: memcached-session-manager-1.3.0.jar msm-javolution-serializer-1.3.0.jar javolution-5.4.3.1.jar memcached-2.4.2.jar
redis 实现: 网址:https://github.com/jcoleman/tomcat-redis-session-manager 同样修改 tomcat 的 conf目录下的 context.xml 文件: <ValveclassName="com.radiadesign.catalina.session.RedisSessionHandlerValve"/> <ManagerclassName="com.radiadesign.catalina.session.RedisSessionManager" host="localhost" port="6379" database="0" maxInactiveInterval="60"/> 以上是以 1.2 版为例子,需要用的jar 包: tomcat-redis-session-manager-1.2-tomcat-6.jar jedis-2.1.0.jar commons-pool-1.6.jar
3、使用 terracotta 服务器共享 这种方式配置有点复杂,大家到网上搜索一下吧。 以上配置成功后,前端使用 nginx进行负载均衡就行了,同时使用 Gzip 压缩 和 静态文件缓存。
以下是实例: 一、nginx+tomcat+memcached (依赖架包下载) 1.memcached配置:(v1.4.13) 节点1(192.168.159.131:11444) 节点2(192.168.159.131:11333) 2.tomcat配置 tomcat1(192.168.159.128:8081) tomcat2(192.168.159.128:8082) 3.nginx安装在192.168.159.131。 首先,是配置tomcat,使其将session保存到memcached上。有两种方法: 方法一:在server.xml中配置。 找到host节点,加入 <ContextdocBase="/var/www/html" path="">
<ManagerclassName="de.javakaffee.web.msm.MemcachedBackupSessionManager"
memcachedNodes="n1:192.168.159.131:11444n2:192.168.159.131:11333"
requestUriIgnorePattern=".*\.(png|gif|jpg|css|js)$"
sessionBackupAsync="false"sessionBackupTimeout="3000"
transcoderFactoryClass="de.javakaffee.web.msm.serializer.javolution.JavolutionTranscoderFactory"
copyCollectionsForSerialization="false"/>
</Context> 方法二:在context.xml中配置。 找到Context节点,在context中加入 <ManagerclassName="de.javakaffee.web.msm.MemcachedBackupSessionManager"
memcachedNodes="n1:192.168.159.131:11444"
requestUriIgnorePattern=".*\.(png|gif|jpg|css|js)$"
sessionBackupAsync="false"sessionBackupTimeout="3000"
transcoderFactoryClass="de.javakaffee.web.msm.serializer.javolution.JavolutionTranscoderFactory"
copyCollectionsForSerialization="false" /> 其次,配置nginx,用于测试session保持共享。 upstream xxy.com {
server 192.168.159.128:8081 ;
server 192.168.159.128:8082 ;
}
log_format www_xy_com '$remote_addr - $remote_user [$time_local] $request '
'"$status"$body_bytes_sent "$http_referer"'
'"$http_user_agent" "$http_x_forwarded_for"';
server
{
listen 80;
server_name xxy.com;
location/ {
proxy_pass http://xxy.com;
proxy_set_header Host $host;
proxy_set_header X-Real-IP $remote_addr;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
}
access_log /data/base_files/logs/www.xy.log www_xy_com;
} 最后,将你的应用放到两个tomcat中,并依次启动memcached、tomcat、nginx。访问你的nginx,可以发现两个tomcat中的session可以保持共享了。 二、nginx+tomcat+redis (依赖架包下载) 1.redis配置(192.168.159.131:16300)(v2.8.3) 2.tomcat配置 tomcat1(192.168.159.130:8081) tomcat2(192.168.159.130:8082) 3.nginx安装在192.168.159.131。 首先,是配置tomcat,使其将session保存到redis上。有两种方法,也是在server.xml或context.xml中配置,不同的是memcached只需要添加一个manager标签,而redis需要增加的内容如下:(注意:valve标签一定要在manager前面。) 配置和memcached 一样 找到Context节点,在context中加入
<ValveclassName="com.radiadesign.catalina.session.RedisSessionHandlerValve"/>
<ManagerclassName="com.radiadesign.catalina.session.RedisSessionManager"
host="192.168.159.131"
port="16300"
database="0"
maxInactiveInterval="60"/> 其次,配置nginx,用于测试session保持共享。 upstream redis.xxy.com {
server 192.168.159.130:8081;
server 192.168.159.130:8082;
}
log_format www_xy_com '$remote_addr - $remote_user [$time_local] $request '
'"$status"$body_bytes_sent "$http_referer"'
'"$http_user_agent" "$http_x_forwarded_for"';
server
{
listen 80;
server_name redis.xxy.com;
location/ {
proxy_pass http://redis.xxy.com;
proxy_set_header Host $host;
proxy_set_header X-Real-IP $remote_addr;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
}
access_log /data/base_files/logs/redis.xxy.log www_xy_com;
} 最后,将你的应用放到两个tomcat中,并依次启动redis、tomcat、nginx。访问你的nginx,可以发现两个tomcat中的session可以保持共享了。
|