Springboot整合redis完成session共享
1.1 安装redis就不再介绍
1.2 Springboot创建项目
引入Spring web Spring security Spring Data redis Spring session
1.3 配置propertise文件
spring.redis.host=localhost
spring.redis.database=0
spring.redis.port=6379
spring.redis.password=wzh622301
#指定端口
server.port=8080
1.4 web层进行测试
新建controller
@RestController
public class HelloController {
@Value("${server.port}")
Integer port;
@GetMapping("/set")
public String set(HttpSession httpSession){
httpSession.setAttribute("name","wzh");
return String.valueOf(port);
}
@GetMapping("/get")
public String get(HttpSession session){
return (String) session.getAttribute("name")+port;
}
浏览器进行测试
测试8081,可以直接进行,实际应用中还要结合nginx进行使用
为什么要用redis结合session共享呢?
1.先进的企业级或者大型的网站平台,都是分布式结构,分布式的好处是通过nginx分发请求,让多个服务器各自处理请求,来减少单一服务器的压力,并且提高执行效率。
2.在这个分布式结构下,如果不用共享session的话,就会出现问题。当一个客户端发送一个请求(无session),通过nginx将第一次请求分发给服务器1,服务器判断无session,就让那个客户进行登录操作,并得到响应,此时客户端会存储一个来自服务器1响应的session,并存储在客户端。
3.当客户端发送第二次请求的时候,此时本次请求已经携带了session(跳过登录),nginx却将请求分发给服务器2,因为服务器2中没有session,所以无法与客户端session进行对应。所以程序会出现异常或是报错,无法正常响应