Spring Cloud 终于大改版?为什么要用日期来做版本号?

简介: Spring Cloud终于改了最近Spring Cloud把版本号从A到Z的伦敦地铁站,改为以日期命名了。

Spring Cloud终于改了

最近Spring Cloud把版本号从A到Z的伦敦地铁站,改为以日期命名了。

也就是从 Greenwich.SR6, Hoxton.SR9 这样子的风格改为 2020.0.0。广大人民终于不用为spring cloud的版本号烦恼了。Spring Cloud推广不力,固然有自身复杂的原因,版本号太复杂也是一个坑。

以日期为版本号,即所谓的Calendar Versioning,可以参考这个网站:

艿艿:Spring Data 也开始使用日期作为版本号!!!!

下面是calver网站的说明。

何时使用 CalVer

如果你和你不认识的人都严肃地使用你的项目,那么 使用一个严肃的版本。幸运的是,为那个版本决定是否使用 CalVer 比以往任何时候都要容易。

  • 你的项目是否具有较大或不断变化的范围?
  • 大型系统和框架,如 Ubuntu 和 Twisted。
  • 无定形的实用程序集,比如 Boltons。
  • 你的项目是否对时间敏感?是否有其他的外部变化 驱动项目新版本的发布?
  • 业务需求,例如 Ubuntu 对支持计划的支持。
  • 安全更新,例如 certifi 对证书更新的需求。
  • 政治变化,例如 pytz 对时区变化的处理。

如果你对这些问题中的任何一个回答是肯定的,CalVer 的语义就会使 它成为你项目的有力选择。

但上面这些理由我觉得都不够充分。

在我看来最重要的理由是:以日期为版本号,让依赖库的开发和下游业务方达成了默契。

阿里巴巴的实践

pandora是阿里巴巴内部的隔离容器。在14年时,pandora 包版本号是这样子的:

  • 2_1_0_3 , 2_1_0_4_10-LOG

后面改为pandora版本 + 日期

  • 2_2_140825, 2_2_140905

但实际上应用方并不关心pandora的版本,所以改为现在的风格:

  • 2020-04-release-fix , 2020-10-release

好处是:

  1. 按时间节点推动升级
    电商的业务都是时间为关键节点的,比如 618/双11。中间件和应用方达成了一个默契:到关键时间点,业务方使用中间件推出的稳定版本,如果出了事故那么就是中间件的锅。不升级,则是业务方自己的锅。
  2. 推动升级的阻力变小
    当业务方遇到问题时,很多时候是不业务方一看它的版本号是1年多前的,很自然它就会升级了。
  3. 依赖提供方要按时间保持更新
    维护人员本身要不断发版本证明自己的生命力。下游用户也可以根据时间选择是否要切换到其它的新技术路线上去了。

对于一些总体的依赖,比如公司内部的maven bom,都建议使用时间做日期。

比如spring 2.5.6版本,大部分开发都知道它是比较旧的依赖了,但不会有太大的动力去管。 但是如果你说,这是12年之前的代码(绝大部分开发还没毕业),那么开发人员就知道很容易会出现不兼容的问题,他自己就知道应该要升级了。

以时间为版本号,既是对用户的承诺,也是对开发者自己的鞭策。

后记

Java领域的微服务虽然不能说尘埃落定,但目前是Spring Boot一家独大。在这5年间有很多故事,我们也有很多实践。立一个flag,希望能写一系列文章记录下来。

相关文章
|
4月前
|
监控 负载均衡 Java
深入理解Spring Cloud中的服务网关
深入理解Spring Cloud中的服务网关
|
4月前
|
Java 开发工具 git
实现基于Spring Cloud的配置中心
实现基于Spring Cloud的配置中心
|
4月前
|
设计模式 监控 Java
解析Spring Cloud中的断路器模式原理
解析Spring Cloud中的断路器模式原理
|
1月前
|
Java 关系型数据库 开发工具
idea创建不了spring2.X版本,无法使用JDK8,最低支持JDK17 , 如何用idea创建spring2.X版本,使用JDK8解决方案
本文提供了解决方案,如何在IDEA中创建Spring 2.X版本的项目并使用JDK8,尽管Spring 2.X已停止维护且IDEA不再直接支持,通过修改pom.xml或使用阿里云的国内源来创建项目。
58 0
idea创建不了spring2.X版本,无法使用JDK8,最低支持JDK17 , 如何用idea创建spring2.X版本,使用JDK8解决方案
|
2月前
|
前端开发 Java Spring
【非降版本解决】高版本Spring boot Swagger 报错解决方案
【非降版本解决】高版本Spring boot Swagger 报错解决方案
|
4月前
|
资源调度 Java 调度
Spring Cloud Alibaba 集成分布式定时任务调度功能
Spring Cloud Alibaba 发布了 Scheduling 任务调度模块 [#3732]提供了一套开源、轻量级、高可用的定时任务解决方案,帮助您快速开发微服务体系下的分布式定时任务。
14893 31
|
4月前
|
负载均衡 Java Spring
Spring cloud gateway 如何在路由时进行负载均衡
Spring cloud gateway 如何在路由时进行负载均衡
473 15
|
4月前
|
Java Spring
spring cloud gateway在使用 zookeeper 注册中心时,配置https 进行服务转发
spring cloud gateway在使用 zookeeper 注册中心时,配置https 进行服务转发
109 3
|
3月前
|
Java
SpringBoot和SpringCloud对应版本
SpringBoot和SpringCloud对应版本
83 0