当多个应用做集群的时候,如何实现应用之间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里。