目前,为了使web能适应大规模的访问,需要实现应用的集群部署。集群最有效的方案就是负载均衡,而实现负载均衡用户每一个请求都有可能被分配到不固定的服务器上,这样我们首先要解决session的统一来保证无论用户的请求被转发到哪个服务器上都能保证用户的正常使用,即需要实现session的共享机制。

在集群系统下实现session统一的有如下几种方案:
(1) 应用服务器间的session复制共享(如tomcat自带session共享)
(2) 基于cache DB缓存的session共享

一、应用服务器间的session复制共享(Tomcat自带的功能)
session复制共享,主要是指集群环境下,多台应用服务器之间同步session,使session保持一致,对外透明。 如果其中一台服务器发生故障,根据负载均衡的原理,web服务器(apache/nginx)会遍历寻找可用节点,分发请求,由于session已同步,故能保证用户的session信息不会丢失。

此方案的不足之处:
技术复杂,必须在同一种中间件之间完成(如:tomcat-tomcat之间).
session复制带来的性能损失会快速增加.特别是当session中保存了较大的对象,而且对象变化较快时, 性能下降更加显著. 这种特性使得web应用的水平扩展受到了限制。
Session内容序列化(serialize),会消耗系统性能。
Session内容通过广播同步给成员,会造成网络流量瓶颈,即便是内网瓶颈。

二、基于 Memcached 缓存的 session 共享
即使用cacheDB存取session信息,应用服务器接受新请求将session信息保存在cache DB中,当应用服务器发生故障时,web服务器(apache/nginx)会遍历寻找可用节点,分发请求,当应用服务器发现session不在本机内存时,则去cache DB中查找,如果找到则复制到本机,这样实现session共享和高可用。
目前有开源的msm用于解决tomcat之间的session共享:Memcached_Session_Manager(MSM)
http://code.google.com/p/memcached-session-manager/
一个高可用的Tomcat session共享解决方案,除了可以从本机内存快速读取Session信息(仅针对黏性Session)外,同时可使用memcached存取Session,以实现高可用。

特性
支持Tomcat6、Tomcat7支持黏性、非黏性Session
无单一故障点
可处理tomcat故障转移
可处理memcached故障转移
插件式session序列化
允许异步保存session,以提升响应速度
只有当session有修改时,才会将session写回memcached
JMX管理&监控

该方案的不足之处:
memcache支持的数据结构比较单一
memcache的内存必须足够大,否则会出现用户session从Cache中被清除
需要定期的刷新缓存
服务器故障时,存在于内存的memcache数据将会丢失

为了解决基于memcache中存在的不足,故提出了下面的一种解决方案:

三、基于redis缓存的session共享
结合上面的分析后,由redis负责session数据的存储,而我们自己实现的session manager将负责session生命周期的管理。利用 redis 自身的key过期时间机制,我们不再需要定期刷新和做其他额外的处理。

截止到2015-09-20 前是不支持Tomcat8的,开源Git 地址:https://github.com/jcoleman/tomcat-redis-session-manager
因为我们使用redis 来存储Session,所以前提是redis已经安装和配置完成。(本文不进行redis 的安装配置说明)
使用步骤:

1、将 tomcat-redis-session-manager-1.2.jar 、jedis-2.6.1.jar、commons-pool2-2.2.jar 三个jar包拷贝到tomcat7/lib中。
2、在Tomcat 的conf/context.xml 文件里增加如下内容:

<Valve className="com.orangefunction.tomcat.redissessions.RedisSessionHandlerValve" />
<Manager className="com.orangefunction.tomcat.redissessions.RedisSessionManager"host="localhost" <!-- 可选,默认是"localhost" -->port="6379" <!-- 可选,默认是 "6379" -->database="0" <!-- 可选,默认是 "0" -->maxInactiveInterval="60" <!-- 可选,默认是 "60" (单位:秒)--> />

3、重启Tomcat7,到redis 中查看session_id,如下:

127.0.0.1:6379> keys WJ*
1) "WJSESSIONID:6D5B0E0FD89E3A170B8BC5B8C112D3FD"
2) "WJSESSIONID:9546B26D78C99E8F0BF785535E319271"
3) "WJSESSIONID:839A35CFE17E900A81F50D629C104D2F"
4) "WJSESSIONID:1C287C797CF00C82BBBF37A617A3B55C"
5) "WJSESSIONID:FA2822C5021139641760754242F73393"
6) "WJSESSIONID:E904369E5B24D39B4E25515D50650EA6"
127.0.0.1:6379>

这里进行一下特殊说明:
git 开源项目是直接将SESSIONID作为key存储到redis中的,如下所示:

1) "6D5B0E0FD89E3A170B8BC5B8C112D3FD"
2) "9546B26D78C99E8F0BF785535E319271"
3) "839A35CFE17E900A81F50D629C104D2F"
4) "1C287C797CF00C82BBBF37A617A3B55C"
5) "FA2822C5021139641760754242F73393"
6) "E904369E5B24D39B4E25515D50650EA6"

我对该项目做了一点修改。
修改原因包括几点:
1、项目也有使用redis 做其他数据存储,直接使用这样的key存储到redis中,直观上无法区分哪些key是用来做session共享用的。
2、项目包括好几个服务(web、wap、cms),每个服务都需要做负载均衡session共享,这样以来无法区分哪些session是属于哪个服务的。
3、很难统计每个服务的在线用户数。

我在集群部署中我的每个服务都有不同的sessionCookieName(web = WJSESSIONID、wap = MJSESSIONID、cms = CMSJSESSIONID)
不知道怎么配置的,这里简单说一下,直接在tomcat7/conf/server.xml 的最下面的Context中增加 sessionCookieName 配置即可:

<Context docBase="F:\workspace\web" path="" reloadable="false" sessionCookieName="WJSESSIONID" />

我修改后的项目已经共享到:http://download.csdn.net/detail/catoop/9122857 (项目是一个maven项目)
其中 tomcat-redis-session-manager\target\tomcat-redis-session-manager-1.2.jar 可以直接使用。

Tomcat7基于Redis的Session共享实战二相关推荐

  1. Tomcat7基于Redis的Session共享

    目前,为了使web能适应大规模的访问,需要实现应用的集群部署.集群最有效的方案就是负载均衡,而实现负载均衡用户没一个请求都有可能被分配到不固定的服务器上,这样我们首先要解决session的统一来保证无 ...

  2. 项目分布式部署那些事(1):ONS消息队列、基于Redis的Session共享,开源共享

    因业务发展需要现在的系统不足以支撑现在的用户量,于是我们在一周之前着手项目的性能优化与分布式部署的相关动作. 概况 现在的系统是基于RabbitHub(一套开源的开发时框架)和Rabbit.WeiXi ...

  3. tomcat+redis实现session共享

    注意:在实际应用中,发现该方案会不定期导致Tomcat假死(怀疑Redis连接未释放),慎用. 服务器192.168.14.132和192.168.14.133, 均已经安装tomcat,tomcat ...

  4. C#session共享+redis_技术干货分享:基于SpringBoot+Redis的Session共享与单点登录

    categories: 架构 author: mrzhou tags: SpringBoot redis session 单点登录 基于SpringBoot+Redis的Session共享与单点登录 ...

  5. tomcat集群redis配置session共享

    针对之前的nginx+tomcat的负载均衡机制,因为会出现session丢失的问题,特研究了下redis的session共享:下载JDK7.tomcat7以备后续测试: 一.下载tomcat-red ...

  6. 分布式中使用 Redis 实现 Session 共享(中)

    http://blog.jobbole.com/91874/ 原文出处: 焰尾迭   欢迎分享原创到伯乐头条 上一篇介绍了一些redis的安装及使用步骤,本篇开始将介绍redis的实际应用场景,先从最 ...

  7. SpringBoot整合Redis+Redis缓存应用+Redis实现Session共享+...

    一.SpringBoot整合Redis 1.导入依赖 <!--存在Redis依赖--> <dependency><groupId>org.springframewo ...

  8. Tomcat通过Redis实现session共享的完整部署记录

    对于生产环境有了一定规模的tomcat集群业务来说,要实现session会话共享,比较稳妥的方式就是使用数据库持久化session.为什么要持久化session(共享session)呢?因为在客户端每 ...

  9. Rainbond最佳实践:Tomcat配置Redis实现Session共享

    Rainbond:生产级无服务器PaaS Rainbond是国内首个开源的生产级无服务器PaaS,深度整合基于Kubernetes的容器管理.多类型CI/CD应用构建与交付.多数据中心的资源管理等技术 ...

最新文章

  1. BZOJ 2137 submultiple(约数,拉格朗日插值求自然数k次幂和)【BZOJ 修复工程】
  2. 掌握它才说明你真正懂 Elasticsearch
  3. 一个hadoop hdfs put 文件失败的小情况
  4. [UOJ422]小Z的礼物
  5. 速卖通运营之选品方法和技巧
  6. OpenGL:显示一些立体图形示例程序(真不错)
  7. 输入两个正整数m和n,用java求其最大公约数和最小公倍数
  8. 451 Sort Characters By Frequency 根据字符出现频率排序
  9. MAC下go语言的安装和配置
  10. Using openRefine
  11. 魏俊妮《非人力资源的人力资源管理技术提升》课程大纲
  12. 全国增值税发票查验平台验证码识别
  13. 征途服务器文件,征途端游服务器地址
  14. Day05——综合任务1、顺序表
  15. codeforces 1509 B. TMT Document
  16. Golang开发新手常犯的50个错误
  17. Keras学习| ImageDataGenerator的参数
  18. c语言头文件格式图片_请高手赐教C语言图片文件头文件格式的解释,该怎么处理...
  19. 华为系大数据专家傅一航老师--沪师经纪刘建
  20. 拿到华为200万年薪的8个人到底是何方神圣?为什么有人反而不屑?

热门文章

  1. 一张图片学Python
  2. 微信公众账号开发文档
  3. Linux程序在预处理、编译、汇编、链接、运行步骤的作用
  4. HttpWebResponse 的问题
  5. Thinkpad F2不能进行重命名的问题
  6. php用get方式传json数据 变成null了
  7. 05_通过sql操作表中的数据_插入修改删除查询
  8. Strut学习-web.xml
  9. HRBUST 1909——理工门外的树——————【离线处理,差分前缀和】
  10. PHP检查PEAR是否工作