微服务之间的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();
    }

}
  • 2
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
微服务架构下的应用通常会面临共享会话的问题。由于微服务的特性,每个微服务都是独立部署和运行的,因此无法直接共享会话状态。然而,有几种方法可以在微服务架构中实现会话共享: 1. 使用无状态会话:将会话状态保存在客户端,每个请求都包含会话信息。微服务通过解析请求中的会话信息来获取会话状态。这种方式不需要在微服务之间共享会话状态,但会增加每个请求的负载大小。 2. 使用共享数据库:将所有微服务的会话状态存储在共享数据库中,例如Redis或数据库。每个微服务都可以访问和更新该数据库中的会话状态。这种方式需要确保对共享数据库的访问是高效和可靠的。 3. 使用分布式缓存:使用像Redis这样的分布式缓存来存储会话状态。每个微服务可以从缓存中获取会话状态,并将更新后的状态写回缓存。这种方式可以减轻对共享数据库的负载,并提供更好的性能。 4. 使用JWT(JSON Web Tokens):将会话信息编码为JWT,并将其传递给每个微服务。每个微服务可以验证和解码JWT来获取会话信息。这种方式不需要在微服务之间共享会话状态,但需要确保JWT的安全性和完整性。 需要注意的是,无论选择哪种方法,都需要确保会话状态的一致性和安全性。同时,根据具体的应用场景和需求,选择适合的方法来共享会话。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值