当多个应用做集群的时候,如何实现应用之间session共享。
解决办法:
用一个容器保存 session,就能共享了。容器可以是数据库,缓存,文件等。当然这里性能最高的还是
redis了。
实例代码:
pom文件中加入redis跟session
<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>
在配置文件application.properties里配置
# Redis服务器地址
spring.redis.host=localhost
# Redis服务器连接端口
spring.redis.port=6379
# Redis服务器连接密码(默认为空)
spring.redis.password=
加上端口号
server.port=8080
定义一个Controller
@GetMapping("get")
public Map<String,String> getSession(HttpServletRequest request){
HashMap<String,String>map=new HashMap<String, String>();
map.put("sessionId",request.getSession().getId());
return map;
}
启动app类加上@EnableRedisHttpSession 开启spring session支持
@SpringBootApplication
@EnableRedisHttpSession
public class DemoApplication {
public static void main(String[] args) {
SpringApplication.run(DemoApplication.class, args);
}
}
启动第二个项目就是改项目的端口
首先访问8080端口的设置session
最后,再访问8081端口的sessions
可见,8080与8081两个服务器返回结果一样,实现了session的共享
这个时候打开redis客户端,可以查询到session信息已经保存在redis里。