1. 程式人生 > >【微服務從入門到精通】:(一)微服務的藍綠發布及灰度發布

【微服務從入門到精通】:(一)微服務的藍綠發布及灰度發布

采樣 前端 入門 後端 blog 文件 風險 性能 切換

藍綠部署

基本上,藍綠部署是一種以可預測的方式發布應用的技術,目的是減少發布過程中服務停止的時間。

簡單來說,你需要準備兩個相同的環境(基礎架構),在藍色環境運行當前生產環境中的應用,也就是舊版本應用,如圖中 App1 version1 、 App2 version1 、 App3 version3 。

技術分享圖片

當你想要升級 App2 到 version2 ,在藍色環境中進行操作,即部署新版本應用,並進行測試。如果測試沒問題,就可以把負載均衡器/反向代理/路由指向藍色環境了。

技術分享圖片

隨後你需要監測新版本應用,也就是 App2 version2 是否有故障和異常。如果運行良好,就可以刪除 App2 version1 使用的資源。如果運行出現了問題,你可以通過負載均衡器指向快速回滾到綠色環境。

理論上聽起來很棒,但還是要註意一些細節:

  • 當你切換到藍色環境時,需要妥當處理未完成的業務和新的業務。如果你的數據庫後端無法處理,會是一個比較麻煩的問題;

  • 有可能會出現需要同時處理“微服務架構應用”和“傳統架構應用”的情況,如果在藍綠部署中協調不好這兩者,還是有可能導致服務停止的;

  • 需要提前考慮數據庫與應用部署同步遷移 /回滾的問題;

  • 藍綠部署需要有基礎設施支持

  • 在非隔離基礎架構( VM 、 Docker 等)上執行藍綠部署,藍色環境和綠色環境有被摧毀的風險

A/B Testing

A/B 測試跟藍綠部署完全是兩碼事。

A/B 測試是用來測試應用功能表現的方法,例如可用性、受歡迎程度、可見性等等。 A/B 測試通常用在應用的前端上,不過當然需要後端來支持。

技術分享圖片

A/B 測試與藍綠部署的區別在於, A/B 測試目的在於通過科學的實驗設計、采樣樣本代表性、流量分割與小流量測試等方式來獲得具有代表性的實驗結論,並確信該結論在推廣到全部流量可信;藍綠部署的目的是安全穩定地發布新版本應用,並在必要時回滾。

A/B 測試和藍綠部署可以同時使用。

灰度發布/金絲雀發布

灰度發布是在原有版本可用的情況下,同時部署一個新版本應用作為“金絲雀”(金絲雀對瓦斯極敏感,礦井工人攜帶金絲雀,以便及時發發現危險),測試新版本的性能和表現,以保障整體系統穩定的情況下,盡早發現、調整問題。

技術分享圖片

灰度發布/金絲雀發布由以下幾個步驟組成:

  • 準備好部署各個階段的工件,包括:構建工件,測試腳本,配置文件和部署清單文件。
  • 從負載均衡列表中移除掉“金絲雀”服務器。
  • 升級“金絲雀”應用(排掉原有流量並進行部署)。
  • 對應用進行自動化測試。
  • 將“金絲雀”服務器重新添加到負載均衡列表中(連通性和健康檢查)。
  • 如果“金絲雀”在線使用測試成功,升級剩余的其他服務器。(否則就回滾)

總結

對於雲計算來說,以上三種策略都是可用的。不難想象,通過 docker 和 kubernetes ,我們可以很簡單的實現藍綠部署、 A/B 測試、灰度發布……,深度整合 Docker 和 Kubernetes ,提供給用戶包括代碼滾動上線、一鍵代碼回滾等功能和特性在內的強大的 CI/CD 體驗:)

註:本文非原創。參考互聯網博文,好文分享給大家

【微服務從入門到精通】:(一)微服務的藍綠發布及灰度發布