文档章节

Tomcat session共享 —MSM

g
 ghl
发布于 2016/02/29 11:38
字数 387
阅读 38
收藏 1

Tomcat session共享—MSM

一、原理

       

       MSM(memcached-session-manager) 支持tomcat6 tomcat7 ,利用 ValueTomcat 阀)对Request进行跟踪。Request请求到来时,从memcached加载sessionRequest请求结束时,将tomcat session更新至memcached,以达到session共享之目的, 支持 sticky   non-sticky 模式。

 

       Sticky 模式:tomcat session  session memcached 为备 sessionRequest请求到来时, memcached加载备 session tomcat (仅当tomcat jvmroute发生变化时,否则直接取tomcat session)Request请求结束时,将tomcat session更新至memcached,以达到主备同步之目的。

 

       Non-Sticky模式:tomcat session  中转session memcached1 为主 sessionmemcached 2 为备sessionRequest请求到来时,从memcached 2加载备 session  tomcat,(当 容器 中还是没有session 则从memcached1加载主 session  tomcat 这种情况是只有一个memcached节点,或者有memcached1 出错时),Request请求结束时,将tomcat session更新至主memcached1和备memcached2,并且清除tomcat session 。以达到主备同步之目的。

 

 

二、配置

 

1.sticky

 

<Context> 
         <Manager className=" de.javakaffee.web.msm.MemcachedBackupSessionManager" 
                  memcachedNodes="n1:localhost:11211 n2:localhost:11212" 
                  failoverNodes="n1" 
                  requestUriIgnorePattern=".*\.(ico|png|gif|jpg|css|js)$" 
                  transcoderFactoryClass="de.javakaffee.web.msm.serializer.kryo.KryoTranscoderFactory" 
        /> 
</Context>

 

2.non-sticky

 

<Context> 
         <Manager className=" de.javakaffee.web.msm.MemcachedBackupSessionManager" 
                  memcachedNodes="n1:localhost:11211 n2:localhost:11212" 
                 sticky="false" 
                  lockingMode="uriPattern:/path1|/path2" 
                  requestUriIgnorePattern=".*\.(ico|png|gif|jpg|css|js)$" 
                  transcoderFactoryClass="de.javakaffee.web.msm.serializer.kryo.KryoTranscoderFactory" 
         /> 
</Context>

 

 

 

 

3.jvmroute

配置$CATALINA_HOME/conf/server.xml            

         #每台机器jvmRoute不能相同 jvmRoute="tomcat2"

    <Engine name="Catalina" defaultHost="localhost" jvmRoute="tomcat2">

配置$CATALINA_HOME/conf/context.xml<Context> 详见下

 

 

 

4.日志

在该日志文件中添加配置。$CATALINA_HOME/conf/logging.properties.

de.javakaffee.web.msm.level=FINE

 

5.jar

 kryo-1.03.jar
 kryo-serializers-0.8.jar
 memcached-2.4.2.jar
 memcached-session-manager-1.5.0.jar
 memcached-session-manager-tc6-1.5.0.jar
 minlog-1.2.jar
 msm-kryo-serializer-1.5.0.jar

 

三、流程图

1.sticky

2.non-sticky

 

 

参考地址:http://xylonwang.iteye.com/blog/1269704

© 著作权归作者所有

g

ghl

粉丝 3
博文 28
码字总数 6861
作品 0
程序员
私信 提问
Tomcat基于MSM+Memcached实现Session共享

前言 在Tomcat集群中,当一个节点出现故障,其他节点该如何接管故障节点的Session信息呢?本文带来的解决方案是基于MSM+Memcached实现Session共享。 相关介绍 MSM MSM–Memcached Session M...

eddy_linux
2015/11/16
72
0
浅谈web应用的负载均衡、集群、高可用(HA)解决方案

1、熟悉几个组件 1.1、apache —— 它是Apache软件基金会的一个开放源代码的跨平台的网页服务器,属于老牌的web服务器了,支持基于Ip或者域名的虚拟主机,支持代理服务器,支持安全Socket层(...

stone_
2016/05/04
366
0
浅谈web应用的负载均衡、高可用、群集

1、熟悉几个组件 1.1、apache —— 它是Apache软件基金会的一个开放源代码的跨平台的网页服务器,属于老牌的web服务器了,支持基于Ip或者域名的虚拟主机,支持代理服务器,支持安全Socket层(...

壹休哥
2016/11/06
0
0
MSM-Memcached_Session_Manager介绍及使用

我们都知道对于一些大型的web2.0的网站,在正式部署时一般是部署在不同故障域的多台应用服务器上,以j2ee应用为例,一般我们都会部署在tomcat下,假如我们部署了10台tomcat服务器,那这10台t...

凡尘里的一根葱
2015/11/06
68
0
基于nginx的tomcat负载均衡和集群

要集群tomcat主要是解决SESSION共享的问题,因此我利用memcached来保存session,多台TOMCAT服务器即可共享SESSION了。 你可以自己写tomcat的扩展来保存SESSION到memcached。 这里推荐使用mem...

征战职场
2012/09/27
182
0

没有更多内容

加载失败,请刷新页面

加载更多

zk中ToBeAppliedRequestProcessor解析

ToBeAppliedRequestProcessor在Leader中 在已处理事务和最后处理事务处理器之间,处理器链上下一个是FinalRequestProcessor public void processRequest(Request request) throws RequestPro...

writeademo
33分钟前
3
0
Allegro快捷键设置-PCB环境

立题简介: 内容:简单介绍Allegro绘制的PCB环境下的快捷键; 来源:实际使用得出; 作用:对Allegro绘制PCB快捷键进行介绍; PCB环境:Cadence 16.6; 立题详解: 对“allegro”板而言,其在...

demyar
34分钟前
3
0
idea maven web项目启动build时报错java.lang.NullPointerException

之前还好好的,重启一下idea就报这个错了,大概率是tomcat没杀掉端口被占用了,在tomcat配置中更换一下sever端口就好了

宇辰OSC
38分钟前
3
0
weed3-2.3.1.查询之输出

Weed3 一个超轻量级ORM框架(只有0.1Mb哦) 源码:https://github.com/noear/weed3 源码:https://gitee.com/noear/weed3 查询可是个复杂的话题了,可能我们80%的数据库处理都在查询。 今天先...

刘之西东
38分钟前
3
0
【Android JetPack系列】数据绑定:DataBinding

参考MVVM

Agnes2017
46分钟前
3
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部