发布日志
版本更新:
升级Spring Cloud到Greenwich.SR3,确定对Spring Cloud Hoxton版的支持计划
升级Spring Boot版本到2.1.8.RELEASE,并解决spring-web-5.1.9.RELEASE和5.1.8.RELEASE中header设置和传递的不兼容问题(Spring也玩不兼容)
服务端更新:
增加Alibaba Sentinel和灰度路由的有机整合,包括:
封装远程配置中心和本地规则文件的读取逻辑,即优先读取远程配置,如果不存在或者规则错误,则读取本地规则文件。。动态实现远程配置中心对于规则的热刷新
封装NacosDataSource和ApolloDataSource,支持Nacos和Apollo两个远程配置中心,零代码实现Sentinel功能。更多的远程配置中心,请参照Sentinel官方的DataSource并自行集成,参考discovery-plugin-strategy-sentinel-starter-nacos下2个类和spring.factories
支持原生的流控规则、降级规则、授权规则、系统规则、热点参数流控规则
支持扩展LimitApp的机制,通过动态的Http Header方式实现组合式防护机制,包括基于服务名、基于灰度组、基于灰度版本、基于灰度区域、基于机器地址和端口等防护机制,支持自定义任意的业务参数组合实现该功能,例如,根据传入的微服务灰度版本号+用户名,组合在一起进行熔断
支持微服务侧Actuator、Swagger和Rest三种方式的规则写入
支持控制台侧基于微服务名的Actuator、Swagger和Rest三种方式的批量规则写入
支持下面开关关闭上述功能
spring.application.strategy.sentinel.enabled=true
增加Sentinel和Hystrix的Banner输出
网关端更新:
去除GatewayStrategyFilter,合并到AbstractGatewayStrategyRouteFilter,此改动修复了Finchley版灰度路由时的上下文丢失的重大Bug
AbstractGatewayStrategyRouteFilter和AbstractZuulStrategyRouteFilter,增加extendFilter的方法,可以被业务层覆盖,可减少一层Filter
增加GatewayStrategyClearFilter,用以清除GatewayStrategyContext的ThreadLocal对象
去除多余的配置
spring.application.strategy.gateway.route.filter.enabled=truespring.application.strategy.zuul.route.filter.enabled=true
负载均衡更新:
增加微服务侧和网关侧,负载均衡下,消费端尝试获取对应提供端初始服务实例列表为空的时候,进行重试的功能,参考下列配置:
负载均衡下,消费端尝试获取对应提供端初始服务实例列表为空的时候,进行重试。缺失则默认为false# spring.application.no.servers.retry.enabled=false# 负载均衡下,消费端尝试获取对应提供端初始服务实例列表为空的时候,进行重试的次数。缺失则默认为5# spring.application.no.servers.retry.times=5# 负载均衡下,消费端尝试获取对应提供端初始服务实例列表为空的时候,进行重试的时间间隔。缺失则默认为2000# spring.application.no.servers.retry.await.time=2000# 负载均衡下,消费端尝试获取对应提供端服务实例列表为空的时候,通过日志方式通知。缺失则默认为false# spring.application.no.servers.notify.enabled=false
配置更新:
增加Nacos properties获取方式,整合Sentinel NacosDataSource和灰度配置,两个配置实现共享
增强Apllo namespace获取方式,整合Sentinel ApolloDataSource和灰度配置,先从apollo.bootstrap.namespaces方式获取,如果不存在则通过apollo.plugin.namespace获取,如果不存在,默认赋予application值
外部元数据设置方式从-Dext.abc变更为-Dmetadata.abc,更易理解
外部接口更新:
- 增加微服务侧和控制台侧灰度版本动态修改的权限控制
测试更新:
去除自动化测试中的配置,因为基于Group推送规则到服务无法和推送到远程配置中心兼容,新版本中只保留基于后者的自动化测试方式
测试用例的配置内容推送到远程配置中心,还是到服务。缺失则默认为truespring.application.test.configcenter.enabled=true
功能更新:
- 优化灰度发布本地规则文件的读取逻辑
示例更新:
极简示例的由DiscoveryGray更名为DiscoveryGuide,请访问https://github.com/Nepxion/DiscoveryGuide
优化文档和示例
感谢:
- 感谢@WeihuaWang同学贡献Sentinel相关代码
源码主页
https://github.com/Nepxion/Discovery
指南主页
https://github.com/Nepxion/DiscoveryGuide
文档主页
https://pan.baidu.com/s/1i57rXaNKPuhGRqZ2MONZOA
其它版本
同时发布的版本,还包括:
Nepxion Discovery 4.12.0,支持Finchley版
Nepxion Discovery 3.12.0,支持Edgware版
请联系我
微信、公众号和文档
本文分享自微信公众号 - Nepxion开源社区(iMicroService)。
如有侵权,请联系 support@oschina.cn 删除。
本文参与“OSC源创计划”,欢迎正在阅读的你也加入,一起分享。