真实的国产乱ⅩXXX66竹夫人,五月香六月婷婷激情综合,亚洲日本VA一区二区三区,亚洲精品一区二区三区麻豆

成都創(chuàng)新互聯(lián)網(wǎng)站制作重慶分公司

GitOps中如何將DevOps擴展至K8S

GitOps中如何將DevOps擴展至K8S,很多新手對此不是很清楚,為了幫助大家解決這個難題,下面小編將為大家詳細講解,有這方面需求的人可以來學(xué)習(xí)下,希望你能有所收獲。

網(wǎng)站制作、網(wǎng)站建設(shè)的關(guān)注點不是能為您做些什么網(wǎng)站,而是怎么做網(wǎng)站,有沒有做好網(wǎng)站,給創(chuàng)新互聯(lián)公司一個展示的機會來證明自己,這并不會花費您太多時間,或許會給您帶來新的靈感和驚喜。面向用戶友好,注重用戶體驗,一切以用戶為中心。

在過去十年的編程中,出現(xiàn)了一些革命性的轉(zhuǎn)變。其中之一是源于圍繞DevOps的實踐,它將開發(fā)和運維團隊整合到一個共享的工作流程中,此外還有持續(xù)集成和持續(xù)交付(CI/CD),通過CI/CD,Devops團隊可以向代碼庫提供持續(xù)的更新。另一個變革來自于從單體代碼庫到基于云的微服務(wù)的遷移,這些微服務(wù)運行在由Kubernetes等編排平臺管理的容器中。

即使有Kubernetes這樣的平臺來編排協(xié)調(diào),在集群系統(tǒng)或云端運行的基于容器的應(yīng)用程序依舊可能是復(fù)雜的、難以調(diào)配和管理的。GitOps是一套新興的實踐,旨在通過應(yīng)用Devops和CI/CD世界的技術(shù)來簡化這一管理任務(wù)。

GitOps的關(guān)鍵是基礎(chǔ)設(shè)施即代碼(IaC)的理念,它采用與DevOps用于提供應(yīng)用程序一樣的方法來提供基礎(chǔ)設(shè)施。所以,不僅是應(yīng)用,還有底層的主機和網(wǎng)絡(luò)都被描述在文件中,這些文件可以像版本控制系統(tǒng)中的其他代碼一樣,然后由自動化流程來將現(xiàn)實世界的應(yīng)用與這些文件中描述的應(yīng)用進行融合。

用GitOps的說法,版本控制系統(tǒng)中的代碼是關(guān)于應(yīng)用在生產(chǎn)中應(yīng)該是什么樣子的唯一真相來源(single source of truth)。

定義GitOps

Weaveworks是在GitOps概念普及方面貢獻最大的公司。稍后我們會詳細介紹Weaveworks在其中扮演的角色,但首先,我們先來看看該公司對GitOps的定義,它有兩個方面:

Kubernetes和其他云原生技術(shù)的運維模式,為統(tǒng)一部署、管理和監(jiān)控容器化集群和應(yīng)用提供了一套最佳實踐。 GitOps是一條通往管理應(yīng)用的開發(fā)者體驗之路;在這里,端到端的CI/CD流水線和Git workflow可以同時應(yīng)用于運維和開發(fā)。 換句話說,GitOps是一套特定的實踐,旨在管理Kubernetes和類似的平臺。隨著越來越多的開發(fā)團隊采用DevOps實踐,并將代碼遷移到云端,GitOps也將會適合更廣泛的應(yīng)用。但要了解GitOps的秘訣和它所能解決的問題,我們需要談?wù)勊慕M成部分。

Git定義

在GitOps中Git指的是由Linus Torvalds在2005年開發(fā)的極為流行的分布式版本控制系統(tǒng)。Git是一個工具,它允許開發(fā)者團隊在一個應(yīng)用程序代碼庫上共同工作,存儲各種代碼分支,在將它們合并到生產(chǎn)代碼之前,他們可以對這些代碼進行修補。Git 的一個關(guān)鍵概念是拉取請求,即開發(fā)人員正式要求將他們正在編寫的一些代碼整合到代碼庫的另一個分支中。

Git 拉取請求為團隊成員提供了一個協(xié)作和討論的機會,然后再就是否應(yīng)該將新代碼添加到應(yīng)用程序中達成共識。Git 還會存儲舊版本的代碼,如果出了問題,可以很容易地回滾到上一個好的版本,并可以讓你快速查看兩次修改之間的變化。Git 最為人所知的部分可能是作為GitHub 這一云端托管版本控制系統(tǒng)的底層,但 Git 本身也是一個開源軟件,可以部署在任何地方,無論是公司內(nèi)部的服務(wù)器還是你的PC。

需要注意的是,雖然我們通常認為Git是一個計算機編程工具,但實際上取決于你如何使用它。Git 很樂意將任何文本文件作為你的 “代碼庫”,例如,它可以被作者用來記錄合作作品的編輯情況。這一點很重要,因為GitOps的核心代碼庫大多由聲明式配置文件而非可執(zhí)行代碼組成。

在我們繼續(xù)之前,最后要強調(diào)一件事——盡管名字中就有 “Git”,但GitOps實際上并不必要使用Git。 已經(jīng)投入使用其他版本控制軟件(如Subversion)的團隊也可以實現(xiàn)GitOps。但在Devops領(lǐng)域,Git被廣泛用于實現(xiàn)CI/CD,所以大多數(shù)GitOps項目最終都會使用Git。

什么是CI/CD流程?

關(guān)于CI/CD的完整解釋其實不在本文討論的范圍內(nèi),但是因為CI/CD是 GitOps 工作的核心,因此我們需要對其進行簡單的介紹。CI/CD中的一半持續(xù)集成是由版本控制倉庫(如Git)實現(xiàn)的。開發(fā)者可以對代碼庫進行持續(xù)的小改進,而不是每隔幾個月或幾年就推出巨大的、單一的新版本。持續(xù)部署這一塊是通過被稱為流水線(pipeline)的自動化系統(tǒng)來實現(xiàn)的,這些流水線可以構(gòu)建、測試和部署新的代碼到生產(chǎn)中。

同樣,我們在這里一直在談?wù)摯a,這通常會讓人聯(lián)想到用C語言、Java或JavaScript等編程語言編寫的可執(zhí)行代碼。但在GitOps中,我們所管理的 “代碼” 主要是由配置文件組成的。這不是一個小細節(jié),而是GitOps工作的核心。正如我們所說,這些配置文件是描述我們的系統(tǒng)應(yīng)該是什么樣子的 “唯一真理來源(single source of truth)”。它們是聲明式的,而不是指導(dǎo)性的。這意味著,配置文件不會說 “啟動十臺服務(wù)器”,而會簡單地說 “這個系統(tǒng)包括十臺服務(wù)器”。

GitOps方程中的CI那一半允許開發(fā)人員快速推出對這些配置文件的調(diào)整和改進;當自動化軟件代理竭盡全力確保應(yīng)用程序的實時版本能夠反映配置文件中的描述時,CD這一部分會以GitOps語言趨向于聲明式模型。

GitOps和Kubernetes

正如我們所提到的,GitOps的概念最初是圍繞管理Kubernetes應(yīng)用而出現(xiàn)的。通過我們現(xiàn)在對GitOps的了解,讓我們重溫一下Weaveworks的GitOps討論,看看他們是如何描述如何對基于GitOps原則管理的Kubernetes進行更新的。下面是對整個流程的總結(jié):

一個開發(fā)者為一個新功能提出Git 拉取請求。 審查和批準代碼,然后將其合并到主代碼庫中。 合并會觸發(fā) CI/CD 流水線、自動測試和重建新代碼,并將其部署到倉庫。 軟件代理注意到更新,從倉庫中提取新代碼,并更新配置倉庫中的配置文件(用YAML編寫)。 Kubernetes集群中的軟件代理根據(jù)配置文件,檢測到集群已經(jīng)過時,拉取更改,并部署新功能。 Weaveworks和GitOps

顯然,這里的第4步和第5步做了很多繁重的工作。將Git倉庫中的 "真理來源 "與現(xiàn)實世界中的Kubernetes應(yīng)用進行神奇同步的軟件代理,就是讓GitOps成為可能的魔法。正如我們所說,在GitOps術(shù)語中,讓實時系統(tǒng)更像配置文件中描述的理想系統(tǒng)的過程叫做融合。當實時系統(tǒng)和理想系統(tǒng)不同步時,那就是分歧。理想情況下,融合可以通過自動化流程來實現(xiàn),但自動化所能做的事情是有限度的,有時人工干預(yù)是必要的。

我們在這里用通用術(shù)語描述了這個過程,但事實上,如果你真的去看Weaveworks的頁面,我們提到的 “軟件代理” 是該公司W(wǎng)eave Cloud平臺的一部分?!癎itOps” 這個詞是由Weaveworks的CEO Alexis Richardson創(chuàng)造的,它的部分作用是讓W(xué)eaveworks平臺對已經(jīng)沉浸在DevOps和CI/CD世界的開發(fā)者有吸引力。

但Weaveworks從未宣稱自己壟斷了GitOps,GitOps更多的是一種理念和一套最佳實踐,而不是某種具體的產(chǎn)品。 正如提供CI/CD解決方案的公司CloudBees的博客所指出的那樣,GitOps代表了一種開放的、廠商中立的模式,它是針對亞馬遜、谷歌和微軟等大型云廠商推出的管理型專有Kubernetes解決方案而開發(fā)的。CloudBees提供了自己的GitOps解決方案,這個領(lǐng)域的另一些玩家也是如此。

GitOps的優(yōu)勢:

可觀察性:GitOps系統(tǒng)為復(fù)雜的應(yīng)用提供了監(jiān)控、日志、跟蹤和可視化功能,因此開發(fā)人員可以看到什么地方出現(xiàn)了故障,在哪里出現(xiàn)了故障。 版本控制和變更管理:很明顯,這是使用Git這樣的版本控制系統(tǒng)的一個關(guān)鍵優(yōu)勢。有缺陷的更新可以輕松回滾。

易于采用:GitOps建立在許多開發(fā)人員已經(jīng)掌握的開發(fā)技能之上。

提高生產(chǎn)力:GitOps 可以像開發(fā)項目和 CI/CD 那樣提高工作效率。

審計:有了Git,每一個操作都可以追蹤到一個特定的提交,這樣就可以很容易地追蹤到錯誤的原因。

即使你不使用Kubernetes,GitOps也很有可能遲早會成為你工作流程的一部分。

看完上述內(nèi)容是否對您有幫助呢?如果還想對相關(guān)知識有進一步的了解或閱讀更多相關(guān)文章,請關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道,感謝您對創(chuàng)新互聯(lián)的支持。


本文名稱:GitOps中如何將DevOps擴展至K8S
文章出自:http://weahome.cn/article/gdggdo.html

其他資訊

在線咨詢

微信咨詢

電話咨詢

028-86922220(工作日)

18980820575(7×24)

提交需求

返回頂部