需求:
  公司后端两台tomcat做负载,前端nginx接收用户请求;为了使无论用户请求到后端哪台设备其session都能保持一致,需要做session绑定;
所需软件:
tomcat8、redis、nginx
用到的插件:
https://github.com/ran-jit/tomcat-cluster-redis-session-manager
部署:
1、下载安装tomcat
2、部署redis
3、解压tomcat-cluster-redis-session-manager插件包
3.1、将插件解压包中的lib目录下的所有jar包copy到tomcat的lib目录下
cp /root/tomcat-cluster-redis-session-manager/lib/* /usr/local/tomcat/lib/
3.2、将插件解压包目录中conf目录下的redis-data-cache.properties配置文件copy到tomcat的conf目录下
cp /root/tomcat-cluster-redis-session-manager/conf/* /usr/local/tomcat/conf/
3.3、配置redis-data-cache.properties

redis.hosts=r-2aaaaaaaaaaaaaa.redis.rds.aliyuncs.com:6379  # 指定redis地址
redis.password=AAAAAAAAA # 指定redis密码
redis.cluster.enabled=false # 关闭集群模式,如果是redis集群则需要开启
redis.sentinel.enabled=false
redis.sentinel.master=mymaster
redis.database=11 # 指定redis库
lb.sticky-session.enabled=false
session.persistent.policies=DEFAULT
redis.sso.timeout=0

4、配置测试页面
4.1、在tomcat的webapps目录下创建test目录
mkdir -pv /usr/local/tomcat/webapps/test
4.2、在test目录下定义测试页面
vim index.jsp

<%@ page language="java" contentType="text/html; charset=UTF-8"
pageEncoding="UTF-8"%>
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
<title>首页redis-session</title>
</head>
<body>
<div>tomcat 集群测试</div>
<div>
<%
System.out.println(session.getId());
out.println("<br> SESSION ID:" + session.getId()+"<br>");
%>
% </div>
% </body>
% </html>

5、将配置好的tomcat复制一份到另一台设备
6、配置nginx

upstream backstage {
server 192.168.4.23:8080 max_fails=1 fail_timeout=10s;
server 192.168.4.24:8081 max_fails=1 fail_timeout=10s;
} server {
listen 80;
listen 443 ssl;
server_name test.123.com.cn;
ssl_certificate cert/test.123.com.cn.pem;
ssl_certificate_key cert/test.123.com.cn.key;
ssl_session_timeout 5m;
ssl_protocols TLSv1 TLSv1.1 TLSv1.2;
ssl_ciphers HIGH:!ADH:!MD5;
ssl_prefer_server_ciphers on; if ($server_port = 80) {
rewrite ^/Admin/(.*)$ https://$server_name/Admin/$1 permanent;
} if ($request_uri = /) {
return http://$server_name/Admin/;
} location / {
proxy_set_header Host $host;
proxy_set_header X-Real-IP $remote_addr;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
proxy_set_header X-Forwarded-Scheme https;
proxy_set_header Via "nginx";
client_max_body_size 10m;
client_body_buffer_size 256k;
proxy_connect_timeout 600;
proxy_send_timeout 600;
proxy_read_timeout 600;
proxy_buffer_size 32k;
proxy_buffers 4 64k;
proxy_busy_buffers_size 128k;
proxy_temp_file_write_size 512k;
proxy_pass http://backstage;
}
access_log /var/log/nginx/access.log main;
error_log /var/log/nginx/error.log;
}

7、验证测试

无论怎么刷新,其session都是不变的

查看redis中存储的session,跟web页面中展示的session是一致的;

查看日志也是轮询的策略,但是无论请求到哪台后端tomcat其session都是不变的

 总结:

  所有客户端的session信息都将存储在redis中,而不是保存在tomcat自己内部,即使后端某台tomcat挂了,其session信息也不会丢失,同时两台tomcat的session信息也保持了共享;

nginx+redis+tomcat session绑定的更多相关文章

  1. nginx+redis实现session的共享

    上一篇我们介绍了nginx实现的负载均衡和动静分离,可看这边. 我们在文章的末尾说到,负载均衡需要面临的一个问题是内存数据的同步.例如:我有A,B两台服务器做了负载均衡,当我在A服务器上执行了登录并且 ...

  2. nginx redis tomcat 分布式web应用 session共享

    目标:多台tomcat 使用redis实现共享session.redis的安装请参阅:centos上安装redis nginx 作为目前最流行的开源反向代理HTTP Server,用于实现资源缓存.w ...

  3. Tomcat +Nginx+Redis实现session共享

    一.准备工作 中间件:Tomcat.Redis.Nginx jar包:commons-pool2-2.4.2.jar.jedis-2.8.0.jar.tomcat-redis-session-mana ...

  4. 【原创】搭建Nginx(负载均衡)+Redis(Session共享)+Tomcat集群

    为什么移除首页?哪里不符合要求?倒是回我邮件啊! 一.环境搭建 Linux下Vagrant搭建Tomcat7.Java7 二.Nginx的安装配置与测试 *虚拟机下转至root sudo -i 1)下 ...

  5. 搭建Nginx(负载均衡)+Redis(Session共享)+Tomcat集群

    一.环境搭建 Linux下Vagrant搭建Tomcat7.Java7 二.Nginx的安装配置与测试 *虚拟机下转至root sudo -i 1)下载并解压(目前官网最新版本) 创建安装目录:mkd ...

  6. nginx+tomcat+redis完成session共享

    本文记录nginx+redis+tomcat实现session共享的过程 nginx安装:http://blog.csdn.net/grhlove123/article/details/4783467 ...

  7. nginx+tomcat+redis完成session共享(转载)

    转载:http://blog.csdn.net/grhlove123/article/details/48047735 tomcat7下基于redis的session共享所需jar包: http:// ...

  8. tomcat+nginx+redis实现均衡负载、session共享(一)

    在项目运营时,我们都会遇到一个问题,项目需要更新时,我们可能需先暂时关闭下服务器来更新.但这可能会出现一些状况: 1.用户还在操作,被强迫终止了(我们可以看日志等没人操作的时候更新,但总可能会有万一) ...

  9. Redis+Tomcat+Nginx集群实现Session共享,Tomcat Session共享

    Redis+Tomcat+Nginx集群实现Session共享,Tomcat Session共享 ============================= 蕃薯耀 2017年11月27日 http: ...

随机推荐

  1. npm 是什么?

    npm 是什么? 本文写于 2020 年 6 月 16 日 最近帮几个同学装开发环境,发现他们会各种"卡死"在 npm 安装一些包的过程中. 他们会非常纠结这个命令我明明敲的和网上 ...

  2. zabbix 1.2

    1.zabbix图形界面乱码问题处理 2.自定义监控项 (1)在agent端配置agent.conf    打开vim /etc/zabbix/zabbix-agent.conf    找到UserP ...

  3. 被迫开始学习Typescript —— class

    TS 的 class 看起来和 ES6 的 Class 有点像,基本上差别不大,除了 可以继承(实现)接口.私有成员.只读等之外. 参考:https://typescript.bootcss.com/ ...

  4. Nginx报错收集

    在安装完成ngixn之后,访问页面显示空白,报错信息里面有这一条报错信息: tailf /usr/local/nginx/logs/error.log 2018/10/26 10:58:00 [err ...

  5. Go内存管理一文足矣

    最早学习C.C++语言时,它们都是把内存的管理全部交给开发者,这种方式最灵活但是也最容易出问题,对人员要求极高:后来出现的一些高级语言像Java.JavaScript.C#.Go,都有语言自身解决了内 ...

  6. 【多线程】JUC版的CopyOnWriteArrayList

    CopyOnWriteArrayList CopyOnWriteArrayList适合于多线程场景下使用,其采用读写分离的思想,读操作不上锁,写操作上锁,且写操作效率较低. CopyOnWriteAr ...

  7. 111_Power Pivot 24小时维度:累计、同比、环比相关

    博客:www.jiaopengzi.com 焦棚子的文章目录 请点击下载附件 一.背景 今天有朋友讨论怎么做每天24小时维度的工作量计算(运营类企业,每天24小时都在运营)需求如下: 1.从0时到23 ...

  8. 推荐一款新框架PyScript:在 HTML 嵌入 Python 代码!

    一.介绍 网页浏览器是目前世界上最普遍,最可携的计算机环境.几乎所有人都可以在计算机或是手机上使用网页浏览器,以没有基础设施障碍的方式访问程序. 在 PyCon US 2022 上,知名 Python ...

  9. curl-URL请求

    模拟HTTP请求,通过访问URL获取HTTP响应. 语法 curl [选项] 访问URL 选项 --connect-timeout SECONDS 设置最大请求时间. -C, --continue-a ...

  10. JavaScript正则中//g, g 的作用

    //正则表达式的标准写法regexp = new RegExp(pattern[, flag]); pattern:  模板的用法是关键,也是本章的主要内容.    flag:     "i ...