领先一步
VMware 提供培训和认证,以加速您的进步。
了解更多我谨代表社区宣布,Spring Cloud Greenwich 发布列车的正式可用版 (RELEASE) 现已发布。此版本可在 Maven Central 中找到。您可以查看 Greenwich 的 发行说明以获取更多信息。
Edgware 发布列车将于 2019 年 8 月 1 日达到 EOL 状态。您可以在 此处 阅读正式公告。
Spring Cloud Finchley 发布列车被视为主要版本,并且与 Spring Boot 2.0.x 版本相关联。因此,当 Spring Boot 2.0.x 发布分支标记为 EOL 时,Spring Cloud Finchley 发布列车将达到 EOL 状态。一旦确定日期,将在本博客上发布关于此事的公告。
Spring Cloud Greenwich 发布列车被视为次要版本,并将继续支持 Spring Boot 2.x 发布分支。
所有项目都进行了更新以实现 Java 11 兼容性。
Greenwich 发布列车包含两个新项目,Spring Cloud GCP(提供与 Google Cloud Platform 的集成)和 Spring Cloud Kubernetes(提供与 Kubernetes 的集成)。
最近,Netflix 宣布 Hystrix 进入维护模式。Ribbon 自 2016 年以来一直处于 类似状态。尽管 Hystrix 和 Ribbon 现在处于维护模式,但它们仍在 Netflix 中大规模部署。
Hystrix Dashboard 和 Turbine 已被 Atlas 取代。这两个项目的最后一次提交分别是在两年前和四年前。Zuul 1 和 Archaius 1 都已被不向后兼容的更高版本所取代。
以下 Spring Cloud Netflix 模块和相应的启动器将进入维护模式
这并不包括 Eureka 或并发限制模块。
将模块置于维护模式意味着 Spring Cloud 团队将不再向该模块添加新功能。我们将修复阻止程序错误和安全问题,并且我们也将考虑并审查来自社区的小型拉取请求。
我们打算继续支持这些模块至少一年,从 Greenwich 发布列车 的正式可用版开始。
我们建议使用以下替代方案来替代这些模块提供的功能。
当前 | 替代方案 |
---|---|
Hystrix | Resilience4j |
Hystrix Dashboard / Turbine | Micrometer + 监控系统 |
Ribbon | Spring Cloud Loadbalancer |
Zuul 1 | Spring Cloud Gateway |
Archaius 1 | Spring Boot 外部配置 + Spring Cloud Config |
敬请关注关于 Spring Cloud Loadbalancer 以及与新的 Netflix 项目 Concurrency Limits 集成的未来博客文章。
请参阅 Google 的 发布公告。
ServiceInstance.instanceId
字段的支持。ServiceInstance.instanceId
字段的支持。请参阅 Spring Cloud Stream 的 发布公告。
ServiceInstance.instanceId
字段的支持。请参阅 Spring Cloud Task 的 发布公告。
ServiceInstance
元数据来自 Kubernetes 标签、注释和端口。KubernetesDiscoveryClient
进行了增强。EnvironmentRepository
以支持 CredHub 后端。@QueryMap
注解的支持。ServiceInstance
接口中添加了 instanceId
。ReactiveLoadBalancer
接口和使用 Reactor 的实现。以下模块已作为 Greenwich.RELEASE 的一部分更新
| 模块 | 版本 | 问题 |--- |--- |--- |--- | Spring Cloud Sleuth | 2.1.0.RELEASE | (问题) | Spring Cloud Gcp | 1.1.0.RELEASE | (问题) | Spring Cloud Build | 2.1.2.RELEASE | | Spring Cloud Netflix | 2.1.0.RELEASE | (问题) | Spring Cloud Consul | 2.1.0.RELEASE | | Spring Cloud Gateway | 2.1.0.RELEASE | (问题) | Spring Cloud | Greenwich.RELEASE | | Spring Cloud Function | 2.0.0.RELEASE | (问题) | Spring Cloud Stream | Fishtown.RELEASE | | Spring Cloud Zookeeper | 2.1.0.RELEASE | | Spring Cloud Cloudfoundry | 2.1.0.RELEASE | | Spring Cloud Aws | 2.1.0.RELEASE | | Spring Cloud Task | 2.1.0.RELEASE | | Spring Cloud Kubernetes | 1.0.0.RELEASE | (问题) | Spring Cloud Contract | 2.1.0.RELEASE | (问题) | Spring Cloud Release | Greenwich.RELEASE | | Spring Cloud Security | 2.1.0.RELEASE | | Spring Cloud Starter | Greenwich.RELEASE | | Spring Cloud Bus | 2.1.0.RELEASE | (问题) | Spring Cloud Config | 2.1.0.RELEASE | (问题) | Spring Cloud Vault | 2.1.0.RELEASE | (问题) | Spring Cloud Openfeign | 2.1.0.RELEASE | (问题) | Spring Cloud Commons | 2.1.0.RELEASE | | Spring Cloud Dependencies | 2.1.2.RELEASE |
与往常一样,我们欢迎您在 GitHub、Gitter、Stack Overflow 和 Twitter 上提供反馈。
使用 BOM(仅依赖项管理)开始使用 Maven
<dependencyManagement>
<dependencies>
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-dependencies</artifactId>
<version>Greenwich.RELEASE</version>
<type>pom</type>
<scope>import</scope>
</dependency>
</dependencies>
</dependencyManagement>
<dependencies>
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-config</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-netflix-eureka-client</artifactId>
</dependency>
...
</dependencies>
开始使用 Gradle
buildscript {
dependencies {
classpath "io.spring.gradle:dependency-management-plugin:1.0.2.RELEASE"
}
}
apply plugin: "io.spring.dependency-management"
dependencyManagement {
imports {
mavenBom 'org.springframework.cloud:spring-cloud-dependencies:Greenwich.RELEASE'
}
}
dependencies {
compile 'org.springframework.cloud:spring-cloud-starter-config'
compile 'org.springframework.cloud:spring-cloud-starter-netflix-eureka-client'
...
}