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

一. Redis实现分布式Session管理

1. Memcached管理机制

Redis实现分布式Session管理的机制详解_第1张图片

2. Redis管理机制

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

Redis实现分布式Session管理的机制详解_第2张图片

二. SpringBoot项目开发Session管理

1. 引入依赖pop.xml

 
    
      org.springframework.boot
      spring-boot-starter-data-redis
    

    
    
      org.springframework.session
      spring-session-data-redis
    

    
    
    org.springframework.boot
    spring-boot-starter-tomcat
    provided
    

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

Redis实现分布式Session管理的机制详解_第3张图片

@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.打包测试

Redis实现分布式Session管理的机制详解_第4张图片

三 . Nginx+Tomcat集群+Redis测试

1.Nginx相关配置

Redis实现分布式Session管理的机制详解_第5张图片
Redis实现分布式Session管理的机制详解_第6张图片
在这里插入图片描述

2.Tomcat集群

在这里插入图片描述

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


//连接端口


在这里插入图片描述

改变初始页面index.jsp

Redis实现分布式Session管理的机制详解_第7张图片

3.Redis集群

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

Redis实现分布式Session管理的机制详解_第8张图片
Redis实现分布式Session管理的机制详解_第9张图片

4. 测试

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

Redis实现分布式Session管理的机制详解_第10张图片

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

Redis实现分布式Session管理的机制详解_第11张图片
Redis实现分布式Session管理的机制详解_第12张图片
Redis实现分布式Session管理的机制详解_第13张图片

GiF演示一波

Redis实现分布式Session管理的机制详解_第14张图片

到此这篇关于Redis实现分布式Session管理的机制详解的文章就介绍到这了,更多相关Redis实现分布式Session管理内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

你可能感兴趣的:(Redis实现分布式Session管理的机制详解)