作者:蘇宇(流士)
我們業務常見的配置問題
通常業務代碼中包含許多的配置項,這些配置項用于控制各種各樣的業務邏輯,例如一個 bool 型別的變數控制某個功能是否開啟,一個 list 控制訪問白名單或黑名單,一個 String 控制提示資訊,但是在常規的微服務架構應用的配置程序中,會碰到以下的配置問題與挑戰,

針對上述問題,開發者通常希望可以動態、實時地去查看和修改配置項,并且期望不需要撰寫額外的代碼來管理,此時就可以利用 AHAS 功能開關來實時修改和查看對應的配置項,與傳統的配置中心不同,開發者使用 AHAS 功能開關時,無需關注配置項的決議邏輯,只需宣告對應的變數,加上 AHAS 功能開關的注解即可在功能開關控制臺對配置進行動態管理,
什么是 AHAS 功能開關?
AHAS 功能開關是一個輕量級的動態配置框架,通過功能開關可以動態管理代碼中的配置項,根據需求為某個應用開啟或關閉部分功能,或設定某個性能指標的閾值,功能開關通常用于設定黑白名單、運行時動態調整日志級別、降級業務功能等場景,
利用 AHAS 功能開關,可以幫助企業構建完善的線上運維手段,作為流量防護等常規運維手段的有力補充,功能開關可針對特定業務場景實作定向止損,及時保障應用系統穩定性;對不同業務場景下的配置項具體內容可靈活變更,隨時調整;AHAS 功能開關可將原生 Spring 配置項自動轉化為功能開關項,真正做到零改造,
AHAS 功能開關實作邏輯
通過 AHAS 控制臺管理和推送配置項,應用重啟或擴容階段可讀取持久化配置,

市場中現有的配置管理服務在某些配置管理核心環節存在嚴重不足,具體現象可簡述如下:
? 靈活性差
現有配置管理服務多基于檔案方式或需手動設定配置項方能生效,程序較為復雜,且容易出錯;AHAS 功能開關可自動支持原生 Spring 配置項,極大解放業務人員生產力,
? 配置型別缺少校驗
現有配置管理服務在推送階段大多未實作型別校驗,可能導致嚴重線上故障,引發資損;AHAS 功能開關對配置型別進行強校驗,把問題暴露在控制臺層面,避免由于人員操作失誤引發的問題,
? 持久化資料丟失
現有配置管理服務多基于本地檔案或資料庫進行持久化,SLO 難以保障;AHAS 功能開關依托于集團持久化產品保障開關持久化的可靠性,
? 侵入性強
現有配置管理服務對代碼侵入性較強,引入使用需做大量改造,耗費較多精力;AHAS 功能開關提供 Agent 接入方式,對應用完全無侵入,對某些需自定義開關場景可按需引入 SDK,
和業界常見產品的差別是什么?
對 switch 社區版及國內外使用較為廣泛的開關配置產品,從配置在微服務運維的各個階段及維度展開進行比較,AHAS 在應用接入的成本、配置推送的可操作性以及配置持久化方面都有較大的優勢:
? 應用接入
應用通過 Agent 方式接入 AHAS,連接功能開關服務,無需對應用做任何改造,真正做到無侵入,
? 配置推送
通過 AHAS 控制臺即可對應用的配置項進行管理,按需推送配置項,支持按節點推送與全域推送方式,
? 配置持久化
通過 ACM 組件持久化配置項,保障配置項高可靠性,應用在重啟或擴容階段可讀取持久化配置,
詳細內容見下表:

除此之外,AHAS 功能開關相較于其他競品還具備如下差異化優勢:
? 強型別校驗
用戶無需在業務層面對接收到的配置進行型別及格式的校驗,校驗作業由平臺承擔,應用僅需關注業務,
? 無侵入式接入
對 SpringCloud 應用支持一鍵接入,自動識別應用中配置項,可通過控制臺實時修改并進行持久化等操作,
? 復雜配置項支持
在復雜資料型別支持方面較為完善,無需遵守較為繁瑣的配置項規則,
? 開箱即用功能
支持日志級別動態調整,獲取不同級別日志,方便問題分析、故障定位,
業務中開關配置常見的應用場景有哪些?
動態調整日志級別
在開發 Java 程式時,我們經常會用到各種各樣的日志框架,為了避免在程式正常運行時輸出不必要的資訊,可以針對性地動態調整日志級別,以便輸出更多的日志資訊排查線上問題,或是減少日志列印帶來的性能消耗,功能開關提供了在應用運行時動態修改日志級別的功能,在不同的應用場景下,您可以隨時調整日志的級別,得到更有效的日志資訊,(注:支持的日志框架:Log4j、Log4j2、Logback,)
配置項組合更新
在實際的業務運行場景下,可按不同場景批量更新組合配置項,所謂組合配置項指具有一組相互關聯業務語意的配置項,如頁面公告中時間、標題、內容等,商品特殊優惠配置中價格、優惠折扣等,
下圖以'商品優惠配置'為例進行說明,'商品優惠配置'在不同場景下優惠物件、優惠折扣及價格等各不相同,將'商品優惠配置'涉及的配置項組合,在不同場景下設定不同內容,可在不同場景下快速切換,同時省去繁瑣校驗程序,避免出錯,

開關驅動開發
以開關方式控制代碼執行邏輯,用于新功能快速驗證,在出現問題時可及時回退,相比復雜的系統發布,投入成本較低,可結合 DevOps 機制進行實踐,
如下圖所示,當執行邏輯觸發時訪問對應的開關配置查看配置是否打開,從而決定是否執行新功能,可用于 A/B 測驗、環境隔離等場景,

金絲雀(灰度)發布
確保應用發布的可觀測,可灰度,可回滾,使用金絲雀發布進行小流量驗證,驗證通過后再全量升級,實時查看流量的分配情況,

怎么配置 AHAS 開關?
步驟一 :環境準備
? 功能開關 Agent 方式接入,與流量防護共用 Agent,
配置-Dahas.switch.agent.plugin.group.enabled=true
? 應用配置 SDK 方式接入,參考使用 SDK 接入[1]
? 應用配置 Spring Boot Starter 方式接入,參考使用 Spring Boot Starter 接入[2]
步驟二:配置操作
以開箱即用功能日志動態修改為例,
進入目標應用的開關串列頁面,在開關串列頁面搜索到 SYSTEM_LOG_CONFIG 開關,即日志級別開關,

推送值格式:Key 為 LoggerName,Value 為日志級別,如需修改全域日志級別,LoggerName 為 root,如下所示,
{
"root": "ERROR"
}
步驟三:配置效果
修改后即可生效,具體效果如下,

相關鏈接
[1] 使用 SDK 接入
https://help.aliyun.com/document_detail/156225.html
[2] 使用 Spring Boot Starter 接入
https://help.aliyun.com/document_detail/155940.html
歡迎掃碼進群聯系我們:

發布云原生技術最新資訊、匯集云原生技術最全內容,定期舉辦云原生活動、直播,阿里產品及用戶最佳實踐發布,與你并肩探索云原生技術點滴,分享你需要的云原生內容,
關注【阿里巴巴云原生】公眾號,獲取更多云原生實時資訊!
轉載請註明出處,本文鏈接:https://www.uj5u.com/qita/458525.html
標籤:其他
