多台tomcat服务的session共享 memcached与redis

由于tomcat的并发数瓶颈问题,可以说使用tomcat的web应用,几乎都存在session不同步问题。

借鉴网上的资料,我也找时间实验一把。

文中涉及的软件下载和安装,一一略过,想必大家也没必要看。

注:本文不对memcached和redis做任何口水讨论,望各个网友自行问谷歌和度娘。

(个人愚见,它们作为一个软件,能获得各自众多支持者,想必它们自然有各自的优点,重点还是从实际需要出发,选择合适自己的东东。)


一、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节点,加入

[html] view plain copy 在CODE上查看代码片 派生到我的代码片
  1. <ContextdocBase="/var/www/html"path="">
  2. <ManagerclassName="de.javakaffee.web.msm.MemcachedBackupSessionManager"
  3. memcachedNodes="n1:192.168.159.131:11444n2:192.168.159.131:11333"
  4. requestUriIgnorePattern=".*\.(png|gif|jpg|css|js)$"
  5. sessionBackupAsync="false"sessionBackupTimeout="3000"
  6. transcoderFactoryClass="de.javakaffee.web.msm.serializer.javolution.JavolutionTranscoderFactory"
  7. copyCollectionsForSerialization="false"/>
  8. </Context>

方法二:在context.xml中配置。

找到Context节点,加入

[html] view plain copy 在CODE上查看代码片 派生到我的代码片
  1. <ManagerclassName="de.javakaffee.web.msm.MemcachedBackupSessionManager"
  2. memcachedNodes="n1:192.168.159.131:11444"
  3. requestUriIgnorePattern=".*\.(png|gif|jpg|css|js)$"
  4. sessionBackupAsync="false"sessionBackupTimeout="3000"
  5. transcoderFactoryClass="de.javakaffee.web.msm.serializer.javolution.JavolutionTranscoderFactory"
  6. copyCollectionsForSerialization="false"/>


其次,配置nginx,用于测试session保持共享。

[html] view plain copy 在CODE上查看代码片 派生到我的代码片
  1. upstreamxxy.com{
  2. server192.168.159.128:8081;
  3. server192.168.159.128:8082;
  4. }
  5. log_formatwww_xy_com'$remote_addr-$remote_user[$time_local]$request'
  6. '"$status"$body_bytes_sent"$http_referer"'
  7. '"$http_user_agent""$http_x_forwarded_for"';
  8. server
  9. {
  10. listen80;
  11. server_namexxy.com;
  12. location/{
  13. proxy_passhttp://xxy.com;
  14. proxy_set_headerHost$host;
  15. proxy_set_headerX-Real-IP$remote_addr;
  16. proxy_set_headerX-Forwarded-For$proxy_add_x_forwarded_for;
  17. }
  18. access_log/data/base_files/logs/www.xy.logwww_xy_com;
  19. }

最后,将你的应用放到两个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前面。

[html] view plain copy 在CODE上查看代码片 派生到我的代码片
  1. <ValveclassName="com.radiadesign.catalina.session.RedisSessionHandlerValve"/>
  2. <ManagerclassName="com.radiadesign.catalina.session.RedisSessionManager"
  3. host="192.168.159.131"
  4. port="16300"
  5. database="0"
  6. maxInactiveInterval="60"/>

其次,配置nginx,用于测试session保持共享。

[html] view plain copy 在CODE上查看代码片 派生到我的代码片
  1. upstreamredis.xxy.com{
  2. server192.168.159.130:8081;
  3. server192.168.159.130:8082;
  4. }
  5. log_formatwww_xy_com'$remote_addr-$remote_user[$time_local]$request'
  6. '"$status"$body_bytes_sent"$http_referer"'
  7. '"$http_user_agent""$http_x_forwarded_for"';
  8. server
  9. {
  10. listen80;
  11. server_nameredis.xxy.com;
  12. location/{
  13. proxy_passhttp://redis.xxy.com;
  14. proxy_set_headerHost$host;
  15. proxy_set_headerX-Real-IP$remote_addr;
  16. proxy_set_headerX-Forwarded-For$proxy_add_x_forwarded_for;
  17. }
  18. access_log/data/base_files/logs/redis.xxy.logwww_xy_com;
  19. }


最后,将你的应用放到两个tomcat中,并依次启动redis、tomcat、nginx。访问你的nginx,可以发现两个tomcat中的session可以保持共享了。


上面文章中,有一点需要说明的是:

如果tomcat配置中,将manager放在server.xml中,那么使用maven做热部署时,会发生失败。所以,本人推荐放在context.xml中。


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值