標(biāo)簽的主要作用:解決同類型的資源對(duì)象越來(lái)越多,為了更好的管理,按照標(biāo)簽分組;
成都創(chuàng)新互聯(lián)公司是一家專業(yè)提供西固企業(yè)網(wǎng)站建設(shè),專注與網(wǎng)站設(shè)計(jì)制作、成都做網(wǎng)站、H5場(chǎng)景定制、小程序制作等業(yè)務(wù)。10年已為西固眾多企業(yè)、政府機(jī)構(gòu)等服務(wù)。創(chuàng)新互聯(lián)專業(yè)網(wǎng)絡(luò)公司優(yōu)惠進(jìn)行中。
常用的標(biāo)簽分類:
- release(版本):stable(穩(wěn)定版)、canary(金絲雀版本、可以理解為測(cè)試版)、beta(測(cè)試版)
- environment(環(huán)境變量):dev(開(kāi)發(fā))、qa(測(cè)試)、production(生產(chǎn))
- application(應(yīng)用):ui、as(應(yīng)用軟件)、pc、sc
- tier(架構(gòu)層級(jí)):frontend(前端)、backend(后端)、cache(緩存、隱藏)
- partition(分區(qū)):customerA(客戶A)、customerB(客戶B)
- track(品控級(jí)別):daily(每天)、weekly(每周)
K8s集群中雖然沒(méi)有對(duì)有嚴(yán)格的要求,但是標(biāo)簽還是要做到:見(jiàn)名知意!方便自己也方便別人!
常用的命令有:
[root@master yaml]# kubectl get pod --show-labels //顯示pod的標(biāo)簽
[root@master yaml]# kubectl get pod -L env //顯示鍵對(duì)應(yīng)的值
[root@master yaml]# kubectl get pod -l env //通過(guò)小l查看僅包含env標(biāo)簽的資源
[root@master yaml]# kubectl get pod -l env --show-labels //顯示對(duì)應(yīng)的鍵值
[root@master yaml]# kubectl label pod labels app=pc //給pod打標(biāo)簽
[root@master yaml]# kubectl label pod labels app- //去除標(biāo)簽
[root@master yaml]# kubectl label pod labels env=dev --overwrite //修改標(biāo)簽內(nèi)容
標(biāo)簽與標(biāo)簽選擇器的關(guān)系:
- 如果標(biāo)簽有多個(gè),標(biāo)簽選擇器選擇其中一個(gè),也可以關(guān)聯(lián)成功!
- 如果選擇器有多個(gè),那么標(biāo)簽必須滿足標(biāo)簽選擇器的條件,才可關(guān)聯(lián)成功!
標(biāo)簽選擇器:標(biāo)簽的查詢過(guò)濾條件
基于等值關(guān)系的(equality-based):”=“、”==“、”!=“前兩個(gè)等于,最后一個(gè)不等于
基于集合關(guān)系(set-based):in、notin、exists三種;
selector:
matchLables: //指定等值關(guān)系的標(biāo)簽選擇器
app: nginx
matchExpressions: //基于集合的標(biāo)簽選擇器。選擇器列表間為”邏輯與“關(guān)系;使用In或NotIn操作是,其values不強(qiáng)制要求為空的字符串列表,而使用Exists或DostNotExists時(shí),其values必須為空;
- {key: name,operator: In,values: [zhangsan,lisi]}
- {key: age,operator: Exists,values:}
使用標(biāo)簽選擇器的邏輯:
- 同時(shí)指定的多個(gè)選擇器之間的邏輯關(guān)系為”與“操作;
- 使用空值的標(biāo)簽選擇器意味著每個(gè)資源對(duì)象都將被選擇中;
- 空的標(biāo)簽選擇器無(wú)法選中任何資源;
Pod控制器基本概念:
Pod是kubernetes的最小單元,自主式創(chuàng)建的pod刪除就沒(méi)有了,但是通過(guò)資源控制器創(chuàng)建的pod如果刪除還會(huì)重建。pod控制器就是用于實(shí)現(xiàn)代替我們?nèi)ス芾韕od的中間層,并幫我們確保每一個(gè)pod資源處于我們所定義或者所期望的目標(biāo)狀態(tài),pod資源出現(xiàn)故障首先要重啟容器,如果一直重啟有問(wèn)題的話會(huì)基于某種策略重新編排。自動(dòng)適應(yīng)期望pod數(shù)量。
Kubernetes中內(nèi)建了很多controller(控制器),這些相當(dāng)于?個(gè)狀態(tài)機(jī),?來(lái)控制Pod的具體狀態(tài)和?為。
Pod控制器有很多種類型,但是目前kubernetes中常用的控制器有:
- Replication Controller(RC):是Kubernetes系統(tǒng)中的核心概念,用于定義Pod副本的數(shù)量。在Master內(nèi),RC進(jìn)程通過(guò)RC的定義來(lái)完成Pod的創(chuàng)建、監(jiān)控、啟停等操作。根據(jù)RC定義,Kubernetes能夠確保在任意時(shí)刻都能運(yùn)行用于指定的Pod"副本"(Replica)數(shù)量。隨著kubernetes的迭代更新,RC即將被廢棄,逐漸被ReplicaSet替代;
- ReplicaSet(RS):它的核心作用是代用戶創(chuàng)建指定數(shù)量的Pod副本,并確定Pod副本一直處于滿足用戶期望數(shù)量的狀態(tài),多退少補(bǔ),同時(shí)支持?jǐn)U縮容機(jī)制。主要有三個(gè)組件:用戶期望的Pod副本數(shù)量;標(biāo)簽選擇器,選擇屬于自己管理和控制的Pod;當(dāng)前Pod數(shù)量不滿足用戶期望數(shù)量時(shí),根據(jù)資源模板進(jìn)行新建;
- Deployment:工作在ReplicaSet之上,用于管理無(wú)狀態(tài)應(yīng)用,除了ReplicaSet的機(jī)制,還增加了滾動(dòng)更新和回滾功能,提供聲明式配置;
- DaemonSet:用于確保集群中的每一個(gè)節(jié)點(diǎn)只運(yùn)行特定的pod副本,通常用于實(shí)現(xiàn)系統(tǒng)級(jí)后臺(tái)任務(wù)。比如ELK服務(wù)。要求:服務(wù)是無(wú)狀態(tài)的;服務(wù)必須是守護(hù)進(jìn)程;
Pod控制器通常包含三個(gè)組成部分:
基本概念
Replication Controller 簡(jiǎn)稱RC,它能確保任何時(shí)候Kubernetes集群中有指定數(shù)量的pod副本(replicas)在運(yùn)行, 如果少于指定數(shù)量的pod副本(replicas),Replication Controller會(huì)啟動(dòng)新的Container,反之會(huì)殺死多余的以保證數(shù)量不變。Replication Controller使用預(yù)先定義的pod模板創(chuàng)建pods,一旦創(chuàng)建成功,pod 模板和創(chuàng)建的pods沒(méi)有任何關(guān)聯(lián),可以修改pod 模板而不會(huì)對(duì)已創(chuàng)建pods有任何影響,也可以直接更新通過(guò)Replication Controller創(chuàng)建的pods。對(duì)于利用pod 模板創(chuàng)建的pods,Replication Controller根據(jù)label selector來(lái)關(guān)聯(lián),通過(guò)修改pods的label可以刪除對(duì)應(yīng)的pods。
最初Replication Controller 是用于復(fù)制和在異常時(shí)重新調(diào)度節(jié)點(diǎn)的唯一kubernetes組件,后來(lái)逐漸被replicaSet代替了?,F(xiàn)在基本上很少見(jiàn)到Replication Controller,它即將被廢棄。但是有的kubernates容器環(huán)境還是有可能會(huì)有RC,所以還是有必要知道它的用法。
根據(jù)Replication Controller的定義,Kubernetes能夠確保在任意時(shí)刻都能運(yùn)行用于指定的Pod"副本"(Replica)數(shù)量。如果有過(guò)多的Pod副本在運(yùn)行,系統(tǒng)就會(huì)停掉一些Pod;如果運(yùn)行的Pod副本數(shù)量太少,系統(tǒng)就會(huì)再啟動(dòng)一些Pod,總之,通過(guò)RC的定義,Kubernetes總是保證集群中運(yùn)行著用戶期望的副本數(shù)量。
Replication Controller(RC)的特點(diǎn):
- 確保Pod數(shù)量;
- 確保Pod健康;
- 彈性伸縮;
- 滾動(dòng)更新;
應(yīng)用示例
[root@master yaml]# vim rc.yaml
kind: ReplicationController
apiVersion: v1
metadata:
name: http-rc
spec:
replicas: 2
selector:
name: http-rc
template:
metadata:
labels:
name: http-rc
spec:
containers:
- name: http-rc
image: httpd
[root@master yaml]# kubectl apply -f rc.yaml
[root@master yaml]# kubectl get rc http-rc
NAME DESIRED CURRENT READY AGE
http-rc 2 2 2 103s
[root@master yaml]# kubectl get pod -o wide
NAME READY STATUS RESTARTS AGE IP NODE NOMINATED NODE READINESS GATES
http-rc-l2sp6 1/1 Running 0 98s 10.244.1.5 node01 <none> <none>
http-rc-xghkm 1/1 Running 0 98s 10.244.2.5 node02 <none> <none>
[root@master yaml]# kubectl delete -f rc.yaml
基本概念
ReplicaSet是Replication Controller的替代者,確保Pod副本數(shù)在任一時(shí)刻都精確滿足期望值。用來(lái)確保容器應(yīng)用的副本數(shù)始終保持在用戶定義的副本數(shù),即如果有容器異常退出,會(huì)自動(dòng)創(chuàng)建新的Pod來(lái)替代;而如果異常多出來(lái)的容器也會(huì)自動(dòng)回收。雖然ReplicaSet可以獨(dú)立使用,但一般還是建議使用 Deployment 來(lái)自動(dòng)管理ReplicaSet,這樣就無(wú)需擔(dān)心跟其他機(jī)制的不兼容問(wèn)題(比如ReplicaSet不支持rolling-update但Deployment支持)。也就是說(shuō)Replicaset通常不會(huì)直接創(chuàng)建,而是在創(chuàng)建最高層級(jí)的deployment資源時(shí)自動(dòng)創(chuàng)建。
RS與RC相比,RS不僅支持等值的標(biāo)簽器,而且還支持基于集合的標(biāo)簽選擇器;
ReplicaSet(RS)主要功能:
- 確保Pod數(shù)量;
- 確保Pod健康;
- 彈性伸縮;
- 滾動(dòng)更新;
應(yīng)用示例
[root@master yaml]# cat rs.yaml
kind: ReplicaSet
apiVersion: apps/v1
metadata:
name: http-rs
spec:
replicas: 2
selector:
matchLabels:
name: http-rs
template:
metadata:
labels:
name: http-rs
spec:
containers:
- name: http-rs
image: httpd
[root@master yaml]# kubectl apply -f rs.yaml
[root@master yaml]# kubectl get rs http-rs
NAME DESIRED CURRENT READY AGE
http-rs 2 2 2 11s
[root@master yaml]# kubectl get pod -o wide
NAME READY STATUS RESTARTS AGE IP NODE NOMINATED NODE READINESS GATES
http-rs-2sstf 1/1 Running 0 19s 10.244.1.6 node01 <none> <none>
http-rs-jm8ph 1/1 Running 0 19s 10.244.2.6 node02 <none> <none>
[root@master yaml]# kubectl delete -f rs.yaml
根據(jù)上面的yaml文件可以看出,ReplicaSet和Replication Controller的template部分是一樣的,但是selector處不一樣。Replication Controller用selector , ReplicaSet用 selector.matchLables選擇器 ,這樣更簡(jiǎn)單,更具有表達(dá)力!
RS支持的spec.selector 支持matchLabels和matchExpressions兩種匹配機(jī)制!
ReplicaSet 與 Replication Controller 的區(qū)別
- ReplicaSet 標(biāo)簽選擇器的能力更強(qiáng);
- Replication Controller只能指定標(biāo)簽名:標(biāo)簽值;
- Replicaset 可以指定env=pro,env=devel ,也可以指定只要包含env標(biāo)簽就行,理解為env=*;
總之,目前來(lái)說(shuō),RS可以代替RC的所有的功能,而且RC已經(jīng)處于快被淘汰的邊緣!
基本概念
Deployment構(gòu)建于ReplicaSet之上,支持事件和狀態(tài)查看、回滾、版本記錄、暫停和啟動(dòng)升級(jí);Deployment有多種自動(dòng)更新方案:Recreate,先刪除再新建;RollingUpdate,滾動(dòng)升級(jí),逐步替換。Deployment為Pod和Replica Set(下一代Replication Controller)提供聲明式更新,它可以更加方便的管理Pod和Replica Set。只需要在 Deployment 中描述想要的目標(biāo)狀態(tài)是什么,Deployment controller 就會(huì)幫您將 Pod 和ReplicaSet 的實(shí)際狀態(tài)改變到您的目標(biāo)狀態(tài)。此外,也可以定義一個(gè)全新的 Deployment 來(lái)創(chuàng)建 ReplicaSet 或刪除已有Deployment 并創(chuàng)建一個(gè)新的來(lái)替換。
Deployment控制器典型的應(yīng)用如下:
- 使用Deployment來(lái)創(chuàng)建ReplicaSet (即RS)。RS在后臺(tái)創(chuàng)建pod。檢查啟動(dòng)狀態(tài),看它是成功還是失?。?/li>
- 接著通過(guò)更新Deployment的PodTemplateSpec字段來(lái)聲明Pod的新?tīng)顟B(tài);這會(huì)創(chuàng)建一個(gè)新的RS,Deployment會(huì)按照控制的速率將pod從舊的RS移動(dòng)到新的RS中;
- 如果當(dāng)前狀態(tài)不穩(wěn)定,回滾到之前的Deployment revision。每次回滾都會(huì)更新Deployment的revision;
- 擴(kuò)容Deployment以滿足更高的負(fù)載;
- 暫停Deployment來(lái)應(yīng)用PodTemplateSpec的多個(gè)修復(fù),然后恢復(fù)上線;
- 根據(jù)Deployment 的狀態(tài)判斷上線是否hang住了;
- 清除舊的不必要的 ReplicaSet;
Deployment和RC、RS一樣都是Kubernetes的一個(gè)核心內(nèi)容,主要職責(zé)同樣是為了保證pod的數(shù)量和健康,90%的功能與Replication Controller完全一樣,可以看做新一代的Replication Controller。
但是,它又具備了Replication Controller之外的新特性:
- RC的全部功能;
- 事件和狀態(tài)查看;
- 回滾;
- 版本記錄;
- 暫停和啟動(dòng);
- 多種升級(jí)方案;
一般情況下,個(gè)人推薦使用Deployment!
應(yīng)用示例
[root@master yaml]# cat deployment.yaml
kind: Deployment
apiVersion: extensions/v1beta1
metadata:
name: http-deployment
spec:
replicas: 2
selector:
matchLabels:
name: http-deployment
template:
metadata:
labels:
name: http-deployment
spec:
containers:
- name: http-deployment
image: httpd
[root@master yaml]# kubectl apply -f deployment.yaml
[root@master yaml]# kubectl get deployments. http-deployment
NAME READY UP-TO-DATE AVAILABLE AGE
http-deployment 2/2 2 2 9s
[root@master yaml]# kubectl get pod -o wide
NAME READY STATUS RESTARTS AGE IP NODE NOMINATED NODE READINESS GATES
http-deployment-548ddf7b65-77vfk 1/1 Running 0 18s 10.244.1.7 node01 <none> <none>
http-deployment-548ddf7b65-hdczk 1/1 Running 0 18s 10.244.2.7 node02 <none> <none>
[root@master yaml]# kubectl delete -f deployment.yaml
基本概念
DaemonSet確保全部(或者一些)Node節(jié)點(diǎn)上運(yùn)行一個(gè)Pod 的副本,可使用節(jié)點(diǎn)選擇器及節(jié)點(diǎn)標(biāo)簽指定Pod僅在部分Node節(jié)點(diǎn)運(yùn)行。當(dāng)有Node加入集群時(shí),會(huì)為他們新增一個(gè)Pod;當(dāng)有Node從集群移除時(shí),這些Pod也會(huì)被回收。刪除 DaemonSet將會(huì)刪除它創(chuàng)建的所有Pod。DaemonSet常用于存儲(chǔ)、日志、監(jiān)控類守護(hù)進(jìn)程。
DeamonSet簡(jiǎn)單的用法是,在所有的 Node 上都存在一個(gè) DaemonSet,將被作為每種類型的 daemon 使用。 一個(gè)稍微復(fù)雜的用法可能是,對(duì)單獨(dú)的每種類型的 daemon 使用多個(gè) DaemonSet,但具有不同的標(biāo)志,和/或?qū)Σ煌布愋途哂胁煌膬?nèi)存、CPU要求。
應(yīng)用示例
[root@master yaml]# cat ds.yaml
kind: DaemonSet
apiVersion: extensions/v1beta1
metadata:
name: http-ds
spec:
selector:
matchLabels:
name: http-ds
template:
metadata:
labels:
name: http-ds
spec:
containers:
- name: http-ds
image: httpd
[root@master yaml]# kubectl apply -f ds.yaml
daemonset.extensions/http-ds created
[root@master yaml]# kubectl get ds http-ds
NAME DESIRED CURRENT READY UP-TO-DATE AVAILABLE NODE SELECTOR AGE
http-ds 2 2 2 2 2 <none> 17s
[root@master yaml]# kubectl get pod
NAME READY STATUS RESTARTS AGE
http-ds-gkscx 1/1 Running 0 39s
http-ds-nbq69 1/1 Running 0 39s
[root@master yaml]# kubectl delete -f ds.yaml
注意:DaemonSet中不可寫(xiě)replicas(副本)數(shù)量。它會(huì)根據(jù)當(dāng)前k8s集群中的node自動(dòng)生成!
——————————本文到此結(jié)束,感謝閱讀——————————————
網(wǎng)頁(yè)標(biāo)題:Kubernetes之標(biāo)簽與Pod控制器詳解
文章鏈接:http://aaarwkj.com/article14/gdisge.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供品牌網(wǎng)站設(shè)計(jì)、外貿(mào)建站、定制網(wǎng)站、網(wǎng)站導(dǎo)航、網(wǎng)站營(yíng)銷、動(dòng)態(tài)網(wǎng)站
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來(lái)源: 創(chuàng)新互聯(lián)