【笔记于学习尚硅谷课程所作】
1、Session共享
问题:
- 同一个服务,复制多份,session不同步问题
- 不同服务,session不能共享问题
(1)hash一致性
优点:
- 只需要改nginx配置,不需要修改应用代码
- 负载均衡,只要hash属性的值分布是均匀的,多台web-server的负载是均衡的
- 可以支持web-server水平扩展(session同步法是不行的,受内存限制)
(2)统一存储
优点:
- 没有安全隐患
- 可以水平扩展,数据库/缓存水平切分即可
- web-server重启或者扩容都不会有session丢失
我们使用统一存储解决Session共享问题
(3)子域session共享
前面两种解决的是在统一域名下的共享问题。如果域名不同,采取的措施,手动设置扩大域名,扩大到域名一样,即使用父域名,变成第一种共享问题
2、 SpringSession整合
1.导入依赖(需要整合过redis【可参考Springboot项目–缓存环境搭建及介绍】)
<!--整合spring session 实现session共享问题 -->
<dependency>
<groupId>org.springframework.session</groupId>
<artifactId>spring-session-data-redis</artifactId>
</dependency>
2.修改配置文件
# 配置springsession的存储方式
spring.session.store-type=redis
# springsession 过期时间
server.servlet.session.timeout=30m
3.添加注解@EnableRedisHttpSession
4.添加自定义的配置文件
@Configuration
public class GulimallSessionConfig {
@Bean
public CookieSerializer cookieSerializer() {
DefaultCookieSerializer serializer = new DefaultCookieSerializer();
serializer.setCookieName("GULISESSION");
serializer.setDomainName("gulimall.com");
return serializer;
}
@Bean
public RedisSerializer<Object> springSessionDefaultRedisSerializer() {
return new GenericJackson2JsonRedisSerializer();
}
}