首页 >> 大全

SpringBoot利用Redis管理分布式Session

2023-12-13 大全 21 作者:考证青年

前言

由于Http连接是无状态的,所以使用做服务器的时候内部会维护一个叫做的东东用来保存客户端的状态,一般情况下每个客户端都有一个里面保存着叫的,每次访问的时候都会携带上,可以根据这个找到对应的。就像你去超市买东西,门口的储物柜可以视作一个容器,而打出的二维码条就是。

在分布式系统中,对于同一个客户端,访问哪个服务器就会在哪个里面创建。简单来说我做一个登录功能,即第一次访问的时候需要输入用户名密码,访问成功后就在自己的里面写入用户名,那么我下次访问的时候直接检测里是否有自己的用户名来判断自己是否处于登录状态了。现在问题来了,如果我第一次访问的是,登录成功后由于nginx的负载均衡第二次访问打到了上,那么里面并没有我的用户名信息,所以我还需要重新登录。一个最直观的想法就是把和的抽出来放到某一个位置,这样不管访问还是都会从同一个里面获取用户信息。

以一个非常简洁易用的方式帮我们实现了分布式,我们需要做的仅仅是1个注解,几行配置,几行代码。

一、配置maven

org.springframework.bootspring-boot-starter-data-redisorg.springframework.bootspring-boot-starter-weborg.springframework.sessionspring-session-data-redis

二、配置.yml

16afc6ac05c0fde52c6779cbc3e42611

spring:session:store-type: redistimeout: 3600sredis:flush-mode: on_savenamespace: spring:sessionredis:host: 192.168.99.100port: 6379timeout: 5000ms

三、使用

//主类首先开启EnableRedisHttpSession注解
@SpringBootApplication
@EnableRedisHttpSession
public class DistributeSessionApplication {public static void main(String[] args) {SpringApplication.run(DistributeSessionApplication.class, args);}
}

//编写controller,set用于向session添加属性,get用于从session获取属性
package com.example.distributesession.controller;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.RestController;import javax.servlet.http.HttpServletRequest;
import java.util.HashMap;
import java.util.Map;/*** @Author: 小混蛋* @CreateDate: 2018/12/11 17:20*/
@RestController
public class TestController {@GetMapping("/set")public void test(HttpServletRequest request){request.getSession().setAttribute("message",request.getQueryString());}@GetMapping("/get")public Map two(HttpServletRequest request){Map map = new HashMap<>();map.put("sessionId",request.getSession().getId());map.put("message",request.getSession().getAttribute("message"));return map;}
}

四、复制项目

复制项目,设置端口为8081,

访问8080端口的接口/set,添加为name='xxx'

image.png

然后访问8081端口的接口/get,结果如下

_分布式事务redis解决方案_分布式事物redis

结果

五、原理浅析

本质上利用的的实现类实现了对每一次请求的拦截,拦截之后把放到Redis里面

关于我们

最火推荐

小编推荐

联系我们


版权声明:本站内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 88@qq.com 举报,一经查实,本站将立刻删除。备案号:桂ICP备2021009421号
Powered By Z-BlogPHP.
复制成功
微信号:
我知道了