概述
DevOps 理念被越來越多的企業采納,DevOps 是 Development 和 Operations 的組合詞,代表著重視「軟體開發人員(Dev)」和「IT 運維技術人員(Ops)」之間溝通合作的文化;旨在透過自動化「軟體交付」和「架構變更」的流程,使得構建、 測驗、發布軟體的程序能夠更加地快捷、頻繁和可靠,在云原生時代,我們更需要 Devops 思維來實作敏捷開發, 本文將介紹和實踐專為云原生打造的 TKE 容器 DevOps 服務,實作從代碼提交時觸發鏡像的自動構建,再到鏡像構建成功時觸發自動部署流程將應用部署、更新到 TKE 集群中的一整套無縫銜接的 Devops 流水線,
TKE 容器 DevOps 簡介
TKE 容器 DevOps 是 容器服務 TKE、容器鏡像服務 TCR 和 CODING DevOps 三個服務緊密結合,面向容器業務場景,具備自動化代碼編譯、容器鏡像構建、鏡像推送及應用部署等功能,為客戶提供強大的一站式云原生 DevOps 服務,容器 DevOps 快速入門請參考 TKE 和 Coding 協同業務實作快速迭代 最佳實踐檔案,
TKE 容器 DevOps 業務流程
TKE 容器 DevOps 服務貫穿了整個應用開發和部署流程的全生命周期管理,實作了從更新代碼到應用部署、更新的自動化,如下圖所示:

如何使用 TKE 容器 DevOps
操作場景
TKE 容器 Devops 功能提供了強大的云原生 Devops服務,下面將按照上述 TKE 容器 Devops 業務流程圖來實作從原始碼更新到業務發布的整套自動化流程,
前提條件
-
創建 TKE 測驗集群
關于如何創建可參考檔案 部署容器服務TKE,
-
開通 容器鏡像服務 TCR 服務
已創建可訪問的 TCR 測驗實體和生成測驗實體訪問憑證, TCR 需要開通企業標準版或高級版支持云原生交付作業流,詳情請參考 容器鏡像服務購買指南,目前 TCR 支持區域請參考 支持地域,
-
開通 CODING DevOps 服務
已創建和完善了 Coding Devops 團隊,如使用子賬號進行操作,請使用主賬號在 CODING DevOps 控制臺快速創建擁有權限的子用戶或參考 子用戶權限設定 提前為子賬號授予對應實體的操作權限,
操作步驟
TKE 容器 Devops 訪問入口
在 TKE 控制臺左側功能選單欄點擊【Devops】功能鏈接即可進入【容器 Devops】介紹界面,如下圖所示:

點擊 【立即使用】即可跳轉到所屬團隊的 Coding 主頁面使用相關 DevOps 功能,
配置代碼托管
在 Coding 團隊主頁面創建一個測驗專案和測驗代碼倉庫,關于 Coding 代碼托管介紹請參考 代碼托管介紹 ,創建步驟如下:
步驟 1:在 Coding 團隊主頁面【 專案】中創建測驗專案,如下圖所示:

步驟 2:點擊已創建的測驗專案 “test-jokey” 進入專案主頁面,在【代碼倉庫】選單中新建測驗代碼倉庫,如下圖所示:

創建構建計劃
在測驗專案 “test-jokey” 主頁面左側選單【持續集成】的子選單 【構建計劃】中創建一個構建計劃,構建計劃是持續集成的基本單元,可以通過選擇構建計劃模版快速創建一個構建計劃,詳情請參考檔案 快速開始持續集成,
步驟 1:選擇 “構建鏡像并推送到 TCR 企業版” 模版快速創建一個構件計劃,創建示例如下:

步驟 2:根據構建計劃模版選擇要檢出的代碼源和配置 TCR 訪問憑證相關環境變數, 右邊可以看到模版生成的 Jenkinsfile 預覽,如下圖:
提示:Coding devops 和 TCR 實體之間內網互通,鏡像 push 默認使用內網傳輸,無需另外配置,

使用構建模版生成的構建專案,也可以通過點擊構建專案的【設定】選單再對構建詳情進行自定義配置,構建計劃配置頁面的功能說明如下:

【基礎資訊】: 基礎配置頁面可選擇代碼源和節點池等基礎配置,節點池相關說明請參考檔案 構建節點,
【流程配置】:用來配置運行構建任務的環境,相關說明請參考 構建環境,
【觸發規則】:用來配置構建計劃的觸發規則,可支持通過多種方式來觸發構建計劃,相關說明請參考 觸發規則,
【變數與快取】:環境變數與快取配置,相關說明請參考 環境變數 和 快取目錄 ,
【通知提醒】:構建計劃完成時可向指定的 Coding 團隊成員發送通知提醒,
另外還可以在【專案配置 -> 開發者選項 -> WebHook】 中新建 WebHook 的方式將事件通知推送到企業微信等即時通信平臺,詳情請參考 WebHook 和 系結企業微信群機器人,配置示例如下圖:

想了解更多關于 Coding 持續集成的詳細介紹請參考 持續集成介紹,
創建持續部署
在測驗專案 “test-jokey” 主頁面左側選單 【持續集成】的子選單 【Kubernetes】中根據步驟引導創建持續部署流水線,如下圖所示:

配置云賬號
請參考 云賬號 檔案,添加配置部署云上資源的訪問云賬號資訊,可以選擇【騰訊云 TKE】或者【Kubernetes】 型別的云賬號,輸入相關認證配置添加云賬號,這里選擇了【Kubernetes】方式系結,

配置應用和流程
關于 Coding 應用與專案相關說明請參考檔案 應用與專案和 流程配置 ,這里僅簡單說明下在配置應用和流程程序中的關鍵配置項,
在創建應用時,需要勾選【 Kubernetes(TKE) 部署】方式:

在新建的應用中創建部署流程時,選擇【Kubernetes】流程模版,再根據實際需要選擇模版下的流程,這里選擇了下圖中第二個流程,部署 Deployment 和 Service 到 Kubernets 集群的流程:

在【部署流程】中配置部署流程時,【啟動所需制品】選項關聯之前的持續集成環節生成的 TCR 倉庫鏡像制品:

使用【自動觸發器】系結 TCR 倉庫鏡像制品,這里是重點,作用是當有新版本鏡像構建成功時,將自動觸發部署流程,配置方式如下:

接下來就是配置【部署 Deployment】和【部署 Service】部署階段,兩個階段的配置方式類似,選擇之前添加的有部署權限的云賬號和填寫自定義的 Manifest,即自定義部署 YAML 模版,

自定義 Deployment YAML 示例如下:
提示:關于持續部署更新策略
本示例僅使用了一個簡單的 Deployment YAML 部署到 Kubernetes 集群,使用了默認的滾動部署(RollingUpdate)更新策略,實際上,可以借助 Nginx-ingress / Istio 等工具配置更高級的更新策略,如藍綠發布、金絲雀、A/B 測驗等,具體使用方法請參閱 藍綠發布 、 Nginx-ingress 實作自動化灰度發布、 持續部署 + TKE Mesh 灰度發布實踐,
apiVersion: apps/v1
kind: Deployment
metadata:
name: devops-app
spec:
replicas: 2
selector:
matchLabels:
app: devops-app
template:
metadata:
labels:
app: devops-app
spec:
containers:
- image: xxx-test.tencentcloudcr.com/xxx-test/jokey-test # 示例鏡像地址
name: devops-app
ports:
- containerPort: 5000
imagePullSecrets: # 私有倉庫訪問憑證配置
- name: tcr-secret # 訪問憑證 secret
其中, 對于 spec.template.spec.containers.*.image 的鏡像地址欄位 Coding 會有一個轉換匹配規則, 關于轉換匹配規則的說明請參考檔案 在 manifest 中系結制品,
關于 TKE 拉取 TCR 私有倉庫鏡像有兩種方式:
- 在 TCR 支持區域內可配置 TKE 免密拉取 TCR 容器鏡像,關于 TCR 支持區域請參考 支持地域,關于如何配置可參考檔案 TKE 集群使用 TCR 插件內網免密拉取容器鏡像,
- 手動配置 TKE 拉取 TCR 私有倉庫鏡像的訪問憑證,配置方式可參考 TKE 配置私有倉庫訪問示例 ,
注意:上面的 Deployment YAML 示例使用了 “手動配置 TKE 拉取 TCR 私有倉庫鏡像的訪問憑證” 的方式,
自定義的 Service Manifest YAML 示例:
apiVersion: v1
kind: Service
metadata:
labels:
app: devops-svc
name: devops-svc
spec:
ports:
- port: 5000
protocol: TCP
selector:
app: devops-app
另外可以為部署流程的每個階段配置自定義事件通知(可選),以便方便快捷的獲知部署流程執行情況,這里配置了企業微信通知方式,獲取企業微信 Webook 機器人鏈接的方法可參考 創建企業微信群機器人,

關聯專案和應用
關聯專案和應用配置請參考檔案 專案和應用關聯,
提單發布
提單發布使用和配置請參考檔案 新建發布單,
想了解更多關于 Coding 持續部署的詳細介紹請參考 持續部署介紹,
測驗驗證
在專案代碼檔案中修改添加如下所示的 v2 API 代碼后提交 master 分支:

由于【持續集成】中的構建計劃使用了 “代碼更新時自動執行” 的事件觸發配置, 了解相關觸發配置請參考 觸發規則,當提交修改的代碼時,會自動觸發關聯的構建計劃執行:

如果為持續集成配置了企業微信 Webhook 通知,企業微信也會收到相應的即時通知訊息,如下圖所示:

當構建計劃生成 Docker 鏡像制品時,又會自動觸發關聯的【持續部署】流程,將新的鏡像應用更新到 TKE 集群中:

如果部署流程有配置企業微信通知的話,當部署流程任務完成時,會收到對應的企業微信部署完成通知,如下圖所示:

此時,可以在 TKE 中看到已經成功更新了作業負載:

從測驗驗證結果可以看出,我們在 TKE 中實作了從原始碼更新到業務發布的整套 DevOps 流程,
【騰訊云原生】云說新品、云研新術、云游新活、云賞資訊,掃碼關注同名公眾號,及時獲取更多干貨!!
轉載請註明出處,本文鏈接:https://www.uj5u.com/qita/203935.html
標籤:其他

