Redis实现分布式Session管理的机制详解

这篇文章主要介绍了Redis实现分布式Session管理的机制详解,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下

一. Redis实现分布式Session管理

1. Memcached管理机制

在这里插入图片描述

2. Redis管理机制

1.redis的session管理是利用spring提供的session管理解决方案,将一个应用session交给Redis存储,整个应用中所有session的请求都会去redis中获取对应的session数据。

在这里插入图片描述

二. SpringBoot项目开发Session管理

1. 引入依赖pop.xml

  org.springframework.bootspring-boot-starter-data-redis org.springframework.sessionspring-session-data-redis org.springframework.bootspring-boot-starter-tomcatprovided

2. 开发Session管理配置类(使用注解)

在这里插入图片描述

 @Configuration @EnableRedisHttpSession //将整个应用中使用session的数据全部交给redis处理 public class RedisSessionManager { }

3. Controller层设计

 package com.xizi.controller; import org.springframework.stereotype.Controller; import org.springframework.web.bind.annotation.RequestMapping; import javax.servlet.http.HttpServletRequest; import javax.servlet.http.HttpServletResponse; import java.io.IOException; import java.util.ArrayList; import java.util.List; @Controller @RequestMapping("test") public class TestController { //使用redis 的session管理 注意:当session中数据发生变化时必须将session中变化的数据同步到redis中 @RequestMapping("test") public void test(HttpServletRequest request, HttpServletResponse response) throws IOException { List list = (List) request.getSession().getAttribute("list"); if(list==null){ list = new ArrayList<>(); } list.add("xxxx"); request.getSession().setAttribute("list",list);//每次session变化都要同步session response.getWriter().println("size: "+list.size()); response.getWriter().println("sessionid: "+request.getSession().getId()); } @RequestMapping("logout") public void logout(HttpServletRequest request){ //退出登录 request.getSession().invalidate();//失效 } }

4.打包测试

在这里插入图片描述

三 . Nginx+Tomcat集群+Redis测试

1.Nginx相关配置

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

2.Tomcat集群

在这里插入图片描述

 //这是tom4 后面的两个端口号依次+1 //关闭端口  //连接端口 

在这里插入图片描述

改变初始页面index.jsp

在这里插入图片描述

3.Redis集群

已经开启了,不会的去看我前面的Redis集群搭建博客

在这里插入图片描述
在这里插入图片描述

4. 测试

上传war包到三个Tomcat的Webapps目录下

在这里插入图片描述

直接访问Nginx页面,反向代理了Tomcat集群

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

GiF演示一波

在这里插入图片描述

以上就是Redis实现分布式Session管理的机制详解的详细内容,更多请关注0133技术站其它相关文章!

赞(0) 打赏
未经允许不得转载:0133技术站首页 » 数据库