当多个应用作集群的时候,如何实现应用之间session共享。redis
解决办法:spring
用一个容器保存 session,就能共享了。容器能够是数据库,缓存,文件等。固然这里性能最高的仍是 数据库
redis了。缓存
实例代码:服务器
pom文件中加入redis跟sessionsession
<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里配置app
# Redis服务器地址 spring.redis.host=localhost # Redis服务器链接端口 spring.redis.port=6379 # Redis服务器链接密码(默认为空) spring.redis.password=
加上端口号spring-boot
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支持server
@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里。