使用memcached实现tomcat集群session共享

环境centos6.7,下载安装必要的软件:yum -y install epel-release(tomcat7在此源上,tomcat7是如今主流版本)css

yum -y install tomcat  直接下载tomcat7,   yum -y install java-1.7.0-openjdk-devel (tomcat须要运行在java虚拟机上)html

vim /etc/tomcat/server.xml   修改配置文件前端

      <Host name="web.com"  appBase="/data/webapps/" unpackWARs="true" autoDeploy="true">
      <Context path="" docBase="/data/webapps" reloadable="true" >
        <Manager className="de.javakaffee.web.msm.MemcachedBackupSessionManager" memcachedNodes="n1:192.168.238.250:11211,n2:192.168.238.251:11211" failoverNodes="n2" requestUriIgnorePattern=".*\.(ico|png|gif|jpg|css|js)$" transcoderFactoryClass="de.javakaffee.web.msm.serializer.javolution.JavolutionTranscoderFactory"/>
      </Context>
      </Host>

上面的字本身都看不清仍是贴个图吧java

自定义了一台虚拟主机:<Host name="web.com"  appBase="/data/webapps/" unpackWARs="true" autoDeploy="true">git

在此虚拟主机上添加了Context:<Context path="" docBase="/data/webapps" reloadable="true" >github

关键是manager这段:web

  为manager取个全局惟一名字:<Manager className="de.javakaffee.web.msm.MemcachedBackupSessionManager"vim

  定义有哪些memcached服务器节点:memcachedNodes="n1:192.168.238.250:11211,n2:192.168.238.251:11211"centos

  定义备用节点:failoverNodes="n2"浏览器

  对那些请求url忽略:requestUriIgnorePattern=".*\.(ico|png|gif|jpg|css|js)$"

  固定格式:transcoderFactoryClass="de.javakaffee.web.msm.serializer.javolution.JavolutionTranscoderFactory"/>

  

把默认虚拟主机定义为web.com:

JvmRoute="TomcatA" 是在请求web.com的session id中添加JvmRoute="TomcatA",此实验中可不用添加

建立页面资源:mkdir -p /data/webapps/{WEB-INF,classes,lib}    cd /data/webapps/  vim index.jsp

jsp页面资源以下

<%@ page language="java" %> <html> <head><title>TomcatA</title></head> <body> <h1><font color="red">TomcatA.test</font></h1> <table align="centre" border="1"> <tr> <td>Session ID</td> <% session.setAttribute("test","test"); %> <td><%= session.getId() %></td> </tr> <tr> <td>Created on</td> <td><%= session.getCreationTime() %></td> </tr> </table> </body> </html>

贴个图:

下载以下几个包:javolution-5.5.1   memcached-session-manager-1.8.2   memcached-session-manager-tc7-1.8.2

msm-javolution-serializer-1.8.2  spymemcached-2.10.2    这几个包做用:java经过memcached实现session管理

上面这几个包的下载地址:https://github.com/magro/memcached-session-manager/wiki/SetupAndConfiguration

把上面几个包放在/usr/share/tomcat/lib/ 目录下 (注意上面几个包不要下错了,这又是个潜在的坑)

 

 

这几个包的版本必定要对,我在这踩了一天的坑,若是你的是tomcat8,对应的memcached-session-manager-tc8-1.8.2

两台memcached各自放在两台tomcat上,使用yum -y install memcached下载就好了

把上面的步骤在tomcatA上的步骤,在tomcatB上执行一遍,tomcatB上的jsp页面资源中的TomcatA改成TomcatB,red改成blue

前端再架设一台Nginx实现负载均衡,启动memcached,启动tomcat,启动Nginx,去浏览器验证

 

验证成功,Session ID保持同样

相关文章
相关标签/搜索