Coin163

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

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

2020腾讯云双十一活动,全年最低!!!(领取3500元代金券),
地址https://cloud.tencent.com/act/cps/redirect?redirect=1073

2020阿里云最低价产品入口,含代金券(新老用户有优惠),
入口地址https://www.aliyun.com/minisite/goods

相关推荐:Nginx + Tomcat + Redis负载均衡及session共享

概述   本文档是用来详细描述 nginx+tomcat+redis负载均衡实现session共享 所需软件及下载地址 软件名称 下载地址 功能说明 Nginx-v1.6.0 http://nginx.org/download/nginx-1.6.0.tar.gz 负载均衡 commons-pool-2-2.4.2.jar http://mirrors.hust.edu.cn/apach

由于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. <Context docBase="/var/www/html" path="">   
  2.     <Manager className="de.javakaffee.web.msm.MemcachedBackupSessionManager"   
  3.             memcachedNodes="n1:192.168.159.131:11444 n2: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. <Manager className="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+Tomcat+memcached负载均衡实现session共享

1.  安装各个软件不用说了。 2.  到tomcat的安装目录lib中,加入: memcached-2.6.jar(http://spymemcached.googlecode.com/files/memcached-2.6.jar) javolution-5.4.3.1.jar memcached-session-manager-1.5.1.jar memcached-session-manager-tc7-1.5.1.ja

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

[html]  view plain copy 在CODE上查看代码片 派生到我的代码片
  1. upstream  xxy.com  {  
  2.       server   192.168.159.128:8081 ;  
  3.       server   192.168.159.128:8082 ;  
  4. }  
  5.   
  6. log_format  www_xy_com  '$remote_addr - $remote_user [$time_local] $request '  
  7.                '"$status" $body_bytes_sent "$http_referer"'   
  8.                '"$http_user_agent" "$http_x_forwarded_for"';  
  9.   
  10. server  
  11. {  
  12.       listen  80;  
  13.       server_name  xxy.com;  
  14.   
  15.       location / {  
  16.                proxy_pass        http://xxy.com;  
  17.                proxy_set_header   Host             $host;  
  18.                proxy_set_header   X-Real-IP        $remote_addr;  
  19.                proxy_set_header   X-Forwarded-For  $proxy_add_x_forwarded_for;  
  20.       }  
  21.   
  22.       access_log  /data/base_files/logs/www.xy.log  www_xy_com;  
  23. }  

最后,将你的应用放到两个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. <Valve className="com.radiadesign.catalina.session.RedisSessionHandlerValve" />  
  2. <Manager className="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. upstream  redis.xxy.com  {  
  2.       server   192.168.159.130:8081;  
  3.       server   192.168.159.130:8082;  
  4. }  
  5.   
  6. log_format  www_xy_com  '$remote_addr - $remote_user [$time_local] $request '  
  7.                '"$status" $body_bytes_sent "$http_referer"'   
  8.                '"$http_user_agent" "$http_x_forwarded_for"';  
  9.   
  10. server  
  11. {  
  12.       listen  80;  
  13.       server_name redis.xxy.com;   
  14.   
  15.       location / {  
  16.                proxy_pass        http://redis.xxy.com;  
  17.                proxy_set_header   Host             $host;  
  18.                proxy_set_header   X-Real-IP        $remote_addr;  
  19.                proxy_set_header   X-Forwarded-For  $proxy_add_x_forwarded_for;  
  20.       }  
  21.   
  22.       access_log  /data/base_files/logs/redis.xxy.log  www_xy_com;  
  23. }  


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


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

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


原文

由于tomcat的并发数瓶颈问题,可以说使用tomcat的web应用,几乎都存在session不同步问题。 借鉴网上的资料,我也找时间实验一把。 文中涉及的软件下载和安装,一一略过,想必大家也没必要看。

------分隔线----------------------------