最近使用spring boot开发一个系统,nginx做负载均衡分发请求到多个tomcat,此时访问页面会把请求分发到不同的服务器,session是存在服务器端,如果首次访问被分发到A服务器,那么session就会被存到A服务器,再次访问时负载均衡会分发到B服务器那么第一次访问的session信息就会获取不到之前的session信息,所以需要实现session共享,还好有spring session,使用简单的配置即可实现session共享,下面介绍下:
1. pom.xml中引入jar包
- <!-- Spring Boot Redis 依赖 -->
- <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>
2. 添加RedisSessionConfig配置类
在项目的目录中,创建一个java文件(名称随意)即可,我这里名称是RedisSessionConfig.java
@EnableRedisHttpSession这个注解非常最重要,加了它之后,会使用spring的一个拦截器来实现Session共享的操作,而配置的这个Bean,则是让Spring根据配置文件中的配置连到Redis。
SpringSession 需要注意的就是redis需要2.8以上版本,然后开启事件通知,在redis配置文件里面加上
- notify-keyspace-events Ex // 打开此配置,其中Ex表示键事件通知里面的key过期事件,每当有过期键被删除时,会发送通知
或是使用如下命令开启开启事件通知:
- redis-cli config set notify-keyspace-events Egx
如果你的Redis不是你自己维护的,比如你是使用阿里云的Redis数据库(我就是这种情况),你不能够更改它的配置,那么可以使用下面的java配置文件即可。
- package org.spring.springboot.config;
-
- import org.springframework.context.annotation.Bean;
- import org.springframework.context.annotation.Configuration;
- import org.springframework.session.data.redis.config.ConfigureRedisAction;
- import org.springframework.session.data.redis.config.annotation.web.http.EnableRedisHttpSession;
-
- @Configuration
- // maxInactiveIntervalInSeconds 默认是1800秒过期,这里测试修改为60秒
- @EnableRedisHttpSession(maxInactiveIntervalInSeconds = 1800)
- public class RedisSessionConfig {
-
- @Bean
- public static ConfigureRedisAction configureRedisAction() {
- return ConfigureRedisAction.NO_OP;
- }
- }
-
3. 配置redis连接
Spring Boot会自动创建一个RedisConnectionFactory将Spring Session连接到端口6379(默认端口)上localhost上的Redis服务器的连接。在生产环境中,您需要确保更新配置以指向Redis服务器
src/main/resources/application.properties
- # Redis 配置
- # Redis数据库索引(默认为0)
- spring.redis.database=0
- # Redis服务器地址
- spring.redis.host=192.168.0.1
- # Redis服务器连接端口
- spring.redis.port=6379
- # Redis服务器连接密码(默认为空)
- spring.redis.password=1234
上面三个步骤搞定后,即可session共享,有任何问题欢迎留言沟通哦~
了解更多spring session内容可以访问官网:https://docs.spring.io/spring-session/docs/current/reference/html5/guides/boot-redis.html
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持w3xue。