介紹GitOps的工作原理
本文將介紹GitOps的工作原理,它的啟動與執行,以及如何在Kubernetes中配合使用GitOps,以團隊的DevOps體驗. |
英國作家Aldous Huxley曾說:“速度是真正的樂趣之源。”我認為生活如此,軟體領域亦然。隨著DevOps以及GitOps之類輔助實踐的興起,軟體從架構設計到程式碼被部署到生產環境的速度是越來越快。
實際上,DevOps是透過定義一組實踐和文化的轉變,來提高我們生成程式碼的速度,並保證程式碼的可靠性。DevOps本身只是一個廣義術語,不同的組織和團隊在其核心原理上開發出了各種具體的實踐,其中包括:ChatOps、DevSecOps、AIOps、以及一種稱為GitOps的較新的實踐。
GitOps的出現和興起,主要得益於軟體開發行業對於Kubernetes的廣泛採用。在各類組織向Kubernetes的邁進過程中,開發團隊的逐步成長,以及對於擴充套件叢集的管理實踐會變得勢在必行。因此GitOps旨在將Git和Kubernetes結合在一起,為開發人員提供某種形式的操作模型、以及基於Kubernetes的基礎架構和應用程式。可以說,在Kubernetes開發的過程中,GitOps能夠在確保“速度”的基礎上,實現軟體方案的持續交付。
下面,我們來看看GitOps的工作原理,它的啟動與執行,以及如何在Kubernetes中配合使用GitOps,以團隊的DevOps體驗。
GitOps秉承了DevOps的核心理念--“構建它並交付它(you built it you ship it)”。它能夠讓開發人員在自己所選的Git工具中,提出拉式請求,觸發Kubernetes叢集的部署,從而使得Git成為唯一的來源。
顯然,該思想是將基於推式的管道替換為基於拉式的管道,從而使得開發人員能夠直接根據其拉式請求執行部署。而一旦開發人員執行合併或開啟請求,該基礎結構就會在部署過程中觸發一系列的事件。GitOps運算子(operator)只要檢測到此類變化,就會導致另一個運算子宣告的更改,並將其部署到叢集之中。例如,您可以使用如下工具棧來實現GitOps:
- 將Bitbucket作為您的Git VCS(譯者注:Version Control System,版本控制系統)工具。
- 用Docker儲存您的各種映象。
- 用Amazon S3來儲存各種Helm圖表。
- 用AWS Lambda拉取圖表,並提交給叢集儲存庫。
- 用Weaveworks Flux檢測叢集儲存庫中的更改,並做相應的調整。
當然,在您的工具棧中,實現此類功能的實際基礎架構可能會有所不同,但是其機制卻是相似的。
如下是可以實現的GitOps工作流:
- 使用 Bitbucket管道之類的CI(持續整合)工具,將各種Docker映象推送到 之類的託管(hosting)工具處。
- 各種雲功能函式從主儲存bucket處,將不同的配置和 複製到主git儲存庫中。
- 諸如 之類的GitOps運算子,會根據各種配置圖表去更新叢集,並透過Lambda函式提取不同的helm圖表。
當然,上述技術棧中所描述的每個工具都有著對應的替代方案,開發團隊可以選擇最適合的工具,以實現DevOps的目標。例如,同屬於Atlassian套件的Jira功能就能夠輕鬆地與Bitbucket協同發揮作用。因此,如果一個拉式請求在Bitbucket中被建立,就會自動將Jira中的問題傳送到自定義的“部署”上。這將大幅簡化從設計到釋出的DevOps實踐過程。
類似地,當考慮到透過GitOps實現的持續交付機制可能出現失敗時,我們可以新增其他的監控工具,以提供急需的可見性。例如,Thundra.io可被用於監控S3觸發的AWS Lambda函式,以確保在將更改提交給叢集儲存庫時,不會發生任何故障。
同理,我們也可以利用Thundra.io的整合功能,將警報傳送給Opsgenie之類的報警工具,進而通知合適的值班人員,以快速解決那些由拉式請求觸發的部署所引發的任何問題。
可見,我們完全可以透過向GitOps引擎新增更多的功能,以提高GitOps實踐過程中的可靠性和便利性。
總的說來,GitOps能夠為Kubernetes的部署提供融合、冪等、確定性和自動化等方面的功能。根據Kubernetes強大的收斂機制,它將不斷嘗試去改變叢集的狀態,讓各種收斂應用都具有相同的結果。而且這些都會自動而迅速地被觸發。
Kubernetes的編排器(orchestrator)會持續將各種更改應用到叢集中,直到叢集收斂到配置更新所定義的狀態為止,也就是要滿足開發人員或SRE人員所期望的配置狀態。這不但適用於所有的Kubernetes資源,還能夠被用到自定義資源(Custom Resource Definitions,CRD)或Kubernetes的擴充套件。
整個GitOps的過程始於在Git儲存庫中定義某個所需的狀態,然後Git被定位為唯一的來源。此外,我們需要保障提交過來的更改能夠與群集相配,以便標記處群集是已經收斂到了所需的狀態,還是已偏離了該狀態。
當期望狀態與實際狀態不相同時,Kubernetes中的收斂運算子會主動嘗試著補足這兩個狀態之間的差異,即:根據那些針對Git的提交,觸發更改的“差異”警報,以標識處仍然需要進一步的收斂。因此,這就意味著,所有的提交都會產生對於叢集的可驗證的、且冪等的更改。當然,Kubernetes也可能按需產生回滾。就其機制而言,回滾可以被看作是進一步收斂到以前的狀態。
最後,如果系統中不再存在“差異”警報、或僅存在“聚合”警報,那麼該機制就認為實際狀態已經達到了所需的狀態。實際上,我們可以使用回撥、或回寫事件的方法,來設定此類聚合狀態。
至此,我們可以認識到:GitOps依賴於IAC(譯者注:基礎架構即程式碼)的概念。即:以程式設計的方式定義了基礎架構,而基礎架構的實際狀態也會隨著發生相應的變化。這種就是我們在前文中提到的基於拉式的部署方式,它與傳統的基於推式的部署有所不同。
如您所知,DevOps是一個廣闊的領域,它不僅僅限於軟體行業。而GitOps則只是在軟體行業朝著更加敏捷、可靠的方向發展過程中,一種新興的開發實踐。更準確地說,隨著技術趨勢的變化,開發實踐必須適應可用的技術,而GitOps是團隊和組織如何跟蹤技術發展,持續推進開發實踐的一種優秀示例。值得一提的是,諸如Weaveworks Flux之類的運算子,可以很好地幫助您在叢集啟用GitOps。當然,您也可以選用Spinnaker之類的其他代替方案。
此外,考慮到持續部署可能會給生成環境帶來風險,我們可以透過新增諸如Thundra.io和Opsgenie之類的工具,來對系統進行全覆蓋性的測試,以減少風險點,保證一定的可觀察性和事件管理能力。
總的來說,我們可以將GitOps視為一種實踐,它能夠利用Kubernetes的核心力量,來加快軟體從設計到釋出的全部過程。我們只有掌握了GitOps的工作原理,才能充分發揮Kubernetes在容器服務方面的巨大潛力,為持續部署與持續交付保駕護航。
原文地址:
來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/31559985/viewspace-2705761/,如需轉載,請註明出處,否則將追究法律責任。
相關文章
- Apache kafka 工作原理介紹ApacheKafka
- 輪換代理IP的工作原理介紹
- servlet的生命週期和工作原理介紹Servlet
- Fiddler(1)基本介紹以及工作原理
- 山武溫控器的工作原理詳情介紹
- com.sap.ui5.resource.ResourceServlet的工作原理介紹UIServlet
- 學習筆記-React的簡單介紹&工作原理筆記React
- Redis主從複製工作原理和步驟介紹Redis
- JVM 垃圾回收器工作原理及使用例項介紹JVM
- SAP Fiori Elements 框架裡 Smart Table 控制元件的工作原理介紹框架控制元件
- GC演算法介紹及工作原理和優缺點GC演算法
- Docker的原理及特性介紹Docker
- 常用鎖原理的介紹(上)
- XMPP協議的原理介紹協議
- Oracle DRM原理介紹Oracle
- GPU的介紹 以及原理的分析GPU
- 深入介紹 UI5 框架裡 Smart Field 控制元件的工作原理UI框架控制元件
- NTP時間同步伺服器(時鐘同步)工作原理介紹伺服器
- 用於找工作的自我介紹
- Kafka的原理介紹及實踐Kafka
- 工作流介紹 (轉)
- 軟工作業-個人介紹軟工
- SAP工作流介紹之ABAP Business Workflow介紹
- ppium簡介及工作原理
- MapReduce工作原理流程簡介
- HttpSession工作原理簡介HTTPSession
- Async Commit 原理介紹MIT
- phpob快取原理介紹PHP快取
- 單頁面 Web 應用(Single Page Application,SPA)的工作原理介紹WebAPP
- 什麼是影片流?影片流化工作原理以及挑戰介紹
- Struts1、Struts2、Hibernate、Spring框架工作原理介紹Spring框架
- DAPP系統的原理與介紹APP
- 分散式系統CAP的原理介紹分散式
- 1、Camunda工作流-介紹
- Thanos工作原理及元件簡介元件
- ipa重簽名原理介紹
- AsyncDisplayKit介紹(一)原理和思路
- ARKit 和 ARCore原理介紹(轉)