文档章节

Nginx+Tomcat+Redis负载均衡Session共享实现超级简单(CentOS6.9系统 Java版本)

小帅帅丶
 小帅帅丶
发布于 2017/06/07 11:37
字数 1610
阅读 4498
收藏 279

个人小程序,可以微信扫一扫看看。谢谢支持

有问题加QQ:783021975 验证问题写明在哪知道的QQ。直接说问的问题。会在不忙的时候回复你。毕竟我也有自己的工作要做。

第一步Nginx+Tomcat 实现负载均衡的测试

  •  相关软件环境
软件名称 版本号 版本说明
Java 1.7 linux版本
Tomcat 8081 7.x linux版本
Tomcat 8082 7.x linux版本
Redis 3.2.9 linux版本
Nginx 1.12.0 linux版本
CentOS 6.9 ----------
MySql 系统自带 ----------

链接: https://pan.baidu.com/s/1i5U3srj 密码: hkda 这个是centos网盘地址。其他的在博文底部有给出下载地址

  • 软件版本环境截图

  • 实践测试环境说明

使用的是VMware Workstation 挂载了CentOS6.9版本的虚拟机。这个版本的虚拟机里面自带了mysql,所以不需要下载安装。

Java 安装教程 http://www.cnblogs.com/haoliansheng/p/5832979.html

Redis 安装教程 http://jingyan.baidu.com/article/6dad507510ea07a123e36e95.html

Tomcat在安装好Java之后再解压即可。为了做Nginx负载均衡。需要2个Tomcat。本人分别为8081 8082端口做2个Tomcat。需要修改server.xml 只截取了部分内容

  

  <Server port="8015" shutdown="SHUTDOWN"><!--这里需要修改tomcat的关闭端口 默认是8005-->
  <Listener className="org.apache.catalina.startup.VersionLoggerListener" />
  <Listener className="org.apache.catalina.core.JasperListener" />
  <Listener className="org.apache.catalina.core.JreMemoryLeakPreventionListener" />
  <Listener className="org.apache.catalina.mbeans.GlobalResourcesLifecycleListener" />
  <Listener className="org.apache.catalina.core.ThreadLocalLeakPreventionListener" />
  <GlobalNamingResources>
    <Resource name="UserDatabase" auth="Container"
              type="org.apache.catalina.UserDatabase"
              description="User database that can be updated and saved"
              factory="org.apache.catalina.users.MemoryUserDatabaseFactory"
              pathname="conf/tomcat-users.xml" />
  </GlobalNamingResources>
  <Service name="Catalina">
   <!--这里需要修改tomcat的访问端口 默认是8080-->
    <Connector port="8081" protocol="HTTP/1.1"
               connectionTimeout="20000"
               redirectPort="8443" />
    <!--这里需要修改tomcat的代理端口 8443不用更改-->
    <Connector port="7009" protocol="AJP/1.3" redirectPort="8443" />

修改完即可。启动Tomcat 8081 & 8082  cd到bin目录下  执行 ./startup.sh 即可 想看启动相关内容 则执行 ./catalina.sh 命令截图如下

那么现在就可以访问Tomcat了。左图8081 右图 8082 部署了2个相同的项目。

               

  • 接下来可以Nginx的安装了。

有可能需要安装一些库  命令如下

yum -y install pcre-devel openssl openssl-devel
yum install gcc gcc-c++ ncurses-devel perl
yum install -y zlib-devel

tar解压nginx。进入到nginx目录

输入 make 命令。等待执行完成后。输入make install 。基本到这里就安装完成。那么来启动一下。验证nginx是否成功。nginx默认端口为80

  • 配置Nginx 以达到负载均衡的效果。5种配置方式
序号 方式名称 方式说明(1 2 3实践测试过)
1 轮询

默认配置

upstream xsdemo{  
server 192.168.110.128:8081;  
server 192.168.110.128:8082;  
 

2 weight(权重)

正向代理 设置权重

upstream xsdemo{  
server 192.168.110.128:8081 weight=10;  
server 192.168.110.128:8082 weight=10;  
 

3 ip_hash 

每个请求按访问ip的hash结果分配,这样每个访客固定访问一个后端服务器,可以解决session(并不是共享session解决)的问题。  

upstream xsdemo{ 

ip_hash;
server 192.168.110.128:8081 weight=10;  
server 192.168.110.128:8082 weight=10;  
 

4 fair 按后端服务器的响应时间来分配请求,响应时间短的优先分配
5 url_hash 按访问url的hash结果来分配请求,使每个url定向到同一个后端服务器,后端服务器为缓存时比较有效
  • 博文采用第一种测试。修改nginx的配置文件 nginx.conf 大概在33行上下。upstream是固定写法后面的 xsDemo可以自定义。但是要与下面的localtion proxy_pass http://xsDemo http://后面的对应。区分大小写。保存以后。重启nginx。如果tomcat没启动。则先启动tomcat后再启动nginx
upstream xsDemo {
	server 192.168.110.128:8081;
	server 192.168.110.128:8082;
	}
    server {
        listen       80;
        server_name  localhost;
        location / {
            root   html;
            index  index.html index.htm;
	     proxy_pass http://xsDemo;
        }
  • 看下效果 第一次是8081 再刷新8082 来回刷新来回切换。这就是轮询配置方式的负载均衡

  

  • 使用ip_hash 可以解决session的问题。但是只能做唯一服务器访问。这样不算是负载均衡。所以这里不再做测试给演示看。可以自行测试。

-----------------------------------------------------------------------

第二步接做Redis+Session共享。

  • 上面有Redis的安装经验网址。自行查看即可。为了测试方便。允许远程访问虚拟机的redis。修改配置文件redis.conf 大概在55行左右。修改bind 后面的ip为 0.0.0.0 即可
Port           : 6379
Config file    : /etc/redis/6379.conf
Log file       : /var/log/redis_6379.log
Data dir       : /var/lib/redis/6379
Executable     : /usr/local/bin/redis-server
Cli Executable : /usr/local/bin/redis-cli
方便测试开启远程访问。并没有设置密码。修改6379.conf即可。增加密码验证 44行上下
# requirepass foobared 取消注释 修改foobared为您自己要设置的密码即可。
允许任何ip访问设置 55行上下  bind 127.0.0.1 修改为  bind 0.0.0.0 即可。修改这些之前建议停止redis。
  • 需要第三方jar来支持session共享
tomcat-redis-session-manager1.2.jar

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

链接: https://pan.baidu.com/s/1nw4SWcx 密码: j8yv

commons-pool2-2.0.jar 链接: https://pan.baidu.com/s/1nw4SWcx 密码: j8yv
jedis-2.7.2.jar 链接: https://pan.baidu.com/s/1nw4SWcx 密码: j8yv

以上3个jar。需要放在tomcta的lib文件夹下面。切记是tomcat的lib下面。不是项目的lib下面。注意pool这个jar。如果有冲突会启动失败。所以要检查好

  • 还需要修改context.xml文件 切记tomcat关闭哦 context.xml文件存在于tomcat的conf文件夹下
<?xml version='1.0' encoding='utf-8'?>
<Context>
    <WatchedResource>WEB-INF/web.xml</WatchedResource>
<Valve className="com.orangefunction.tomcat.redissessions.RedisSessionHandlerValve" />  
  <Manager className="com.orangefunction.tomcat.redissessions.RedisSessionManager"  
   host="192.168.110.128"  
   port="6379"  
   password="xiaoshuai" 如果设置了密码则在这里配置上
   database="0"  redis默认16个database 第一个是0 最后一个是15
   maxInactiveInterval="60" />  
</Context>
  • 到此。配置全部完成。然后再次启动tomcat 8081 & 8082 再启动nginx
  • 看图是不是真的session共享了

第一次登录到title为8888的tomcat服务器

第二次刷新页面不需要重新登录。但是title变成了9999的tomcat服务器

  • 这样就实现了轮询访问服务器。并且session共享。用户不需要再次重新登录了。
  • 看下redis里面的session是否和浏览器的一致

这样整个简单测试Nginx+Tomcat+Redis负载均衡Session共享实现 就已经完成了。

觉得好。可以打赏哦。是本作者亲测的。所以肯定都是运行有结果的。

-----------------------------------------------------------------------

关于Nginx+Keepalived搭建高可用负载均衡环境(HA)的博文。请点击这里https://my.oschina.net/xshuai/blog/917097

© 著作权归作者所有

小帅帅丶

小帅帅丶

粉丝 518
博文 101
码字总数 129547
作品 2
北京
后端工程师
私信 提问
加载中

评论(24)

mofangoing
mofangoing
@nothanks 遇到了和你一样的我问题,redis安装好了,相应的redis需要的jar包也放到tomcat7 lib目录下了,也配置了context文件,用ngxin代理就是登不进去,tomcat也没报错,我的项目中用到了spring security做登录验证,有一种说法是使用了spring security不能直接共享session (https://stackoverflow.com/questions/28447414/how-to-get-same-session-with-spring-security-and-spring-session-from-multiple-se),不知道你解决了这个问题没有
J
JavaMVC

引用来自“小帅帅丶”的评论

引用来自“JavaMVC”的评论

tomcat8+redis做session共享,这样才对,亲自测试通过 http://blog.csdn.net/clj198606061111/article/details/46051483
这个也是我在网上找到的博客

回复@JavaMVC : 恩恩。你说的很对。我后续测试了也更新一下。JDK8+TOMCAT8这个环境我后续更新到博文里面。
还有一个问题就是这个存到redis数据库里的session信息怎么设置有效时间,是真正的像tomcat session一样的那个有效时间,而不是redis数据库的那个有效时间,redis的那个有效时间是正要过了时间就删除了,。如果这些信息一直存在redis里面时间久了,信息量会很大,redis很快就崩溃了
J
JavaMVC
@小帅帅丶 还有一个问题就是这个存到redis数据库里的session信息怎么设置有效时间,是真正的像tomcat session一样的那个有效时间,而不是redis数据库的那个有效时间,redis的那个有效时间是正要过了时间就删除了,。如果这些信息一直存在redis里面时间久了,信息量会很大,redis很快就崩溃了
小帅帅丶
小帅帅丶 博主

引用来自“JavaMVC”的评论

tomcat8+redis做session共享,这样才对,亲自测试通过 http://blog.csdn.net/clj198606061111/article/details/46051483
这个也是我在网上找到的博客

回复@JavaMVC : 恩恩。你说的很对。我后续测试了也更新一下。JDK8+TOMCAT8这个环境我后续更新到博文里面。
J
JavaMVC
tomcat8+redis做session共享,这样才对,亲自测试通过 http://blog.csdn.net/clj198606061111/article/details/46051483
这个也是我在网上找到的博客
小帅帅丶
小帅帅丶 博主

引用来自“JavaMVC”的评论

tomcat8 加session共享的时候直接报错
文中有给出测试的软件环境及各个版本要求。tomcat-redis-session也有给出github地址。代码作者也给出目前还没有完全支持8.具体原因也有说明。你可以自己pull下来。进行测试修改成支持8的。麻烦稍微认真看下文中内容。
J
JavaMVC
tomcat8 加session共享的时候直接报错
小帅帅丶
小帅帅丶 博主

引用来自“小帅帅丶”的评论

引用来自“nothanks”的评论

按照你的操作步骤之后,为啥系统登录不上去,一直停留在登录页?

@nothanks 啥软件环境 你开调试工具自己看下错误 我都是亲测的

引用来自“nothanks”的评论

tomcat用的是tomcat7,其余的跟你一样。我很纳闷,用nginx代理后登录不上,单独访问tomcat就可以
可以加QQ 783021975帮你看一下。单独的nginx是不会session共享的。
小帅帅丶
小帅帅丶 博主

引用来自“小帅帅丶”的评论

引用来自“nothanks”的评论

按照你的操作步骤之后,为啥系统登录不上去,一直停留在登录页?

@nothanks 啥软件环境 你开调试工具自己看下错误 我都是亲测的

引用来自“nothanks”的评论

tomcat用的是tomcat7,其余的跟你一样。我很纳闷,用nginx代理后登录不上,单独访问tomcat就可以
你如果tomcat还没配置redis的一些信息。只用nginx肯定登录不了。我那nginx写的配置内容是轮询方式。基本一操作一次就会跳一个服务器。如果来回跳想登录成功。就是后续的安装redis 和配置redis集成Tomcat。
小帅帅丶
小帅帅丶 博主

引用来自“小帅帅丶”的评论

引用来自“nothanks”的评论

按照你的操作步骤之后,为啥系统登录不上去,一直停留在登录页?

@nothanks 啥软件环境 你开调试工具自己看下错误 我都是亲测的

引用来自“nothanks”的评论

tomcat用的是tomcat7,其余的跟你一样。我很纳闷,用nginx代理后登录不上,单独访问tomcat就可以
你先做第一步 nginx 负载均衡。先不着急session共享呢。一步一步来
redis缓存服务器(nginx+tomcat+redis+mysql实现session会话共享)

一、redis介绍 redis是一个key-value存储系统。和Memcached类似,它支持存储的value类型相对更多,包括string(字符串)、list(链表)、set(集合)、zset(sorted set --有序集合)和hash(哈希类型...

何小帅
2018/06/26
0
0
Nginx反向代理,负载均衡+Tomcat实现Session共享

Nginx反向代理,负载均衡+Tomcat实现Session共享 防伪码:学而不思则罔,思而不学则殆。 作者:何小帅 博客URL:http://hexiaoshuai.blog.51cto.com 一、如何保持session会话 目前,为了使w...

何小帅
2018/06/26
0
0
springboot集成springsession利用redis来实现session共享

spring boot的文档中,告诉我们添加@EnableRedisHttpSession来开启spring session支持,配置如下: Java代码 而@EnableRedisHttpSession这个注解是由spring-session-data-redis提供的,所以在...

鱼煎
2018/11/22
27
0
企业网站架构之Nginx+tomcat+memcached集群

nginx+tomcat+memcached应用 系统环境:RHEL6.4 x64 iptables -F and selinux is disabled 主机角色:node1 :192.168.0.24 :lnmp环境 tomcat memcached node2 :192.168.0.99 : tomcat memcache......

Andy-xu
2014/08/11
1K
0
关于Tomcat集群中对象共享问题

问题大概是这样的: 我们的有个JAVA WEB应用,在一台机器上开两个tomcat做负载(一台机器可以满足需求,为未来也不会做多机的负载均衡),已经使用了memcached做好session共享,后来发现应用...

LeungBin
2012/07/27
1K
3

没有更多内容

加载失败,请刷新页面

加载更多

Spring Boot + Mybatis-Plus 集成与使用(二)

前言: 本章节介绍MyBatis-Puls的CRUD使用。在开始之前,先简单讲解下上章节关于Spring Boot是如何自动配置MyBatis-Plus。 一、自动配置 当Spring Boot应用从主方法main()启动后,首先加载S...

伴学编程
今天
7
0
用最通俗的方法讲spring [一] ──── AOP

@[TOC](用最通俗的方法讲spring [一] ──── AOP) 写这个系列的目的(可以跳过不看) 自己写这个系列的目的,是因为自己是个比较笨的人,我曾一度怀疑自己的智商不适合干编程这个行业.因为在我...

小贼贼子
今天
7
0
Flutter系列之在 macOS 上安装和配置 Flutter 开发环境

本文为Flutter开发环境在macOS下安装全过程: 一、系统配置要求 想要安装并运行 Flutter,你的开发环境需要最低满足以下要求: 操作系统:macOS(64位) 磁盘空间:700 MB(不包含 IDE 或其余...

過愙
今天
6
0
OSChina 周六乱弹 —— 早上儿子问我他是怎么来的

Osc乱弹歌单(2019)请戳(这里) 【今日歌曲】 @凉小生 :#今日歌曲推荐# 少点戾气,愿你和这个世界温柔以待。中岛美嘉的单曲《僕が死のうと思ったのは (曾经我也想过一了百了)》 《僕が死の...

小小编辑
今天
2.5K
16
Excption与Error包结构,OOM 你遇到过哪些情况,SOF 你遇到过哪些情况

Throwable 是 Java 中所有错误与异常的超类,Throwable 包含两个子类,Error 与 Exception 。用于指示发生了异常情况。 Java 抛出的 Throwable 可以分成三种类型。 被检查异常(checked Exc...

Garphy
今天
42
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部