H__D  

概述

  web项目中,Tomcat的访问量总是有限的,这时候就需要用到Tomcat集群,多个Tomcat的时候就要考虑Session共享的问题,这里介绍一种使用Memcached做Session共享的解决方案

环境

  操作系统:Linux( centOS 6..5 版)

  软件:Tomcat7

       Memcached

实现原理

  Tomcat + Memcached 实现session共享流程图

  

配置

  •   安装Tomcat 2个和Memcached 1个,参考【Linux】Tomcat安装及一个服务器配置多个Tomcat 和 【Linux】Memcached安装
  •       配置Tomcat,到tomcat的安装目录lib中,加入:需要的jar包
      
      maven下依赖如下:
     1 <dependency>
     2             <groupId>asm</groupId>
     3             <artifactId>asm</artifactId>
     4             <version>3.2</version>
     5         </dependency>
     6 
     7         <dependency>
     8             <groupId>com.couchbase.client</groupId>
     9             <artifactId>couchbase-client</artifactId>
    10             <version>1.4.11</version>
    11         </dependency>
    12 
    13         <dependency>
    14             <groupId>com.googlecode</groupId>
    15             <artifactId>kryo</artifactId>
    16             <version>1.04</version>
    17         </dependency>
    18 
    19         <dependency>
    20             <groupId>de.javakaffee</groupId>
    21             <artifactId>kryo-serializers</artifactId>
    22             <version>0.11</version>
    23         </dependency>
    24 
    25         <dependency>
    26             <groupId>de.javakaffee.msm</groupId>
    27             <artifactId>memcached-session-manager</artifactId>
    28             <version>1.8.2</version>
    29         </dependency>
    30 
    31         <dependency>
    32             <groupId>de.javakaffee.msm</groupId>
    33             <artifactId>memcached-session-manager-tc7</artifactId>
    34             <version>1.8.2</version>
    35         </dependency>
    36 
    37         <dependency>
    38             <groupId>com.googlecode</groupId>
    39             <artifactId>minlog</artifactId>
    40             <version>1.2</version>
    41         </dependency>
    42 
    43         <dependency>
    44             <groupId>de.javakaffee.msm</groupId>
    45             <artifactId>msm-kryo-serializer</artifactId>
    46             <version>1.8.2</version>
    47         </dependency>
    48 
    49         <dependency>
    50             <groupId>com.esotericsoftware</groupId>
    51             <artifactId>reflectasm</artifactId>
    52             <version>1.01</version>
    53         </dependency>
    54 
    55         <dependency>
    56             <groupId>net.spy</groupId>
    57             <artifactId>spymemcached</artifactId>
    58             <version>2.11.4</version>
    59         </dependency>
    View Code

     

  •      在tomcat安装目录下的context.xml文件中加入:
    1 <Manager       
    2         className="de.javakaffee.web.msm.MemcachedBackupSessionManager" 
    3         memcachedNodes="n1:127.0.0.1:11211" 
    4         sticky="false" 
    5         sessionBackupAsync="false" 
    6         requestUriIgnorePattern=".*\.(ico|png|gif|jpg|jpeg|bmp|css|js|html|htm)$" 
    7         transcoderFactoryClass="de.javakaffee.web.msm.serializer.kryo.KryoTranscoderFactory" 
    8       />

     

  •     在tomcat安装目录下的server.xml文件中加入:
    1 <Engine name="Catalina" defaultHost="localhost" jvmRoute="tomcat1">

    第二个Tomcat中设置 jvmRoute="tomcat2", 用来区分tomcat

  •    在tomcat中添加测试界面,session.jsp
    1 <%@ page language="java" contentType="text/html; charset=UTF-8"
    2     pageEncoding="UTF-8"%>
    3 <BR>
    4 SessionID:<%=session.getId()%>
    5 <BR>
    6 SessionIP:<%=request.getServerName()%>
    7 <BR>
    8 SessionPort:<%=request.getServerPort()%>
    9 <BR>

     

  • 在同一个浏览器中,打开2个tomcat的测试界面,sessionId相同,表示通过Memcached实现的session共享,如下

 

  注:此方案和可以配合nginx使用,利用nginx分发请求来访问不同的tomcat,而session又是共享的

 

posted on 2017-04-18 18:01  H__D  阅读(4960)  评论(0编辑  收藏  举报