6.3.3(OCT 20, 2020)
发布日志
发布策略
提醒:版本号右边, ↑
表示>=该版本号, ↓
表示<=该版本号
提醒:Spring Boot版本和Spring Cloud Alibaba版本需要在版本号后面加上.RELEASE
版本 | 状态 | SC版本 | SB版本 | SCA版本 |
---|---|---|---|---|
6.3.3 | H.SR5 ↑ H G F |
2.3.x 2.2.x 2.1.x 2.0.x |
2.2.x 2.2.x 2.1.x 2.0.x |
|
G | 2.1.x | 2.1.x | ||
F | 2.0.x | 2.0.x | ||
3.20.3 | E | 1.5.x | 1.5.x | |
D | 1.x.x | N/A | ||
C | 1.x.x | N/A |
表示维护中 | 表示不维护,但可用,强烈建议升级 | 表示不维护,不可用,已废弃
- 6.x.x版本(同时适用于Finchley、Greenwich和Hoxton以及未来的更高版本),将继续维护
- 5.x.x版本(适用于Greenwich)已废弃
- 4.x.x版本(适用于Finchley)已废弃
- 3.x.x版本(适用于Edgware)不维护,但可用,强烈建议升级
- 2.x.x版本(适用于Dalston)已废弃
- 1.x.x版本(适用于Camden)已废弃
版本变更
无中间件版本变更
依赖变更
管理中心插件依赖独立
如果使用者想使用该插件,需要手工引入。例如,在服务侧的依赖,变更如下
<dependencies>
<!-- 1.注册中心插件 -->
<dependency>
<groupId>com.nepxion</groupId>
<artifactId>discovery-plugin-register-center-starter-nacos</artifactId>
<version>${discovery.version}</version>
</dependency>
<!-- 2.配置中心插件 -->
<dependency>
<groupId>com.nepxion</groupId>
<artifactId>discovery-plugin-config-center-starter-nacos</artifactId>
<version>${discovery.version}</version>
</dependency>
<!-- 3.管理中心插件 -->
<dependency>
<groupId>${project.groupId}</groupId>
<artifactId>discovery-plugin-admin-center-starter</artifactId>
<version>${discovery.version}</version>
</dependency>
<!-- 4.服务的策略编排插件 -->
<dependency>
<groupId>com.nepxion</groupId>
<artifactId>discovery-plugin-strategy-starter-service</artifactId>
<version>${discovery.version}</version>
</dependency>
</dependencies>
异步跨线程Agent插件依赖独立
为使异步跨线程Agent插件更具通用性,从Discovery工程独立出去,单独以DiscoveryAgent工程呈现,请访问
https://github.com/Nepxion/DiscoveryAgent
插件入口的包名简化为
discovery-agent-starter-${discovery.agent.version}.jar
并提供相关插件扩展指南示例,请访问
https://github.com/Nepxion/DiscoveryAgentGuide
功能迭代
灰度路由下的版本故障转移
版本故障转移,即无法找到相应版本的服务实例,路由到老的稳定版本的实例。其作用是防止灰度版本路由人为设置错误,或者对应的版本实例发生灾难性的全部下线,导致流量有损
故障转移方式,对版本号进行排序,取第一个版本号,所以此方案的前置条件是必须版本号是规律的有次序,例如,以时间戳的方式。如果所有服务实例的版本号未设置,那么将转移到未设置版本号的实例上
需要通过如下开关开启该功能
# 启动和关闭版本故障转移。缺失则默认为false
spring.application.strategy.version.failover.enabled=true
并行灰度路由下的版本偏好策略
版本偏好,即非灰度路由场景下,路由到老的稳定版本的实例。其作用是防止多个网关上并行实施灰度版本路由产生混乱,对处于非灰度状态的服务,调用它的时候,只取它的老的稳定版本的实例;灰度状态的服务,还是根据传递的Header版本号进行匹配
偏好方式,对版本号进行排序,取第一个版本号,所以此方案的前置条件是必须版本号是规律的有次序,例如,以时间戳的方式。如果所有服务实例的版本号未设置,那么将转移到未设置版本号的实例上
需要通过如下开关开启该功能
# 启动和关闭版本偏好。缺失则默认为false
spring.application.strategy.version.prefer.enabled=true
增加SLF4J MDC异步Agent插件
需要通过如下开关开启该功能
-Dthread.mdc.enabled=true
增加自定义异步Agent插件开关控制机制
需要通过isEnabled方法覆盖实现开关控制插件生效/失效机制
以MDCPlugin为例,表示thread.mdc.enabled=true的时候,开启该插件
public class MDCPlugin extends AbstractPlugin {
private Boolean threadMDCEnabled = Boolean.valueOf(System.getProperty("thread.mdc.enabled", "false"));
@Override
protected String getMatcherClassName() {
return "org.slf4j.MDC";
}
@Override
protected String getHookClassName() {
return MDCContextHook.class.getName();
}
@Override
protected boolean isEnabled() {
return threadMDCEnabled;
}
}
缺陷修复
修复IP地址和端口路由的缺陷
遗漏对非Json格式的端口路由Header支持
修复异步场景下域名灰度路由的缺陷
修复异步场景下,Http Request获取RequestURL的空指针异常
相关下载
DiscoveryAgent下载
访问https://github.com/Nepxion/DiscoveryAgent/releases
获取最新版本
DiscoveryDesktop下载
访问https://github.com/Nepxion/DiscoveryUI/releases
获取最新版本