关闭

Redis学习笔记(八)Redis存储Tomcat集群的Session

307人阅读 评论(0) 收藏 举报
分类:

作者:chszs,转载需注明。博客主页:http://blog.csdn.net/chszs

前段时间,我花了不少时间来寻求一种方法,把新开发的代码推送到到生产系统中部署,生产系统要能够零宕机、对使用用户零影响。

我的设想是使用集群来搞定,通过通知负载均衡Nginx,取下集群中的Tomcat节点,然后对Tomcat上的应用进行升级,再通知负载均衡Nginx,把Tomcat节点重新加载上去。依次这么做,把集群中的所有Tomcat都替换一次即可。

那么问题来了,在取下Tomcat节点和加载新Tomcat节点时如何做到对用户无影响呢?方法很简单,共享Session。
下面,我们用实例来说明此方案。我们的例子使用了一台Nginx做负载均衡,后端挂接了两台Tomcat,且每台Tomcat的Session会话都保存到Redis数据库中。其中,Nginx配置为non-sticky运行模式,也即每一个请求都可以被分配到集群中的任何节点。当要上线新代码时,只需简单地取下Tomcat实例,此时所有的访问用户会被路由到活动的Tomcat实例中去,而且由于会话数据都是保存在Redis数据库中,所以活跃用户并不会受影响。当Tomcat更新完毕,又可以把此节点加入到Nginx中。

安装Nginx

# sudo rpm -ivh nginx-1.4.2-1.el6.ngx.x86_64.rpm

修改配置文件/etc/nginx/nginx.conf,并添加下面的内容:

http {
upstream tomcat  {
        server localhost:8080;
        server localhost:8081;
    }
include       /etc/nginx/mime.types;
default_type  application/octet-stream;
修改配置文件/etc/nginx/conf.d/default.conf并替换location部分的内容:

location / {
    proxy_pass  http://tomcat;
  }

重启Nginx

# sudo service nginx restart
接下来,安装两个Tomcat实例。由于我们是在同一台服务器上做的演示,要让两台Tomcat不发生冲突,需要修改第二个Tomcat实例的端口号。由于Nginx配置为non-sticky运行模式,对每个请求采用的是Round-robin负载均衡方式,这意味着它会为每个请求都抽奖一个新会话。

接着,下载并安装Redis。步骤省略,很简单。

最后,我们需要配置Tomcat,让Tomcat把会话Session保存到Redis数据库。

我们要使用tomcat-redis-session-manager这样的第三方库,主页见:

https://github.com/jcoleman/tomcat-redis-session-manager

要注意此库并非开箱即用的,使用时需要做一些调整。你需要下载源码,并在更新了依赖库的版本后,重建项目。比如我使用了commons-pool2-2.2.jar和jedis-2.6.1.jar依赖库。要记住把这些jar文件复制到每一个Tomcat实例的lib子目录下。

在更新了commons-pool、jedis和tomcat版本这些库后,你可以使用build.gradle来构建整个项目。构建完毕后,复制新生成的tomcat-redis-session-manager-1.2.jar到每一个Tomcat实例的lib子目录下。并在修改每一个Tomcat实例的context.xml配置文件:

<Valve className="com.orangefunction.tomcat.redissessions.RedisSessionHandlerValve" />
<Manager className="com.orangefunction.tomcat.redissessions.RedisSessionManager"
         host="localhost"
         port="6379"
         database="0"
         maxInactiveInterval="60" />
重启Tomcat实例。可以检查到Redis确实保存了Tomcat的会话。然后我们对Tomcat实例取下或恢复时,访问用户确实没受影响。
2
0
查看评论

搭建Tomcat集群&通过Redis缓存共享session的一种流行方案

为什么要共享session? 我们使用单台Tomcat的时候不会有共享sesssion的疑虑,只要使用Tomcat的默认配置即可,session即可存储在Tomcat上。 但是随着业务的扩大,增加Tomcat节点构成Tomcat集群大势所趋,分布式带来了增加更大规模并发请...
  • u011674124
  • u011674124
  • 2017-05-31 12:17
  • 1095

Tomcat集群之使用Redis来存储集群Session

在对tomcat进行集群时,不可避免的涉及到session的共享问题。session共享有这几种方案: 每个tomcat都保存所有的session,且需要有一定的机制来同步session 将session放在第三方,每个tomcat自己不再维护session,当tomcat需要使用session时,...
  • sxyandapp
  • sxyandapp
  • 2016-08-03 11:42
  • 1158

tomcat集群-基于redis的session共享

1.环境依赖:tomcat7,jdk7 2.下载所需jar commons-pool2-2.2.jar、jedis-2.6.1.jar、tomcat-redis-session-manager1.2.jar 下载地址:http://download.csdn.net/download/xu...
  • xuxile
  • xuxile
  • 2016-11-01 12:01
  • 377

使用Redis存储Nginx+Tomcat负载均衡集群的Session

环境:Cent OS 7.0(虚拟机环境)、Nginx 1.9.8、Redis 3.2.1一、背景在使用Nginx+Tomcat实现负载均衡的时候,由于Nginx对不同的请求分发到某一个Tomcat,Tomcat在运行的时候分别是不同的容器里,因为会出现session不同步或者丢失的问题。二、Ngi...
  • u010870518
  • u010870518
  • 2016-07-25 17:26
  • 20646

【JavaWeb】Redis存储Session方案

所有支持Servlet规范的容器都自带session管理,于是大多数人都使用HttpSession接口存放状态信息。事实上, servlet的session会使得应用服务器水平扩展变的非常困难。 使用Servlet Session时的妥协方案 Session Replication 这...
  • hj7jay
  • hj7jay
  • 2016-09-03 14:41
  • 1282

spring-session,利用redis存储session,解决集群共享session的问题

用nginx做负载的时候,会出现每一次http请求都会分配到不同的tomcat上,这样用session存储用户数据就会有问题。因为tomcat集群之间没有实现session共享。 spring-session很好的帮我们解决了这个问题。 第一步,在pom.xml添加依赖 org....
  • guo5253142
  • guo5253142
  • 2016-06-03 10:51
  • 4292

Redis应用——使用Redis存储Session

PHP默认使用文件存储Session,但如果并发量很大,效率非常低。而Redis对高并发的支持非常好,所以,可以使用Redis替代文件存储Session。 在讲解实例之前,先了解PHP的session_set_save_handler()函数的作用和使用方法。该函数可以设置用户级别的Sessio...
  • lamp_yang_3533
  • lamp_yang_3533
  • 2016-09-18 22:38
  • 1298

session保存到redis简单实现

在负载均衡情况下,如果用户访问不同的机器,如果没有做session同步,用户就会被提出,这样用户体验非常不好,所以我们很远必要做session同步,把session放到reids缓存服务器就能很好的解决问题。下面是代码简单的实现。 一、配置web.xml过滤器: sessionFilter...
  • ppt0501
  • ppt0501
  • 2015-06-30 20:54
  • 19552

单点登录 Tomcat7集群共享Session 基于redis实现统一管理

http://jaychang.iteye.com/blog/2249415
  • u013322876
  • u013322876
  • 2016-12-26 11:54
  • 1151

基于Redis的Tomcat集群Session共享

目前的web应用集群,使用Nginx做负载均衡,将upstream配置成ip_hash的方式,这种模式下,Nginx会根据来源IP和后端配置来做hash分配,确保固定IP只访问一个后端。 upstream YOUR_NAME { ip_hash; server 192.168...
  • qq_27376871
  • qq_27376871
  • 2016-09-20 16:31
  • 1332
    个人资料
    • 访问:354758次
    • 积分:6602
    • 等级:
    • 排名:第4322名
    • 原创:212篇
    • 转载:457篇
    • 译文:1篇
    • 评论:68条