基于redis实现会话保持

环境描述:

192.168.140.10 nginx

192.168.140.11 tomcat服务器 两个tomcat实例

192.168.140.12 redis服务器 三个redis实例,一主两从实例

192.168.140.13 redis哨兵

1、配置ngix实现tomcat负载均衡

2、配置tomcat实例

第二个实例要更改的地方和上方一致

增加执行权限

进行启动

测试页面

<%@ 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>你好</title>

</head>

<%for(int i=1;i<=6;i++){ %>

<h<%=i%> align="center">欢迎访问 tomcat 1 jsp页面!</

h<%=i%>>

<%} %>

<body>

<center>

<%= request.getSession().getId() %>

</body>

</html>

3、通过nginx访问tomcat,此时tomcat会话ID是非持久的

4、配置redis一主两从环境

1)安装redis2.6
2)配置 redis多实例

3)配置一主多从

7003同上

4)验证一主多从成功
5、配置哨兵
1) 安装redis 2.6

2) 复制哨兵配置文件
3) 编辑配置文件

4) 启动哨兵

需要使用redis-sentiner命令来启动哨兵在redis解压目录里为方便使用拷贝到redis安装目录bin目录中

6、配置tomcat连接redis哨兵保存会话

1)将jar包复制到tomcat

2)编辑tomcat实例配置文件,指定redis集群的信息

在Context标签中添加配置信息

<Valve className="com.orangefunction.tomcat.redissessions.RedisSessionHandlerValve" />

<Manager className="com.orangefunction.tomcat.redissessions.RedisSessionManager"

maxInactiveInterval="60"

sentinelMaster="mymaster"

sentinels="192.168.140.13:26379"

/>

第二个实例同上

7、测试访问nginx,查看会话ID是否一致

相关推荐
九河云3 分钟前
在云计算环境中实施有效的数据安全策略
大数据·网络·数据库·云计算
爱吃烤鸡翅的酸菜鱼1 小时前
从数据库直连到缓存预热:城市列表查询的性能优化全流程
java·数据库·后端·spring·个人开发
虫师c1 小时前
分布式缓存实战:Redis集群与性能优化
redis·分布式·缓存·redis集群·高可用架构·生产环境·数据分片
dualven_in_csdn1 小时前
ubuntu离线安装 xl2tpd
linux·数据库·ubuntu
初听于你3 小时前
高频面试题解析:算法到数据库全攻略
数据库·算法
BTU_YC9 小时前
Neo4j查询计划完全指南:读懂数据库的“执行蓝图“
数据库·neo4j
非极限码农9 小时前
Neo4j图数据库上手指南
大数据·数据库·数据分析·neo4j
mit6.82410 小时前
[C# starter-kit] 命令/查询职责分离CQRS | MediatR |
java·数据库·c#
苏打水com10 小时前
数据库进阶实战:从性能优化到分布式架构的核心突破
数据库·后端