关于SpringCloud灰度发布的实现

 更新时间:2023年08月31日 11:28:27   作者:haozhugogo  
这篇文章主要介绍了关于SpringCloud灰度发布的实现,灰度发布又称金丝雀发布,是在系统升级的时候能够平滑过渡的一种发布方式,灰度发布可以保证整体系统的稳定,在初始灰度的时候就可以发现、调整问题,以保证其影响度,需要的朋友可以参考下

一、springcloud灰度发布思路

  • 注册中心:不解释了
  • 根据用户路由:user id关联路由标签
  • 区分服务实例:给服务实例打标签   eureka.instance.metadata-map.key=value
  • 负载均衡ribbon:修改路由规则,根据用户标签路由到对应服务

二、ribbon大致原理

  1. RibbonAutoConfiguration 是起始点,会在spring启动时被扫起来,实例化SpringClientFactory。
  2. SpringClientFactory 是获取Ribbon相关实例或配置的工厂类,可以获取指定服务的ILoadBalancer和IConfig等,继承自NamedContextFactory。
  3. NamedContextFactory 维护了每个服务相关的上下文AnnotationConfigApplicationContext;上下文在第一次调用时被创建,并注册、装配相关类、接口;外界获取相关类、接口就是从上下文中拿的。
  4. RibbonClientConfiguration 用来实例化自定义接口。
  5. XXXLoadBalancer 负责调用IRule选择Server,并启动定时任务更新ServerList列表。
  6. ZoneAvoidanceRule是默认的IRule,先利用XXXPredicate进行过滤,然后在从过滤的结果中选择。

三、最终代码实现

1.在目标服务上配置灰度标签。

2.将想要的灰度标签保存到threadlocal里,注意有线程池的情况。

3.自定义路由规则IRule以及预判规则Predicate,将不符合标签的服务过滤掉掉,然后从剩下的服务中选一个。

4.自定义RibbonClientConfiguration,指定用步骤3的自定义IRule。

到此这篇关于关于SpringCloud灰度发布的实现的文章就介绍到这了,更多相关SpringCloud灰度发布内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • MyBatis的一级缓存和二级缓存以及优点说明

    MyBatis的一级缓存和二级缓存以及优点说明

    MyBatis的缓存机制包括一级缓存和二级缓存,一级缓存是SqlSession级别的缓存,开启默认,二级缓存是跨SqlSession的缓存,需要手动开启和配置,二级缓存的优点是减少数据库访问、提高性能、降低负载和提高可扩展性,同时需要注意缓存可能导致的数据不一致问题
    2025-02-02
  • 如何利用Ganymed SSH-2模拟SSH操作

    如何利用Ganymed SSH-2模拟SSH操作

    这几天看SFTP资料时,无意中看到了Ganymed SSH-2,写了个简单demo,通过,感觉挺好用的,下面就和大家分享下。需要的朋友可以过来参考参考
    2013-08-08
  • JavaBean四个作用域范围的详解

    JavaBean四个作用域范围的详解

    这篇文章主要介绍了JavaBean四个作用域范围的详解的相关资料,希望通过本文能帮助到大家,需要的朋友可以参考下
    2017-10-10
  • Java 网络编程之 TCP 实现简单的聊天系统

    Java 网络编程之 TCP 实现简单的聊天系统

    这篇文章主要介绍了Java 网络编程之 TCP 实现简单的聊天系统,帮助大家更好的理解和学习Java 网络编程,感兴趣的朋友可以了解下
    2020-11-11
  • 一篇文章带你入门Java数据结构

    一篇文章带你入门Java数据结构

    这篇文章主要介绍了Java常见数据结构面试题,带有答案及解释,希望对广大的程序爱好者有所帮助,同时祝大家有一个好成绩,需要的朋友可以参考下,希望可以帮助到你
    2021-08-08
  • Java数据结构和算法之冒泡,选择和插入排序算法

    Java数据结构和算法之冒泡,选择和插入排序算法

    这篇文章主要为大家介绍了Java冒泡,选择和插入排序算法 ,具有一定的参考价值,感兴趣的小伙伴们可以参考一下,希望能够给你带来帮助
    2022-01-01
  • java实现电话本管理系统

    java实现电话本管理系统

    这篇文章主要为大家详细介绍了JAVA实现电话本管理系统,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2018-02-02
  • Spring Boot 优雅整合多数据源

    Spring Boot 优雅整合多数据源

    这篇文章主要介绍了Spring Boot 优雅整合多数据源,多数据源就是在一个单一应用中涉及到了两个及以上的数据库,更多相关内容需要的小伙伴可以参考下面文章介绍
    2022-05-05
  • Java实现桌面日历

    Java实现桌面日历

    这篇文章主要为大家详细介绍了Java实现桌面日历,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2022-06-06
  • SpringBoot+MyBatis-Plus实现分页功能

    SpringBoot+MyBatis-Plus实现分页功能

    在SpringBoot项目中,结合MyBatis-Plus(简称MP)可以非常方便地实现分页功能,MP为开发者提供了分页插件PaginationInterceptor,只需简单配置即可使用,本文给大家介绍了SpringBoot+MyBatis-Plus实现分页功能,文中通过代码示例给大家介绍的非常详细,需要的朋友可以参考下
    2024-01-01

最新评论