微服务之间的Session共享问题

【笔记于学习尚硅谷课程所作】

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();
    }

}

猜你喜欢

转载自blog.csdn.net/qq_41596568/article/details/106593016