【翻譯】Kubernetes 部署語言(Kubernetes Deployment Language)

由于簡書圖片上傳失敗轿曙,可以通過 https://www.guyu.me/blog/2022-02-15-kdl/ 訪問本文弄捕。

在網(wǎng)上搜索規(guī)范化的 K8S 的部署架構(gòu)圖畫法時,發(fā)現(xiàn)了 Redhat 的一篇博客导帝。覺得非常不錯守谓,遂翻譯分享之。

原文: https://github.com/raffaelespazzoli/kdl

介紹

這篇博文介紹了 Kubernetes API 對象的圖形表示法:Kubernetes 部署語言(簡稱 KDL)您单。 Kubernetes API 對象可被用于描述如何在 Kubernetes 中部署一個解決方案斋荞。

筆者認(rèn)為有必要描述和記錄如何在 Kubernetes 中部署應(yīng)用程序,特別是當(dāng)應(yīng)用程序用到了多個不同的 Kuberenetes 組件時虐秦。

筆者想創(chuàng)建一個簡單的圖形符號約定來描述這些應(yīng)用程序的部署平酿,以便這些圖形可以輕松地在白板或文檔中繪制。

為了更好地解釋該符號體系的目標(biāo)悦陋,我們可以將其與 UML比較蜈彼。UML 有幾種圖形語言來描述應(yīng)用程序架構(gòu)的不同方面。 不過俺驶,與 UML 的不同之處在于幸逆,在 KDL 中,我們沒有進(jìn)行正向或逆向工程的目標(biāo)(即我們不轉(zhuǎn)換 yaml 文件中的圖表,反之亦然)秉颗。 這樣痢毒,我們就有機(jī)會管理要在圖表中顯示的信息量送矩。 作為一般經(jīng)驗(yàn)法則蚕甥,我們只會顯示與架構(gòu)相關(guān)的信息。

您還可以下載KDL 的 visio模板栋荸。

目標(biāo)

該圖形符號體系的目標(biāo)如下:

  • 創(chuàng)建一種通用的圖形語言來描述如何在 Kubernetes 中部署應(yīng)用程序菇怀。
  • 表示 Kubernetes API 對象與架構(gòu)最相關(guān)的方面。
  • 簡單地說晌块,在理想情況下爱沟,一個擁有白板和一些彩色便利貼的人應(yīng)該能夠創(chuàng)建這些圖表。

以下內(nèi)容不是該符號體系的目標(biāo):

  • 自動生成 API 對象定義

顏色編碼

一般來說匆背,Kubernetes API 對象涵蓋以下范疇:

范疇 顏色約定 例子
Kubernetes 集群 Kubernetes 解決方案中包含的若干個集群
計(jì)算 部署
網(wǎng)絡(luò) 服務(wù)
存儲 藍(lán) 持久卷申領(lǐng)(PersistentVolumeClaim)呼伸,持久卷(PersistentVolume)

Kubernetes 集群

Kubernetes 集群可以簡單地表示為一個紅色的矩形:

kubernetes集群

所有其他 API 對象都存在于集群內(nèi)部或集群邊緣。
永遠(yuǎn)不需要顯式表現(xiàn) Kubernetes 集群內(nèi)的各個節(jié)點(diǎn)钝尸。

您可以用其它的圖形表示集群外部的組件以及它們?nèi)绾闻c集群內(nèi)部的組件連接括享。 此圖形約定不含集群外的組件的展示方式。

計(jì)算

計(jì)算對象是最復(fù)雜的圖形珍促。 通常铃辖,它們由一個帶有組件標(biāo)識的矩形表示,用于展示計(jì)算對象的附加信息猪叙。 這是一個模板:

計(jì)算

圖片的中心部分代表一個 Pod娇斩。 在其中我們可以看到一個或多個容器。 Pod 和容器都應(yīng)該有一個名稱穴翩。

在 Pod 的左側(cè)犬第,我們有額外的計(jì)算附加信息。 頂部標(biāo)記指定此 Pod 的控制器類型芒帕。 以下是控制器的類型及其縮寫:

控制器類型 縮寫
Replication Controller RC
Replica Set RS
Deployment D
DeploymentConfig (OpenShift only) DC
DaemonSet DS
StatefulSet SS
Job J
Cron Job J

在底部歉嗓,我們有該 Pod 實(shí)例的基數(shù)。 根據(jù)控制器的類型副签,該字段具有不同的含義和格式遥椿,這里有一個參考表格:

控制器類型 格式
Replication Controller 一個數(shù)字或者數(shù)字范圍 (例如 3 或 2:5)
ReplicaSet 一個數(shù)字或者數(shù)字范圍 (例如 3 或 2:5)
Deployment 一個數(shù)字或者數(shù)字范圍 (例如 3 或 2:5)
DeploymentConfig (只有 OpenShift 有) 一個數(shù)字或者數(shù)字范圍 (例如 3 或 2:5)
DaemonSet 節(jié)點(diǎn)選擇器: 例如 storage-node=true
StatefulSet 一個數(shù)字: 例如 3
Job 一個表示并行度的數(shù)字: 例如 3
Cron Job 一個表示并行度的數(shù)字: 例如 3

在 pod 的頂部,是暴露的端口淆储。 您可以使用小矩形僅顯示端口號或添加端口名稱冠场。 這是一個例子:

端口

這些小矩形是黃色的,因?yàn)榇砭W(wǎng)絡(luò)配置本砰。您可以將每個端口與實(shí)際暴露該端口相關(guān)的容器連接起來碴裙。 但在大多數(shù)情況下,這不是必需的,因?yàn)榇蠖鄶?shù) pod 只有一個容器舔株。

在 pod 的底部莺琳,我們有 附加卷。 卷的名稱應(yīng)顯示在矩形中载慈。 在大多數(shù)情況下惭等,這些將是持久卷。 如果卷類型不是持久卷办铡,則顯示它可能是相關(guān)的辞做。 此外,有時顯示安裝點(diǎn)也很重要寡具。 以下是卷的符號示例:

附加卷

在 Pod 的右側(cè)秤茅,具有與 Pod 的配置相關(guān)的卷:secretsconfigmaps。 對于數(shù)據(jù)卷童叠,應(yīng)該指明卷的名稱框喳,通常區(qū)分configmapssecret很重要,所以還應(yīng)該指明卷的類型厦坛,如果需要還可以顯示掛載點(diǎn)五垮。 這里有些例子:

配置相關(guān)卷

網(wǎng)絡(luò)

網(wǎng)絡(luò)對象有兩種: servicesingresses (routes 在 OpenShift 里有).

服務(wù)

服務(wù)可以用橢圓表示,如下圖所示:

服務(wù)

左側(cè)有一個代表服務(wù)類型的小矩形粪般。 以下是縮寫:

類型 縮寫
Cluster IP CIP
Cluster IP, ClusterIP: None HS a.k.a. Headless Service
Node Port NP
LoadBalancer LB
External Name (OpenShift only) EN
External IP EIP

在服務(wù)的頂部有暴露的端口拼余。 此處適用與計(jì)算對象端口相同的約定。

該服務(wù)應(yīng)連接到計(jì)算對象亩歹。 這將隱式定義服務(wù)選擇器匙监,因此無需在圖片中指示它。

如果服務(wù)允許從集群外部到內(nèi)部 pod 的流量(例如負(fù)載均衡器或節(jié)點(diǎn)端口或外部 IP)小作,則應(yīng)在集群邊緣進(jìn)行描述亭姥。

邊緣服務(wù)

相同的概念適用于調(diào)節(jié)出站流量(例如外部名稱)的服務(wù),盡管在這種情況下它們可能會出現(xiàn)在 Kubernetes 集群矩形的底部顾稀。

Ingress

Ingress 可以用平行四邊形表示达罗,如下圖:

ingress

Ingress 顯示 Ingress 名稱以及可選的 host。 Ingress 將連接到服務(wù)(相同的規(guī)則適用于 OpenShift 路由)静秆。

Ingress 始終顯示在 OpenShift 集群的邊緣粮揉。

邊緣 Ingress

路由 (OpenShift)

OpenShift 路由使用與 Ingress 相同的符號表示。

存儲

存儲用于指示持久卷抚笔。 存儲的顏色是藍(lán)色的扶认,它的形狀是一個桶,部署如下圖:

存儲

存儲應(yīng)指明持久卷名和存儲提供程序(例如 NFS殊橙、gluster 等)辐宾。
存儲始終位于集群的邊緣狱从,因?yàn)樗侵赶蛲獠靠捎么鎯Φ呐渲谩?/p>

外部可用存儲

Putting it all together

在本節(jié)中,我們將通過一個示例來說明如何使用此表示法來描述應(yīng)用程序的部署叠纹。
我們的應(yīng)用程序是一個銀行服務(wù)應(yīng)用程序季研,它使用 mariadb 數(shù)據(jù)庫作為其數(shù)據(jù)存儲。 作為銀行應(yīng)用程序誉察,一切都必須在 HA 中与涡。
以下是部署圖:

完整的例子

請注意,mariadb pod 使用 StatefulSet 和一個持久卷來存儲其數(shù)據(jù)冒窍。 這個 pod 沒有暴露給集群外部递沪,但它的服務(wù)被 BankService 應(yīng)用程序使用豺鼻。
BankService 應(yīng)用程序是一個由部署配置控制的無狀態(tài) pod综液,該部署配置具有用于訪問數(shù)據(jù)庫的憑據(jù)的機(jī)密。 它還有一個服務(wù)和一個路由儒飒,以便它可以接受來自集群外部的入站連接谬莹。

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市桩了,隨后出現(xiàn)的幾起案子附帽,更是在濱河造成了極大的恐慌,老刑警劉巖井誉,帶你破解...
    沈念sama閱讀 216,997評論 6 502
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件蕉扮,死亡現(xiàn)場離奇詭異,居然都是意外死亡颗圣,警方通過查閱死者的電腦和手機(jī)喳钟,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,603評論 3 392
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來在岂,“玉大人奔则,你說我怎么就攤上這事”挝纾” “怎么了易茬?”我有些...
    開封第一講書人閱讀 163,359評論 0 353
  • 文/不壞的土叔 我叫張陵,是天一觀的道長及老。 經(jīng)常有香客問我抽莱,道長,這世上最難降的妖魔是什么骄恶? 我笑而不...
    開封第一講書人閱讀 58,309評論 1 292
  • 正文 為了忘掉前任食铐,我火速辦了婚禮,結(jié)果婚禮上叠蝇,老公的妹妹穿的比我還像新娘璃岳。我一直安慰自己年缎,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,346評論 6 390
  • 文/花漫 我一把揭開白布铃慷。 她就那樣靜靜地躺著单芜,像睡著了一般。 火紅的嫁衣襯著肌膚如雪犁柜。 梳的紋絲不亂的頭發(fā)上洲鸠,一...
    開封第一講書人閱讀 51,258評論 1 300
  • 那天,我揣著相機(jī)與錄音馋缅,去河邊找鬼扒腕。 笑死,一個胖子當(dāng)著我的面吹牛萤悴,可吹牛的內(nèi)容都是我干的瘾腰。 我是一名探鬼主播,決...
    沈念sama閱讀 40,122評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼覆履,長吁一口氣:“原來是場噩夢啊……” “哼蹋盆!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起硝全,我...
    開封第一講書人閱讀 38,970評論 0 275
  • 序言:老撾萬榮一對情侶失蹤栖雾,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后伟众,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體析藕,經(jīng)...
    沈念sama閱讀 45,403評論 1 313
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,596評論 3 334
  • 正文 我和宋清朗相戀三年凳厢,在試婚紗的時候發(fā)現(xiàn)自己被綠了账胧。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 39,769評論 1 348
  • 序言:一個原本活蹦亂跳的男人離奇死亡数初,死狀恐怖找爱,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情泡孩,我是刑警寧澤车摄,帶...
    沈念sama閱讀 35,464評論 5 344
  • 正文 年R本政府宣布,位于F島的核電站仑鸥,受9級特大地震影響吮播,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜眼俊,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,075評論 3 327
  • 文/蒙蒙 一意狠、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧疮胖,春花似錦环戈、人聲如沸闷板。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,705評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽遮晚。三九已至,卻和暖如春拦止,著一層夾襖步出監(jiān)牢的瞬間县遣,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 32,848評論 1 269
  • 我被黑心中介騙來泰國打工汹族, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留萧求,地道東北人。 一個月前我還...
    沈念sama閱讀 47,831評論 2 370
  • 正文 我出身青樓顶瞒,卻偏偏與公主長得像夸政,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子搁拙,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,678評論 2 354

推薦閱讀更多精彩內(nèi)容