雲計算

雲效流水線基於標籤功能實現阿里雲ECS多環境發佈

在軟件開發和部署過程中,我們的軟件往往需要在不同的運行環境中運行,例如:開發人員本地開發環境、測試團隊的測試環境、還有類生產環境和生產環境。在整個研發流程的過程中,針對開發和運維,前者面向需求和代碼,後者面向資源和環境,而部署,是兩者都會關注的部分。通過本文,你可以瞭解到,如何通過雲效流水線有效拉通開發與運維,打破二者之間的壁壘牆,讓開發與運維高效聯動。
圖片 1.png
如果你對雲效流水線功能實踐想有一個更詳細的瞭解,請參考下面這篇文章:[通過雲效流水線實現Java應用構建並部署ECS]
https://thoughts.aliyun.com/sharespace/5e8c387c0aa435001a74f7ab/docs/5f19008b6fd3fa0023fdcef4
一、用戶訴求

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

二、雲效解決方案

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

三、雲效操作實踐

接下來以一個 Java Spring Boot 的代碼庫為例,講解如何通過雲效流水線進行阿里雲 ECS 的多環境發佈。

前置條件
1、 運維人員已購買相應阿里雲ECS資源,並配置好相應環境,如本文案例中需要的JDK環境。購買ECS參考鏈接:https://ecs-buy.aliyun.com/
2、 運維人員,根據需要,對相應ECS資源進行標籤配置。標籤是雲資源的標識,可以幫助您從不同維度對具有相同特徵的雲資源進行分類、搜索和聚合,讓資源管理變得更加輕鬆。本文中ECS資源及標籤設置如圖所示:
標籤鍵: environment 標籤值:dev、sit、product
3.png

創建流水線
1、 進入雲效流水線(https://flow.aliyun.com/my?channel=yy_rccb )。
116C8E17-9500-4DCD-9EFD-7C696EC12360.png

2、點擊右上角【新建流水線】,進入流水線創建嚮導頁面。
5.png

3、選擇圖中標識模板,並點擊創建
6.png

配置代碼庫

  1. 創建流水線之後會自動彈出添加代碼源的窗口,這裡選擇Flow提供的示例代碼源,並進行添加
    7.png

配置構建上傳任務

  1. 修改一下”Java構建上傳“的任務,增加一個打包路徑,填入deploy.sh。這個文件存在於代碼庫中,其中包含了在ECS上進行應用啟動的腳本,為了進行後續的主機部署,需要將這個文件也打入到壓縮包中,在後續的主機部署任務中可以看到如何使用該deploy.sh。在該配置中指定了target/和deploy.sh兩個路徑,所以Flow會將這兩個文件(夾)打包成為一個壓縮包,並進行歸檔,在Flow中我們稱之為製品,該製品也會在後續的主機部署任務中用到。
    8.png

配置部署任務

  1. 接下來配置主機部署任務,在製品下拉框中選擇”製品名稱.default”,也就是前面的”Java構建上傳“步驟歸檔的那個製品。為了配置主機組,需要先創建一個,點擊”新建主機組”。
    9.png

  2. 選擇”阿里雲ECS“,點擊”新建服務授權”,跳轉到阿里雲,完成RAM授權,然後會自動跳回到Flow。
    10.png

11.png

  1. 此時再選擇標籤方式添加,依次選擇地區、ECS標籤鍵、ECS標籤值,點擊下一步。
    12.png

  2. 在新彈出的頁面中輸入主機組名稱及主機組環境,點擊保存即可。
    13.png

  3. 接下來進行部署腳本的配置:
    • 下載路徑:表示希望把”構建上傳”任務中的壓縮包下載到機器上的什麼位置,在本例的值為:/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
    14.png

  4. 部署策略配置
    • 暫停方式:希望一個主機組中的機器以什麼樣的暫停方式進行,比如第一批暫停,每批暫停,或者不暫停。推薦使用第一批暫停,在發佈完第一批之後,對線上服務進行觀察,如果沒有異常,則可以繼續其餘批的發佈
    • 分批數量:希望主機組中的機器分為幾批進行發佈。比如一共4臺機器,分兩批,則每批同時發佈2臺機器。
    本文中配置如下所示:
    15.png

  5. 部署結果查看
    • 點擊右上角保存並執行按鈕
    16.png

• 待執行完畢後,點擊部署詳情按鈕查看部署明細。
17.png

18.png

• 通過IP:8080訪問驗證,如下圖所示:
19.png

資源變更場景

  1. 因業務需要,需在開發環境中增加一臺機器,運維同學只需在ECS側準備相應資源,打上相應環境標籤即可,如下圖所示。
    20.png

  2. 運維同學配置完畢後,開發同學不需做任何變更,直接運行相應環境流水線即可。流水線運行過程中,因為我們之前設置的分批,第一批暫停的發佈策略,因此流水線會暫停,出現如下狀態
    21.png

  3. 此時點擊部署詳情按鈕,進入部署詳情頁面,確認沒有問題後,點擊繼續按鈕,如下圖所示
    22.png

23.png


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

Leave a Reply

Your email address will not be published. Required fields are marked *