Skip to content

6.3.3(OCT 20, 2020)

Compare
Choose a tag to compare
@HaojunRen HaojunRen released this 19 Oct 14:01

发布日志

发布策略

提醒:版本号右边, 表示>=该版本号, 表示<=该版本号

提醒: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
5.6.0 G 2.1.x 2.1.x
4.15.0 F 2.0.x 2.0.x
3.20.3 E 1.5.x 1.5.x
2.0.x D 1.x.x N/A
1.0.x 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获取最新版本