看了尚硅谷的教材资料,觉得非常好理解,分享出来!!!
session原理
1、每次请求都会带上一个cookie:jessionid= xxxzzz
2、按照jessionid就知道是哪个用户session.setAttribuet(k,v) /session.getAttribute(k)
为什么要spring-session
4.1 SpringSession简介
1、SpringSession主要解决分布式情况下,session一致性的问题;
2、session一致性:只要用户不重启浏览器,每次http短连接请求,理论上服务端都能定位到session,保持会话。
4.2 为什么要spring-session
1、传统方式session问题
在传统单机web应用中,一般使用tomcat/jetty等web容器时,用户的session都是由容器管理。
浏览器使用cookie中记录sessionid,每次发送请求的时候会带上这个sessionid,web容器根据sessionid找到当时在服务存储信息时使用的那个Map,以此判断用户是否存在会话session。
注意:最大的问题是,session存储在web容器中,被单台服务器容器管理。
在分布式情况下,这会导致什么?
当然,如果我们一直玩单机版的应用,不用关心这个问题,但是随着业务逐渐增大,分布式应用和集群是趋势。
解决session不一致有很多方案,但多配置复杂或者有明显的缺点。有了SpringSession,所有的session由SpringSession创建维护,无需我们修改任何代码,就能在集群环境下使用原生的session方式编程,无侵入、简单配置和Spring应用无缝整合、对接各种session存储方案;
SpringSession使用
5.1 整合SpringBoot
5.1.1 引入依赖
在配置文件中编写配置
redis配置
spring.redis.host=39.98.76.67
#spring.redis.pool.max-active=100
spring.redis.jedis.pool.max-idle=100
springsession配置
spring.session.store-type=redis
session过期时间
spring.session.timeout=1800
测试
@RestController
@SpringBootApplication
public class SpringSession01Application {
public static void main(String[] args) {
SpringApplication.run(SpringSession01Application.class, args);
}
@GetMapping("/set")
public String setSession(HttpSession session){
session.setAttribute(“msg”, “Hello”);
return “ok”;
}
@GetMapping("/get")
public String getSession(HttpSession session){
return (String) session.getAttribute(“msg”);
}
}
我们可以看到,redis中保存了数据,而且如果我们设置多台服务器,访问get获取到的都是一样的