当前位置: 58彩票app下载 > 关于计算机 > 正文

使用Memcached实现Tomcat集群Session共享

时间:2019-11-02 09:28来源:关于计算机
环境CentOS6.7,下载安装必要的软件:yum-y install epel-release(tomcat7在这里源上,tomcat7是当今主流版本) yum -y install tomcat  直接下载tomcat7,  yum -y installjava-1.7.0-openjdk-devel (tomcat需求周转在

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

yum -y install tomcat  直接下载tomcat7,  yum -y install java-1.7.0-openjdk-devel (tomcat需求周转在java虚构机上)

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>

地点的字本人都看不清仍旧贴个图吧

图片 1

自定义了生机勃勃台虚拟主机:<Host name="web.com"  appBase="/data/webapps/" unpackWA本田CR-Vs="true" autoDeploy="true">

在那虚构主机上增添了Context:<Context path="" docBase="/data/webapps" reloadable="true" >

关键是manager这段:

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

  定义有怎样memcached服务器节点:memcachedNodes="n1:192.168.238.250:11211,n2:192.168.238.251:11211"

  定义备用节点:failoverNodes="n2"

  对那么些呼吁url忽视:requestUriIgnorePattern=".*.(ico|png|gif|jpg|css|js)$"

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

把私下认可虚拟主机定义为web.com:

图片 2

JvmRoute="汤姆catA" 是在伸手web.com的session id中加多JvmRoute="汤姆catA",此试验中可不要加多

创造页面财富: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>

贴个图:

图片 3

下载如下几个包: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处理

地点那多少个包的下载地址:

把下边多少个包放在/usr/share/tomcat/lib/ 目录下 (注意上边多少个包不要下错了,这又是个机密的坑)

图片 4

那多少个包的版本一定要对,笔者在这里踩了一天的坑,尽管您的是tomcat8,对应的memcached-session-manager-tc8-1.8.2

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

把上边的步调在tomcatA上的步调,在tomcatB上实践一遍,tomcatB上的jsp页面财富中的汤姆catA改为汤姆catB,red改为blue

前端再架设风流罗曼蒂克台Nginx落成负载均衡,运维memcached,运行tomcat,运营Nginx,去浏览器验证

图片 5

图片 6 

表明成功,Session ID保持长期以来。

越多汤姆cat相关教程见以下内容

CentOS 6.6下安装配置汤姆cat境遇  http://www.linuxidc.com/Linux/2015-08/122234.htm

RedHat Linux 5.5安装JDK+Tomcat并部署Java项目  http://www.linuxidc.com/Linux/2015-02/113528.htm 

汤姆cat权威指南(第二版)(中国和英国高清PDF版+带书签)  http://www.linuxidc.com/Linux/2015-02/113062.htm 

汤姆cat 安全布局与性情优化 http://www.linuxidc.com/Linux/2015-02/113060.htm 

Linux下使用Xshell查看汤姆cat实时日志汉语乱码建设方案 http://www.linuxidc.com/Linux/2015-01/112395.htm 

CentOS 64-bit下安装JDK和汤姆cat并安装汤姆cat开机运行操作步骤 http://www.linuxidc.com/Linux/2015-01/111485.htm 

CentOS 6.5下安装Tomcat  http://www.linuxidc.com/Linux/2015-01/111415.htm 

汤姆cat 的亲力亲为介绍:请点这里
汤姆cat 的下载地址:请点这里

本文永远更新链接地址:http://www.linuxidc.com/Linux/2016-05/131688.htm

图片 7

编辑:关于计算机 本文来源:使用Memcached实现Tomcat集群Session共享

关键词: