SpringBoot中实现分布式的Session共享的详细教程

作者:千锋教育官方博客 时间:2023-08-23 18:23:43 

一. SpringBoot中实现Session共享

1. 创建web项目

我们按照之前的经验,创建一个web程序,并将之改造成Spring Boot项目,具体过程略。

SpringBoot中实现分布式的Session共享的详细教程

2.添加依赖包


<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-data-redis</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.session</groupId>
<artifactId>spring-session-data-redis</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.session</groupId>
<artifactId>spring-session-core</artifactId>
</dependency>

3.创建application.yml文件


server:
port: 8080
#配置redis
spring:
redis:
host: 127.0.0.1
port: 6379
#password: 123456
jedis:
pool:
 max-idle: 8
 min-idle: 0
 max-active: 8
 #max-wait: 60000
#timeout: 3000 #超时一定要大于0
session:
#设置session存储类型
store-type: redis

这里可以设置多种session的store-type:

SpringBoot中实现分布式的Session共享的详细教程

我们这里选择利用redis来对session进行集中存储,实现session共享。

4.创建Session配置类


package com.yyg.boot.config;

import org.springframework.context.annotation.Configuration;
import org.springframework.session.data.redis.config.annotation.web.http.EnableRedisHttpSession;

/**
* @Author 一一哥Sun
* @Date Created in 2020/4/28
* @Description 开启Redis Http Session
*/
@Configuration
@EnableRedisHttpSession(maxInactiveIntervalInSeconds = 3600)
public class RedisHttpSessionConfiguration {

}

在这里添加@EnableRedisHttpSession注解,可以通过maxInactiveIntervalInSeconds属性设置Session的过期时间。

5.创建一个Controller接口方法

该接口方法当用户不存在时提示“用户不存在”,否则会提示“用户存在”。


package com.yyg.boot.web;

import lombok.extern.slf4j.Slf4j;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestParam;
import org.springframework.web.bind.annotation.RestController;

import javax.servlet.http.Cookie;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpSession;

/**
* @Author 一一哥Sun
* @Date Created in 2020/4/28
* @Description Description
*/
@Slf4j
@RestController
public class SessionController {

@RequestMapping("/session")
public Object springSession(@RequestParam("username") String username, HttpServletRequest request, HttpSession session) {
Cookie[] cookies = request.getCookies();
if (cookies != null && cookies.length > 0) {
 for (Cookie cookie : cookies) {
 log.warn(cookie.getName() + "=" + cookie.getValue());
 }
}

Object value = session.getAttribute("username");
if (value == null) {
 log.warn("用户不存在");
 //保存session
 session.setAttribute("username", "{username: '" + username + "', age: 30}");
} else {
 log.warn("用户存在");
}

return "username=" + value;
}

}

6.创建入口类


package com.yyg.boot;

import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;

/**
* @Author 一一哥Sun
* @Date Created in 2020/4/28
* @Description Description
*/
@SpringBootApplication
public class SpringSessionApplication {

public static void main(String[] args){
springapplication.run - 这个网站可出售。 - 最佳的springapplication 来源和相关信息。(SpringSessionApplication.class,args);
}

}

7.完整项目结构

SpringBoot中实现分布式的Session共享的详细教程

8.启动项目进行测试

第一次在浏览器中进行访问,会看到浏览器中的username=null,并且控制台中展示的log信息为“用户不存在”,说明此时还没有创建出session。但是当第一次访问之后,session就被创建出来了,并且被存储到了redis中,实现了持久化存储。可以看如下图:

SpringBoot中实现分布式的Session共享的详细教程

第二次访问,就会看到username已经可以获取到新的信息了。

SpringBoot中实现分布式的Session共享的详细教程

log控制台中也看到已经提示“用户存在”的信息了。

SpringBoot中实现分布式的Session共享的详细教程

并且我们可以看到Redis控制台中,提示了TTL过期时间是3660,每隔1秒钟刷新1次,3600秒后过期。

SpringBoot中实现分布式的Session共享的详细教程

此时我们可以分别启动一个8080和8081进程,在两个进程上分别测试session接口。

#进入到项目的target目录下,执行java -jar命令,部署我们的jar包

F:\onlineWorks\boot-demos\demo43_springsession\target>java -jar demo43_springsession-1.0-SNAPSHOT.jar --server.port=8080

F:\onlineWorks\boot-demos\demo43_springsession\target>java -jar demo43_springsession-1.0-SNAPSHOT.jar --server.port=8081

SpringBoot中实现分布式的Session共享的详细教程

SpringBoot中实现分布式的Session共享的详细教程

在浏览器中,我们的8080和8081端口上访问时,可以看到有一个共同的Session信息:

SpringBoot中实现分布式的Session共享的详细教程

可以看到在两个不同的进程端口上,都分别访问到了同一个session信息,说明我们实现了分布式进程中session共享。可见在有了Spring Session后,实现session共享还是很简单得到。

来源:https://blog.csdn.net/GUDUzhongliang/article/details/106897785

标签:SpringBoot,分布式,Session,共享
0
投稿

猜你喜欢

  • Reactor中的onErrorContinue 和 onErrorResume

    2022-12-01 14:30:58
  • 如何从UA分辨出Android设备类型

    2023-09-03 00:37:44
  • Struts2中异常处理机制分析

    2023-11-17 21:54:32
  • Android Studio项目适配AndroidX(Android 9.0)的方法步骤

    2022-10-30 12:01:03
  • c#制作类似qq安装程序一样的单文件程序安装包

    2021-07-22 17:13:31
  • Spring3 整合MyBatis3 配置多数据源动态选择SqlSessionFactory详细教程

    2023-03-21 21:22:27
  • tcp、udp、ip协议分析_动力节点Java学院整理

    2023-05-17 18:00:17
  • C#中缓存的基本使用方法

    2023-02-23 13:47:44
  • sweet alert dialog 在android studio应用问题说明详解

    2022-12-14 04:17:53
  • 获取JsonObject某一未知key的值操作

    2023-02-10 15:09:45
  • C#实现添加多行文本水印到Word文档

    2023-03-22 07:45:33
  • 描述C#多线程中lock关键字的使用分析

    2021-12-31 08:42:32
  • jmeter+ant+jenkins自动化测试环境配置搭建过程

    2023-11-17 23:38:06
  • 通过实例了解java spring使用构造器注入的原因

    2022-11-25 03:48:24
  • Android编程基于距离传感器控制手机屏幕熄灭的方法详解

    2022-02-20 10:49:05
  • Java设计模式之代理模式_动力节点Java学院整理

    2021-08-24 05:55:18
  • Java集合继承体系详解

    2023-12-03 00:22:13
  • C#在DataTable中根据条件删除某一行的实现方法

    2022-03-09 05:34:19
  • C# CancellationToken和CancellationTokenSource的用法详解

    2023-05-26 19:39:41
  • Unity实现本地文本多语言化

    2023-05-19 21:58:50
  • asp之家 软件编程 m.aspxhome.com