zoukankan      html  css  js  c++  java
  • 关于 tomcat 集群中 session 共享的三种方法

    前两种均需要使用 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可以保持共享了。

    我喜欢程序员,他们单纯、固执、容易体会到成就感;面对压力,能够挑灯夜战不眠不休;面对困难,能够迎难而上挑战自我。他 们也会感到困惑与傍徨,但每个程序员的心中都有一个比尔盖茨或是乔布斯的梦想“用智慧开创属于自己的事业”。我想说的是,其 实我是一个程序员
  • 相关阅读:
    分享Kali Linux 2016.2第41周镜像虚拟机
    Visual Studio工具栏中无法选择调试设备
    Xamarin.iOS编译出错
    Xamarin基础命名空间Microsoft.SqlServer.Server
    编译包含Google Play服务App的SDK版本问题
    解决Fiddler无法抓到手机的会话包
    Xamarin.Android编译CPU类型选择方式
    Delphi iOS
    Delphi Android
    CRC16-循环冗余校验
  • 原文地址:https://www.cnblogs.com/kms1989/p/5477166.html
Copyright © 2011-2022 走看看