1. 程式人生 > 其它 >雲效Flow如何實現阿里雲ECS多環境釋出

雲效Flow如何實現阿里雲ECS多環境釋出

一、背景

雲效Flow基於標籤功能實現阿里雲ECS多環境釋出,在軟體開發和部署過程中,我們的軟體往往需要在不同的執行環境中執行,例如:開發人員本地開發環境、測試團隊的測試環境、還有類生產環境和生產環境。在整個研發流程的過程中,針對開發和運維,前者面向需求和程式碼,後者面向資源和環境,而部署,是兩者都會關注的部分。通過本文,你可以瞭解到,如何通過雲效流水線有效拉通開發與運維,打破二者之間的壁壘牆,讓開發與運維高效聯動。

二、使用者訴求

一般來說,使用者使用主機部署訴求如下: 1、開發人員不需要關注資源變更,只需要按需選擇環境進行部署即可。 2、開發人員能夠根據制定好的釋出策略,自主釋出,不需要手工配置和干預。
3、運維人員不需關注研發平臺,只需做好資源的規劃管理即可。 該場景下主要會涉及開發人員跟運維人員兩個角色,下面文章中我們主要會這兩個角色角度進行講解。

三、雲效解決方案

結合雲效交付流水線釋出策略及ECS的標籤功能,為ECS的多環境釋出提供了很好的基礎保障,如圖:

四、雲效操作實踐

前置條件

接下來以一個 Java Spring Boot 的程式碼庫為例,講解如何通過雲效流水線進行阿里雲 ECS 的多環境釋出。 1、運維人員已購買相應阿里雲ECS資源,並配置好相應環境,如本文案例中需要的JDK環境。 2、運維人員,根據需要,對相應ECS資源進行標籤配置。標籤是雲資源的標識,可以幫助您從不同維度對具有相同特徵的雲資源進行分類、搜尋和聚合,讓資源管理變得更加輕鬆。本文中ECS資源及標籤設定如圖所示:
標籤鍵: environment 標籤值:dev、sit、product

建立流水線

1、進入雲效流水線,點選右上角【新建流水線】,進入流水線建立嚮導頁面。
說明 立即體驗:雲效流水線Flow
2、選擇圖中標識模板,並點選建立 配置程式碼庫 1. 建立流水線之後會自動彈出新增程式碼源的視窗,這裡選擇Flow提供的示例程式碼源,並進行新增 配置構建上傳任務 修改一下”Java構建上傳“的任務,增加一個打包路徑,填入deploy.sh。這個檔案存在於程式碼庫中,其中包含了在ECS上進行應用啟動的指令碼,為了進行後續的主機部署,需要將這個檔案也打入到壓縮包中,在後續的主機部署任務中可以看到如何使用該deploy.sh。在該配置中指定了target/和deploy.sh兩個路徑,所以Flow會將這兩個檔案(夾)打包成為一個壓縮包,並進行歸檔,在Flow中我們稱之為製品,該製品也會在後續的主機部署任務中用到。
配置部署任務 1、接下來配置主機部署任務,在製品下拉框中選擇”製品名稱.default”,也就是前面的”Java構建上傳“步驟歸檔的那個製品。為了配置主機組,需要先建立一個,點選”新建主機組”。 2、選擇”阿里雲ECS“,點選”新建服務授權”,跳轉到阿里雲,完成RAM授權,然後會自動跳回到Flow。 3、此時再選擇標籤方式新增,依次選擇地區、ECS標籤鍵、ECS標籤值,點選下一步。 4、在新彈出的頁面中輸入主機組名稱及主機組環境,點選儲存即可。 5、接下來進行部署指令碼的配置: · 下載路徑:表示希望把”構建上傳”任務中的壓縮包下載到機器上的什麼位置,在本例的值為:/home/admin/app/package.tgz · 執行使用者:希望以是哪個使用者的身份進行指令碼執行,本例的值為:root · 部署指令碼:在機器上執行指令碼的具體內容,本例的值為: mkdir -p/home/admin/application/tar zxvf /home/admin/app/package.tgz -C/home/admin/application/sh /home/admin/application/deploy.sh restart 6、部署策略配置 · 暫停方式:希望一個主機組中的機器以什麼樣的暫停方式進行,比如第一批暫停,每批暫停,或者不暫停。推薦使用第一批暫停,在釋出完第一批之後,對線上服務進行觀察,如果沒有異常,則可以繼續其餘批的釋出 · 分批數量:希望主機組中的機器分為幾批進行釋出。比如一共4臺機器,分兩批,則每批同時釋出2臺機器。 本文中配置如下所示: 7、部署結果檢視 · 點選右上角儲存並執行按鈕 · 待執行完畢後,點選部署詳情按鈕檢視部署明細。 · 通過IP:8080訪問驗證,如下圖所示:

資源變更場景

1. 因業務需要,需在開發環境中增加一臺機器,運維同學只需在ECS側準備相應資源,打上相應環境標籤即可,如下圖所示。 2. 運維同學配置完畢後,開發同學不需做任何變更,直接執行相應環境流水線即可。流水線執行過程中,因為我們之前設定的分批,第一批暫停的釋出策略,因此流水線會暫停,出現如下狀態 3. 此時點選部署詳情按鈕,進入部署詳情頁面,確認沒有問題後,點選繼續按鈕,如下圖所示

五、結語

雲效Flow基於標籤功能實現阿里雲ECS多環境釋出,在軟體開發和部署過程中,我們的軟體往往需要在不同的執行環境中執行,通過以上的操作流程,我們可以通過雲效流水線,利用標籤功能,拉通開發與運維,同時,讓開發和運維關注點分離,專注於核心的工作內容,實現ECS的多環境部署。 歡迎體驗、試用雲原生時代新DevOps平臺阿里云云效