微服务之间的Session共享问题

本文探讨了Session共享的三种解决方案:hash一致性、统一存储和子域session共享,并详细介绍了如何通过SpringSession整合来实现session的共享,解决了多实例部署下session不同步的问题。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

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

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

}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值