上一文中講述了如何在AWS下搭建OpenShift集群。這篇文章將目光轉向如何在OpenShift中實現CI/CD以及產品環境的部署。
持續交付
如果要打造一個持續交付的流水線,首先要考慮多環境的問題。一般一個應用程序會有多個環境,比如開發環境、集成測試環境、系統測試環境、用戶驗收測試環境、類生產環境、生產環境。如何在OpenShift中隔離並建立對這些環境的部署流程有多種方案可以選擇。
- 同一個project中使用label和唯一名稱來區分不同的環境;
- 集群中的不同project來隔離環境;
- 跨集群來隔離環境。
我們以第二種方式為例,演示下多環境管理問題。
在上圖中,我們有一個build project。build project包含了一組相互依賴性比較強的應用,每個應用對應一個build config,產生的Image Stream存放在image register中。而每個環境各對應一個project,其中包含了該應用的deployment config,其鏡像輸入是build config產生的Image Stream。之所以這樣做,有以下幾點考慮:
不同的環境分布在不同的project中,可以很好的借助project的特性進行環境隔離。比如sys project的容器只能部署在label為sys的node上,prod project的容器只能部署在label為prod的node上。
不同的project可以分別定義權限訪問和控制。比如只有QA才能操作sys project中的資源,運維工程師才能操作prod project中的資源。
不同的環境共用一個Image Stream,保證了應用程序鏡像在不同環境中的是完全一致的,防止由於測試環境和生產環境不一致而引入缺陷。
那么大家共用同一個Image Stream,如何實現應用的promotion那?解決方案就是使用tag。
如上圖所示,一個image stream里面有多個版本的鏡像,而OpenShift可以為版本添加自定義tag。在不同的project里面,我們配置image的來源為”ImageStreamTag”,名稱為”applicationName:environmentName”。比如sys project的鏡像名為”App1:sys”,prod project的鏡像為”App1:prod”。如果想將version 3的鏡像推送到sys環境,只需要簡單的給version 3的鏡像打上sys的tag,這樣部署sys環境時就會自動使用version 3的鏡像。
1
|
|
如果在Deployment Config里面配置了自動監聽tag的變動的操作,那么一旦你修改了ImageStream的tag,就會自動觸發對應環境的部署。
由於應用程序鏡像在不同的環境中是一致的,那么變動的部分都被抽取到了外部配置中。如何根據不同的環境來加載對應的外部配置那?實現方式有很多種,這里介紹了使用Spring Cloud Config的方案。
首先我們將針對不同環境的配置放置在一個git倉中,然后通過Spring Cloud Config Server將其轉換為http服務。而我們在應用中嵌入Spring Cloud Config Client,其會接收一個環境變量來拉取指定環境的配置。而該環境變量可以通過Deployment Config來進行注入。
1
|
|
使用Spring Cloud Config給予了我們更多的靈活性。我們可以選擇在應用程序第一次啟動的時候拉取配置,也可以設置每隔一段時間自動更新配置,從而實現熱更新。
OpenShift雖然提供了構建和部署的能力,我們有時也需要使用Jenkins之類的工具來可視化以及編排整個流水線。
既然OpenShift是個容器化的管理平台,那么我們完全也可以將Jenkins作為一個應用納入到OpenShift中來托管,這樣Jenkins的Master和Slave都是容器化的。OpenShift官方提供了一個Jenkins2.0的鏡像,其預裝了OpenShift pipeline插件,可以很方便地進行構建、部署等操作。
生產環境的部署
OpenShift在產品環境的部署默認是rolling的方式。
每次部署時,它會啟動一個新的Replica Controller,部署一個pod,然后削減舊的Replica Controller的pod,如此往復,直到舊的Replica Controller中的所有pod都被銷毀,新的Replica Controller的所有pod都在線。整個過程保證了服務不宕機以及流量平滑切換,對用戶是無感知的。
而有的時候部署場景要負責些,比如我們想在產品環境對新版本做了充分的PVT(product version testing)才切換到新版本。那么就可以使用藍綠部署的方式。
藍綠部署方案的關鍵點在於一個Router對應兩個Service。而Route作為向外界暴露的服務端口是不變的,兩個Service分別對應我們的生產藍環境和生產綠環境。同時只有一個Service能接入Router對外服務,另一個Service用來進行PVT測試。切換可以簡單的修改Router的配置即可。
1 2 3 4 5 |
|
結語
OpenShift在應用的構建以及部署方面為我們提供了大量開箱即用的功能和解決方案,所以實現持續交付不再那么艱難。我們可以將更多的精力花費在提升應用程序質量以及架構方面,交付更好的產品。