Spring Cloud 2020.0.0 正式发布,对开发者来说意味着什么?

2023-10-26

头图.png

作者 |
YourBatman 在线教育领域资深架构师,Spring Framework 开源贡献者
冷冷 云集架构师、开源项目 pig 负责人、Spring Cloud Alibaba Committer
来源|阿里巴巴云原生公众号

北京时间 2020 年 12 月 22 日深夜,Spring Cloud 2020.0.0 版本正式发布。2020.0.0 是第一个使用新版本命名方案的发命名的 Spring Cloud 发行版本。除了肉眼可见的更开发者友好的命名方式,这次发布全面抛弃了 Netflix 技术栈,并且是一个长期维护的主要版本。这对开发者来说意味着什么呢?今天我们邀请到开源社区活跃作者 YourBatman 和 Spring Cloud Alibaba committer 冷冷来和大家解读下这次发版的重要变化,更重要的是和大家聊聊我们作为开发者后续应该如何应对

Spring Cloud 版本管理

在 Spring Cloud 2020.0.0 正式发布之前,Spring Cloud 的 Release Train 名称采用的是伦敦地铁站名称来命名的,并以字母表顺序排列,如:Hoxton、Greenwich、Ilford 等,这种命名方式存在两个致命问题:

  • 对非英语母语国家,比如中国就非常不友好,无法快速理清版本号关系

  • 英文字母就 26 个,倘若版本号到了 Z 以后呢?如何继续发展?

1.png

Spring Cloud 遵循 Pivotal OSS support policy 协议对主要版本提供三年的支持。此外,在 Spring Cloud 的主要或次要版本发布后,若存在严重的 bug 和安全问题,就会再维护一段时间(6-12 个月不等)。参考以下表格:

2.jpg

3.jpg

核心变化解读

Spring Cloud 2020.0.0 作为一个主要版本,带来了众多显著的变化,其中进行了一些阻断式更新(不向下兼容)是本文最大看点,来吧上菜。

核心变化一:再见了,Netflix

早在 2018 年,Spring Cloud 在其 Roadmap 里就宣布将要终结的一些库/版本,其中最重要的就是指 Spring Cloud Netflix 项目进入维护模式,然后计划在 2020 年完全移除。

Spring Cloud 做出这样的决定其实也是不见得是主动的。我们知道 Spring Cloud 一直以来把 Netflix OSS 套件作为其官方默认的一站式解决方案,那时的 Netflix OSS 套件恨不得可以跟 Spring Cloud 划等号。而 Netflix 公司在 2018 年前后宣布其核心组件 Hystrix、Ribbon、Zuul、Archaius 等均进入维护状态

时至今日,Spring Cloud 2020.0 正式发布,在这个主要版本里,按既定计划终于对 spring-cloud-netflix 动刀了。我帮你画了幅 spring-cloud-netflix-dependencies 的 xml 文件前后版本主要差异的对比图,一目了然:

4.jpg

  • 旧版本的 spring-cloud-netflix-dependencies 管理着 Netflix 所有组件,包括 Hystrix、Ribbon、Zuul、Eureka 等。而自 2020.0 版本起它有且只管理 Eureka(包括 Server 和 Client)。

核心变化二:继续业界标准制定,完善抽象定义

可能对于大部分 Spring Cloud 应用开发者, 对于 spring-cloud-commons 模块大概很陌生。此模块作为 Spring Cloud 技术栈的核心,提供了整套解决方案最重要的服务注册与发现、负载均衡、上下文管理等的统一抽象。spring cloud alibaba 等全家桶实现都是 spring-cloud-commons 的具体实现。此版本对上文下启动器的默认启动行文、负载均衡器的核心代码进行相关的跳转。

spring-cloud-commons
  ├── actuator
  ├── circuitbreaker
  ├── discovery
  ├── hypermedia
  ├── loadbalancer
  └── serviceregistry

核心变化三:强推 reactive 异步体系

reactor 是 reactive(反应式编程)的实现框架,也是 Pivotal 团队的作品。

无论是 Spring Cloud Gateway 还是 Spring Cloud Loadbalancer 这些都是构建在 reactor 编程之上。

5.png

另外 Spring 官方布道师 Josh Long 最近出版一本 《Reactive Spring》,如果想深入了解 reactor ,不妨深入阅读。

核心变化四:更好的拥抱云原生能力

Spring Cloud 2020 构建在 Spring Boot 2.4 之上,拥有更强的配置文件处理机制可以非常好的适配云原生 (例如可以直接应用 kubernetes 的 configMap )配置;内置 Docker 镜像构建和分层分析优化能力。

如果团队正在使用 kubernetes,那么 spring-cloud-kubernetes 也将是 Netflix 的不错替代方案。

6.jpg

组件替代方案

Spring Cloud 既然把 Netflix 套件大刀阔斧的砍掉了,那总归得有替代方案吧。那是必然的,Spring Cloud 团队给我们推荐了用于替代的组件:

7.jpg

Spring Cloud LoadBalancer

以上替代品中,你可能最陌生、最好奇的是 Spring Cloud Loadbalancer,它一度只是 Spring Cloud 孵化器里的一个小项目,并且一度搁浅。后再经过重启,发展,现行使其伟大使命,正式用于完全替换 Ribbon,成为 Spring Cloud 负载均衡器唯一实现

8.png

如图,负载均衡抽象 LoadBalancerClient 接口有两个实现,而到了 Spring Cloud 2020.0 版本后,BlockingLoadBalancerClient 就是唯一实现了。

Spring Cloud LoadBalancer 目前仅支持轮询负载均衡策略,相对于 Ribbon 多种高可用策略还是过于简单。

Spring Cloud Circuit Breaker

Circuit Breaker 提供兼容多个断路器组件实现的抽象,允许开发人员选择最熟悉的断路器组件进行业务开发。

9.png

这里主要介绍一下 Sentinel、Resilience4j , Sentinel 作为 Spring Cloud Alibaba 重要组件,通过引入 spring-cloud-starter-alibaba-sentinel 即可拥有熔断降级、流控等能力,提供图形化控制台,作为同类组件 Resilience4j 是基于函数式设计的轻量级容错库,提供熔断、限流、隔离等能力,不过官方提供的 spring-cloud-starter-circuitbreaker-resilience4j 插件能力有限且不能直接使用控制台管理(若需监控需要额外的 Micrometer 服务)。

Spring Cloud Alibaba 适配

  • 由于对 Ribbon 组件的依赖,目前最新的 Spring Cloud Alibaba 2.2.3 并不能完全兼容 Spring Cloud 2020,仅需要微调即可。
// 排除 Ribbon (当然也可以排查 maven 依赖)
@EnableAutoConfiguration(excludeName = 
"org.springframework.cloud.netflix.ribbon.RibbonAutoConfiguration")
  • 增加 spring cloud loadbalancer 依赖。
<dependency>
    <groupId>org.springframework.cloud</groupId>
    <artifactId>spring-cloud-starter-loadbalancer</artifactId>
</dependency>
  • 涉及加载配置中心的服务需要 启动 bootstrap (2020 默认关闭)。
<!--增加此依赖即可完成启动-->
<dependency>
  <groupId>org.springframework.cloud</groupId>
  <artifactId>spring-cloud-starter-bootstrap</artifactId>
</dependency>

开发者如何面对和拥抱变化

正如上文所述 Spring Cloud 提供了强大的封装和抽象能力,例如 spring-cloud-circuit-breaker 提供了对常见容错组件的封装,在使用过程中也不需要考虑 @hystrixcommand``@SentinelResource 组件原生注解。

public static class DemoControllerService {
    private RestTemplate rest;
    private CircuitBreakerFactory cbFactory;
    public String slow() {
        return cbFactory.create("slow").run(() -> rest.getForObject("/slow", String.class), throwable -> "fallback");
    }
}
  • 通过此类抽象底层实现组件的变化 ,对于上层使用 Spring Cloud 全家桶的用户其实影响不大(例如《Spring Cloud Alibaba 迁移指南:零代码从 Eureka 迁移到 Nacos》)。

  • 关于学习 spring-cloud-commns 笔者不建议直接阅读源码(部分 reactor 代码容易劝退),建议 DEBUG 具体实现的形式进行调试(例如 NacosDiscoveryClient),最核心的代码不过百行。

10.png

  • 所以对于开发者来说无论是之前 Netflix 还是选择 Alibaba 技术栈,最核心的还是把握 spring-cloud-commons 抽象,掌握 Spring Cloud 标准尤为重要。

总结

Spring Cloud 2020.0.0 是 Spring Cloud 的主要版本,是非常重要的存在,升级、改变也是巨大的。特别体现在 Netflix 模块的全部移除、Spring Cloud 启动方式变了等等。伴随着 Spring Boot 2.4.x 以及 Spring Cloud 2020.0 的发布,并且弃用 Netflix OSS 套件后,必将走入一个新的深度编程体验,满怀惊喜,很是期待。

当然我们还是非常推荐大家使用 Spring Cloud Alibaba 全家桶的,目前 Spring Cloud Alibaba 开源两年时间,已经从官方毕业,不仅在关注度、活跃上表现抢眼,更通过发布知行动手实验室 start.aliyun.com 提供沙箱和 Java 工程脚手架Arthas 代码诊断工具等成为工具链最完善的 Spring Cloud 实现。

11.png

数据来源:http://www.gharchive.org/ 近2年GitHub开发者行为数据
活跃度计算公式:https://github.com/X-lab2017/github-analysis-report-2019/blob/master/REPORT.md

推荐阅读

本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

Spring Cloud 2020.0.0 正式发布,对开发者来说意味着什么? 的相关文章

  • Static Timing Analysis for Nanometer Designs A Practical Approach

    分享电子书籍 静态时序分析圣经 Static Timing Analysis for Nanometer Designs A Practical Approach 1 setup time Setup time 建立时间 是数据信号 D 在
  • 小程序 - 日期选择器

    效果图 实现步骤 1 创建组件 wxml
  • Unity3D控制Animator播放

    有一个需求 要求第一次打开一个界面触发一个动画播放 关闭界面动画播放关闭 再次打开界面继续上次到播放而不是重新开始播放 如果动画播放结束关闭打开界面入口 即无法在此进入该界面 有两种实现方法 方法1 第一次打开界面开始播放特效动画 调用an

随机推荐

  • AI—漂亮的花简单制作(含详细教程)

    暑假在家刷短视频 不 不 不 球球 别别别 平面制作搞起来 跟数媒小可爱学炒鸡有意思的AI吧 今天带来的是一朵漂亮的花 gt 效果图入下 步骤一 用 星形 工具 gt 角点数 为25 如图 gt 确定 步骤二 按住ALT键 复制一个星形 缩
  • 再也不用担心网吧开黑队友听不清了!降噪解决方案了解一下?

    欢迎大家前往腾讯云 社区 获取更多腾讯海量技术实践干货哦 本文由腾讯游戏云发表于云 社区专栏 经常逛游戏论坛的朋友会深有感触 很多玩家经常会在论坛里吐槽在网吧开黑的体验很差 噪音太多 在游戏语音开黑的过程中 如果其中一个队友身处网吧 则其他
  • chronyc sources -V

    Chrony 是一个时钟同步工具 而 chronyc sources V 是它的命令行参数 用于显示当前时钟源的详细信息 使用这个参数后 会输出当前时钟源的信息 包括 源类型 IP 地址 可用性 偏差和误差等 通过这些信息 可以了解时钟源的
  • Linux 编译运行查找头文件和库的顺序

    linux中在使用gcc进行编译时 可能会出现找不到相应库或头文件的情况 往往让人十分头疼 因此 此文描述了库和头文件的查找顺序和一些注意事项 希望能帮助大家在出错时能够快速定位和解决 头文件 gcc在编译时按照如下顺序寻找所需要的头文件
  • set,env和export的区别

    http blog csdn net longxibendi article details 6125075 http blog chinaunix net uid 128922 id 289956 html set 显示 设置 shell
  • JSP编程手记------jsp页url中传中文参数乱码问题续

    一个偶然的机会 发现了一个解决jsp页url中传中文参数乱码的方法 比我前面说的用隐形的form表单来的更加漂亮和容易 具体方法如下 程序清单 response sendRedirect gh 0001 xm java net URLEnc
  • Qt手动设置Kits套件

    Qt编译器版本手动设置方式 文章目录 Qt编译器版本手动设置方式 前言 一 安装MSVC2019 32bit 二 手动设置kits套件 总结 前言 在给Qt Creator添加自定义控件时 遇到的版本问题让人头疼 我用的Qt5 12 10
  • 那一年读过的技术经典书

    转载请注明 http blog csdn net xinzhangyanxiang article details 10199757 大学刚毕业 总结起来读过的书并不算多 而且主要集中在大四的时期读的 在此把经典统一总结一遍 先总结机器学习
  • Qt信号和信号槽(二)

    目录 信号槽使用拓展 示例1 一个信号可以对应多个槽函数 在上篇文章的代码中进行修改 示例2 用信号连接信号 信号槽的连接方式 示例 Lambda表达式 语法格式 定义和调用 信号槽使用拓展 一个信号可以连接多个槽函数 发送一个信号有多个处
  • SpringBoot使用quartz, 注入feignClient, client为null

    使用 autowired 活着构造方法注入 打断点查看注入的feigncliet为null 搜索网上的一些博客 大致原因是因为quartz启动是通过反射将一些类注入进来 启动的时候引用这个类还没初始化好 下面是解决方案 使用spring 提
  • OpenRestry-demo

    openRestry 基于Nginx和lua的高性能web平台内置了大量lua库和第三方的模块 为了使用lua开发一些定制功能 安装环境 安装环境 yum y install pcre devel openssl devel gcc cur
  • 基本的传染病模型:SI、SIS、SIR及其Python代码实现

    本文主要参考博客 http chengjunwang com en 2013 08 learn basic epidemic models with python 该博客有一些笔误 并且有些地方表述不准确 推荐大家阅读Albert Lasz
  • 【腾讯云 Cloud Studio 实战训练营】通过云IDE构建Web3项目

    iOS开发上架主页 在强者的眼中 没有最好 只有更好 移动开发领域优质创作者 阿里云专家博主 文章目录 背景 一 前言 二 Cloud Studio 主要功能和应用场景 三 Cloud Studio 实验前期准备 3 1 打开官网 3 2
  • 在MATLAB中,用Simulink搭建一个二阶传递函数模型

    文章目录 1 模型准备 二阶传递函数模型 1 1 二阶传递函数模型 1 1 1 时域模型 1 1 2 频域模型 1 2 二阶传递函数公式和参数 2 开始建模 在simulink中搭建二阶传递函数模型 2 1 从simulink库中添加传递函
  • python选择文件夹,并自动发送这个文件夹下的所有文件(以附件的形式)至指定邮箱(通过163邮箱)

    工作中需要将自动生成的表格发送给办公邮箱继续处理 结合遍历文件夹和自动发邮件 做出了可以选择文件夹 并自动发送这个文件夹下的所有文件 以附件的形式 至指定邮箱 import smtplib from email mime multipart
  • jdk8新特性-方法引用

    1 作用 什么是方法引用 方法引用是jdk8推出的一个新特性 在一定的条件下可以替换lambda表达式 可以理解为方法引用实际上还是一个lambda表达式 lambda表达式用法可参见 https blog csdn net xiao yu
  • Centos7 使用yum命令安装软件失败,报错"Couldn't open file /media/cdrom/repodata/repomd.xml"

    今天使用CentOS7安装docker的时候 安装失败 报错 yum install docker 已加载插件 fastestmirror langpacks file media cdrom repodata repomd xml Err
  • java记录操作日志(对象修改细节)

    背景 由于业务涉及收入敏感信息 需记录数据变更前的内容和变更后的内容 但是不能为完成任务而硬编码 要适用于不同bean 针对这种情况 本文使用泛型 反射和基于AOP的自定义注解技术来完成 对对象属性的描述通过自定义注解来完成 读取里面的属性
  • 使用Cytoscape画PPI网络图

    打开Cytoscape软件 根据菜单导入string interactions tsv文件 File gt Import gt Network from File 会弹出下图对话框 在对话框中设置如下 选中string interactio
  • Spring Cloud 2020.0.0 正式发布,对开发者来说意味着什么?

    作者 YourBatman 在线教育领域资深架构师 Spring Framework 开源贡献者 冷冷 云集架构师 开源项目 pig 负责人 Spring Cloud Alibaba Committer 来源 阿里巴巴云原生公众号 北京时间