如何帮助业务丝滑配置?阿里巴巴用了 11 年的“功能开关” 是什么?

本文涉及的产品
性能测试 PTS,5000VUM额度
注册配置 MSE Nacos/ZooKeeper,118元/月
任务调度 XXL-JOB 版免费试用,400 元额度,开发版规格
简介: AHAS 功能开关是一个轻量级的动态配置框架,通过功能开关可以动态管理代码中的配置项,根据需求为某个应用开启或关闭部分功能,或设置某个性能指标的阈值。功能开关通常用于设置黑白名单、运行时动态调整日志级别、降级业务功能等场景。

作者:苏宇(流士)


我们业务常见的配置问题


通常业务代码中包含许多的配置项,这些配置项用于控制各种各样的业务逻辑,例如一个 bool 类型的变量控制某个功能是否开启,一个 list 控制访问白名单或黑名单,一个 String 控制提示信息。但是在常规的微服务架构应用的配置过程中,会碰到以下的配置问题与挑战。


image.jpeg


针对上述问题,开发者通常希望可以动态、实时地去查看和修改配置项,并且期望不需要编写额外的代码来管理,此时就可以利用 AHAS 功能开关来实时修改和查看对应的配置项。与传统的配置中心不同,开发者使用 AHAS 功能开关时,无需关注配置项的解析逻辑,只需声明对应的变量,加上 AHAS 功能开关的注解即可在功能开关控制台对配置进行动态管理。


什么是 AHAS 功能开关?


AHAS 功能开关是一个轻量级的动态配置框架,通过功能开关可以动态管理代码中的配置项,根据需求为某个应用开启或关闭部分功能,或设置某个性能指标的阈值。功能开关通常用于设置黑白名单、运行时动态调整日志级别、降级业务功能等场景。


利用 AHAS 功能开关,可以帮助企业构建完善的线上运维手段,作为流量防护等常规运维手段的有力补充,功能开关可针对特定业务场景实现定向止损,及时保障应用系统稳定性;对不同业务场景下的配置项具体内容可灵活变更,随时调整;AHAS 功能开关可将原生 Spring 配置项自动转化为功能开关项,真正做到零改造。


AHAS 功能开关实现逻辑


通过 AHAS 控制台管理和推送配置项,应用重启或扩容阶段可读取持久化配置。


640 - 2022-04-16T180830.939.png


市场中现有的配置管理服务在某些配置管理核心环节存在严重不足,具体现象可简述如下:


  • 灵活性差

现有配置管理服务多基于文件方式或需手动设置配置项方能生效,过程较为复杂,且容易出错;AHAS 功能开关可自动支持原生 Spring 配置项,极大解放业务人员生产力。


  • 配置类型缺少校验

现有配置管理服务在推送阶段大多未实现类型校验,可能导致严重线上故障,引发资损;AHAS 功能开关对配置类型进行强校验,把问题暴露在控制台层面,避免由于人员操作失误引发的问题。


  • 持久化数据丢失

现有配置管理服务多基于本地文件或数据库进行持久化,SLO 难以保障;AHAS 功能开关依托于集团持久化产品保障开关持久化的可靠性。


  • 侵入性强

现有配置管理服务对代码侵入性较强,引入使用需做大量改造,耗费较多精力;AHAS 功能开关提供 Agent 接入方式,对应用完全无侵入,对某些需自定义开关场景可按需引入 SDK。


和业界常见产品的差别是什么?


对 switch 社区版及国内外使用较为广泛的开关配置产品,从配置在微服务运维的各个阶段及维度展开进行比较。AHAS 在应用接入的成本、配置推送的可操作性以及配置持久化方面都有较大的优势:


  • 应用接入

应用通过 Agent 方式接入 AHAS,连接功能开关服务,无需对应用做任何改造,真正做到无侵入。


  • 配置推送

通过 AHAS 控制台即可对应用的配置项进行管理,按需推送配置项,支持按节点推送与全局推送方式。


  • 配置持久化

通过 ACM 组件持久化配置项,保障配置项高可靠性。应用在重启或扩容阶段可读取持久化配置。


详细内容见下表:

640 - 2022-04-16T180940.476.png


除此之外,AHAS 功能开关相较于其他竞品还具备如下差异化优势:


  • 强类型校验

用户无需在业务层面对接收到的配置进行类型及格式的校验,校验工作由平台承担,应用仅需关注业务。


  • 无侵入式接入

对 SpringCloud 应用支持一键接入,自动识别应用中配置项,可通过控制台实时修改并进行持久化等操作。


  • 复杂配置项支持

在复杂数据类型支持方面较为完善,无需遵守较为繁琐的配置项规则。


  • 开箱即用功能

支持日志级别动态调整,获取不同级别日志,方便问题分析、故障定位。


业务中开关配置常见的应用场景有哪些?


动态调整日志级别


在开发 Java 程序时,我们经常会用到各种各样的日志框架。为了避免在程序正常运行时输出不必要的信息,可以针对性地动态调整日志级别,以便输出更多的日志信息排查线上问题,或是减少日志打印带来的性能消耗。功能开关提供了在应用运行时动态修改日志级别的功能,在不同的应用场景下,您可以随时调整日志的级别,得到更有效的日志信息。(注:支持的日志框架:Log4j、Log4j2、Logback。


配置项组合更新


在实际的业务运行场景下,可按不同场景批量更新组合配置项。所谓组合配置项指具有一组相互关联业务语义的配置项,如页面公告中时间、标题、内容等,商品特殊优惠配置中价格、优惠折扣等。


下图以'商品优惠配置'为例进行说明。'商品优惠配置'在不同场景下优惠对象、优惠折扣及价格等各不相同,将'商品优惠配置'涉及的配置项组合,在不同场景下设置不同内容,可在不同场景下快速切换,同时省去繁琐校验过程,避免出错。


640 - 2022-04-16T181132.131.png


开关驱动开发


以开关方式控制代码执行逻辑,用于新功能快速验证,在出现问题时可及时回退。相比复杂的系统发布,投入成本较低,可结合 DevOps 机制进行实践。


如下图所示,当执行逻辑触发时访问对应的开关配置查看配置是否打开,从而决定是否执行新功能。可用于 A/B 测试、环境隔离等场景。



640 - 2022-04-16T181431.970.png


金丝雀(灰度)发布


确保应用发布的可观测,可灰度,可回滚,使用金丝雀发布进行小流量验证,验证通过后再全量升级,实时查看流量的分配情况。


image.gif640 - 2022-04-16T181516.446.png


怎么配置 AHAS 开关?


步骤一 :环境准备


  • 功能开关 Agent 方式接入,与流量防护共用 Agent,

配置-Dahas.switch.agent.plugin.group.enabled=true


  • 应用配置 SDK 方式接入,参考使用 SDK 接入[1]
  • 应用配置 Spring Boot Starter 方式接入,参考使用 Spring Boot Starter 接入[2]


步骤二:配置操作
以开箱即用功能日志动态修改为例。
进入目标应用的开关列表页面。在开关列表页面搜索到 SYSTEM_LOG_CONFIG 开关,即日志级别开关。


640 - 2022-04-16T181613.508.png


推送值格式:KeyLoggerNameValue 为日志级别。如需修改全局日志级别,LoggerNameroot,如下所示。


{
 "root": "ERROR"
}


步骤三:配置效果
修改后即可生效,具体效果如下。


640 - 2022-04-16T181723.532.png


相关链接


[1] 使用 SDK 接入

https://help.aliyun.com/document_detail/156225.html


[2] 使用 Spring Boot Starter 接入

https://help.aliyun.com/document_detail/155940.html


欢迎扫码进群联系我们:


640 - 2022-04-16T181810.534.png


相关文章
|
25天前
|
存储 小程序 搜索推荐
打造无缝社交体验:多平台适配,开启线上线下陪玩系统小程序社交新时代
通过实施以上策略和行动计划,可以打造出一个无缝社交体验的多平台陪玩社交系统,为用户提供更加便捷、高效、有趣的社交体验,开启线上线下陪玩系统源码社交的新时代。
53 11
|
6月前
|
设计模式 安全 Java
老房改造系列--如何用一套流程接入所有业务线
ToB业务没有太多高并发的挑战,但同一套流程往往可能需要承载各种差异化的复杂业务需求,所以如何让系统具备良好的扩展性成为ToB业务系统最大的挑战。本文将详细讲述如何用一套流程接入所有业务线?
|
3月前
|
监控 测试技术 开发工具
小游戏对接广告联盟流量变现项目系统/开发模式规则
小游戏对接广告联盟流量变现项目系统开发是一个多步骤的过程,包括需求分析、选择广告联盟、SDK集成与接入、广告位设置与管理、流量变现系统开发、数据埋点与监控及测试与优化。通过这一系列步骤,确保广告能够有效展示并实现变现。
|
6月前
|
测试技术
锁屏组件新能力实现问题之多业务同时注册锁屏组件的管理展示如何解决
锁屏组件新能力实现问题之多业务同时注册锁屏组件的管理展示如何解决
41 0
|
9月前
|
设计模式 安全 Java
老系统重构系列--如何用一套流程接入所有业务线
**摘要:** 本文介绍了老系统改造的过程,作者提出,ToB业务的挑战在于需要支持多种差异化的业务需求,而模板模式在处理这种需求时可能会导致继承关系复杂和粒度过粗。为了解决这些问题,文章提出了以下步骤: 1. **梳理流程差异点**:识别不同业务流程的差异,以便确定扩展点。 2. **领域模型梳理**:区分核心域和支撑域,确保核心域的稳定性。 3. **二次抽象隔离层**:创建隔离层,避免核心域因新业务接入而变得不稳定。 4. **基于SPI的扩展体系建设**:选择了COLA-SPI实现扩展点,允许业务域定义接口并实现差异化的流程逻辑。
203 0
|
9月前
|
搜索推荐 小程序 定位技术
【社区每周】AMPE新增车机卡片联动功能;支持个性化场景推荐(2022年6月第四期)
【社区每周】AMPE新增车机卡片联动功能;支持个性化场景推荐(2022年6月第四期)
117 0
|
监控 BI 定位技术
直播程序源码开发建设:洞察全局,数据统计与分析功能
数据统计与分析功能不管是对直播程序源码平台的主播或运营者都会有极大的帮助,是了解观众需求、优化用户体验成为直播平台发展的关键功能,这也是开发搭建直播程序源码平台的必备功能之一。
直播程序源码开发建设:洞察全局,数据统计与分析功能
|
移动开发 前端开发 IDE
手淘双11最新实践:PopLayer弹层领域研发模式升级
近年来,各大APP内的弹层需求逐渐增多,以手机淘宝为例,日常的弹层上线频率为单端每月50次左右,而在大促期间可以达到240次以上。在手淘内,各类弹层业务都会通过PopLayer中间件的能力进行投放。但业务往往会遇到开发弹层难、慢、稳定性差的种种困难。对比于往年业务研发成本较高的现状,PopLayer在今年提出了【低研发搭投模式】来解决这类问题,形成一套快速搭建+可视化+多端多场景通用的解决方案,在日常与大促期间得到了广泛应用:
|
存储 Prometheus 监控
重磅!DIY的Prometheus主备方案,全网唯一。生产未上,测试先行。
重磅!DIY的Prometheus主备方案,全网唯一。生产未上,测试先行。
340 0