Nginx+tomcat+session共享
2016-04-27 12:40
405 查看
Memcached_Session_Manager
MSM–memcached session manager是一个高可用的Tomcat session共享解决方案,除了可以从本机内存快速读取Session信息(仅针对黏性Session)外,同时可使用memcached存取Session,以实现高可用。对于非黏性Session,memcached直接存储session。
特性:
1. 支持Tomcat6、Tomcat7
2. 支持黏性、非黏性Session
3. 无单一故障点
4. 可处理tomcat故障转移
5. 可处理memcached故障转移
6. 插件式session序列化
7. 只有当session有修改时,才会将session写回memcached
8. JMX管理&监控
配置:
Context.xml
<Manager className="de.javakaffee.web.msm.MemcachedBackupSessionManager" memcachedNodes="n1:localhost:11211,n2:localhost:11212" requestUriIgnorePattern=".*\.(png|gif|jpg|css|js){1}quot; sessionBackupAsync="false" sessionBackupTimeout="1800000" copyCollectionsForSerialization="false" transcoderFactoryClass="de.javakaffee.web.msm.serializer.javolution.JavolutionTranscoderFactory" />
说明:
1、 session存储到memchached实现方案时。他主要功能是修改tomcat的session存储机制,使之能够把session序列化存放到memcached中。2、Manager标签属性说明:
className 此属性是必须的。 memcachedNodes 此属性是必须的。这个属性必须包含你所有运行的memcached节点。每个节点的定义格式为<id>:<host>:<port>。多个之间用空格或半角逗号隔开(如:memcachedNodes="n1:localhost:11211,n2:localhost:11212")。如果你设置单个memcache节点<id>是可选的,所以它允许设置为<host>:<port>(memcachedNodes="localhost:11211")。 failoverNodes 可选项,属性只能用在非粘连Session机制中。此属性必须包含memcached节点的Id,此节点是Tomcat作为备份使用。多个之间用空格或逗号隔开 memcachedProtocol 可选项,默认为text。出属性指明memcached使用的存储协议。只支持text或者binary。 sticky 可选项,默认为true。指定使用粘性的还是非粘性的Session机制。 lockingMode 可选项,此属性只对非粘性Session有用,默认为none。 指定非粘性Session的锁定策略。他的只有 (1)、none:从来不加锁 (2)、all: 当请求时对Session锁定,直到请求结束 (3)、auto:对只读的request不加锁,对非只读的request加锁 (4)、uriPattern:<regexp>: 使用正则表达式来比较requestRUI + "?" + queryString来决定是否加锁, requestUriIgnorePattern 可选项,此属性是那些不能改备份Session的请求的正则表达式。如果像css,javascript,图片等静态文件被同一个Tomcat和同一个应用上下文来提供,这些请求也会通过memcached-session-manager。但是这些请求在一个http会话中几乎没什么改变,所以他们没必要触发Session备份。所以那些静态文件没必要触发Session备份,你就可以使用此属性定义。此属性必须符合java regex正则规范。 sessionBackupAsync 可选项,默认true,指定Session是否应该被异步保存到Memcached中。 如果被设置为true,backupThreadCount设置起作用,如果设置false,通过sessionBackupTimeout,设置的过期时间起作用。 backupThreadCount 可选项,默认为CPU内核数。用来异步保存Session的线程数(如果sessionBackupAsync="true")。 sessionBackupTimeout 可选项,默认100,单位毫秒,设置备份一个Session所用的时间,如果操作超过时间那么保存失败。此属性只在sessionBackupAsync="false"是起作用。默认100毫秒 sessionAttributeFilter 可选项 从1.5.0版本有此属性是用来控制Session中的那个属性值保存到Memcached中的正则表达式。郑则表达式被用来匹配Session中属性名称。如sessionAttributeFilter="^(userName|sessionHistory)$" 指定了只有"userName"和"sessionHistory"属性保存到Memcached中。依赖于选择的序列化策略。 transcoderFactoryClass 可选,默认为de.javakaffee.web.msm.JavaSerializationTranscoderFactory此属性值是创建序列化和反序列化保存到Memcached中的Session的编码转换器的工厂类名。这个指定的类必须实现了de.javakaffee.web.msm.TranscoderFactory和提供一个无参的构造方法。例如其他的有效的实现在其他packages/jars中提供如:msm-kryo-serializer,msm-xstrea-serializer和msm-javolution-serializer. copyCollectionsForSerialization 可选项,默认false。customConverter 可选项enableStatistics 可选项,默认true,用来指定是否进行统计。enabled 可选项,默认true,指定Session保存到Memcached中是否可用和是否可以通过JMX进行改变。只用于粘性Session。
黏性Session:
此模式下同一会话中的请求都被派送到同一个tomcat实例上,这样我们就无须在多台服务器之间实现session共享了,这是其好处,不好的地方就是不能实现failureover了,一但用户访问的机器挂掉,那么其session就会丢失。非黏性Session:
又名复制Session,此模式下同一会话中的请求可以被分配到不同的tomcat实例上进行处理,此时就需要在不同服务器之间同步、复制session,这样一来即使一台服务器挂掉了,请求在其它服务器上照样可以访问到session信息,其缺点在于Session复制需要系统资源和网络开销MSM黏性Session(memcache作为备份)
tomcat session 为 主session, memcached 为备 session。Request请求到来时, 从memcached加载备 session 到 tomcat (仅当tomcat jvmroute发生变化时,否则直接取tomcat session);Request请求结束时,将tomcat session更新至memcached,以达到主备同步之目的。当一个请求结束时,session会被送回Memcached进行备份。当下一次请求开始时,本地Session可用,直接服务,请求结束后,session又被送回Memcached备份。
当集群中的一个Tomcat挂掉,下一次请求会被路由到其他Tomcat上。负责处理此此请求的Tomcat并不清楚Session的信息。此时它会从Memcached查找该Session,更新该Session并将其保存在本机内容。此次请求结束,session被修改,送回Memcached备份。
如果一个Memcached故障,当前Memcached中的Session会转移到其他Memcached节点,同时,JSESSIONID被修改并送回浏览器。
如果使用黏性Session,应确保loadbalancer中配置生成的JSESSIONID无任何后缀。
MSM非粘性Session(tomcat不存储session)
memcache1为主节点,memcache2为备节点当请求到来时,先从memcache2加载session至tomcat内存,如果找不到则从memcache1加载session至tomcat内存,然后在tomcat内存进行修改,当请求结束之后,将tomcat本地内存中的session更新至memcache1和memcache2,先memcache1再memcache2。
相关文章推荐
- tomcat和nginx gzip压缩
- MyEclipse部署到tomcat上的项目名不是我更改后的项目名怎么解决
- tomcat +nginx 配置
- 20160427-Android&Tomcat-RAS加密解密文本
- Jenkins部署Web项目到远程tomcat
- Tomcat 加载顺序
- eclipse下如何配置tomcat
- linux 配置多个tomcat(本文配置了两个)
- Eclipse中将tomcat日志输出重定向
- java _tomcat_mysql 部署
- 用jboss/tomcat启动socket mina的方式
- tomcat内存设置之startup.bat启动方式
- Nginx+Tomcat实现动静分离
- nginx整合tomcat
- Jetty和Tomcat的选择:按场景而定
- Ubuntu Tomcat自动启动+内存溢出
- 更改myeclipse工具的内存和tomcat的内存
- MyEclipse和tomcat结合编写jsp对于中文乱码的解决方法
- 利用ant将Web项目部署至远程Tomcat
- linux 启动 终止 tomcat,查看进程