溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

k8s集群部署完成后的運(yùn)行流程與基礎(chǔ)命令

發(fā)布時(shí)間:2020-07-24 17:58:13 來源:網(wǎng)絡(luò) 閱讀:309 作者:qq5b67ff3f5bc58 欄目:云計(jì)算

Master node(主節(jié)點(diǎn))
Linux:一切皆是文件
K8s:一切皆是資源
k8s集群部署完成后的運(yùn)行流程與基礎(chǔ)命令
k8s集群部署完成后的運(yùn)行流程與基礎(chǔ)命令
Kubectl:k8s是命令行端,用來發(fā)送用戶的操做指令。
Authorization(認(rèn)證授權(quán)機(jī)制)
k8s集群部署完成后的運(yùn)行流程與基礎(chǔ)命令
API(編程接口)
API server:(背)是k8s集群的(前端接口)。各種客戶端工具以及k8s的其他組件可以通過它管理k8s集群的各種資源。他提供了HTTP/HTTPS RESTful API即K8S API.

Scheduler:(調(diào)度的意思)負(fù)責(zé)決定將Pod放在那個(gè)node上運(yùn)行,在調(diào)度是,會(huì)充分考慮集群的拓?fù)浣Y(jié)構(gòu),,當(dāng)前各個(gè)節(jié)點(diǎn)的負(fù)載情況,以及應(yīng)對(duì)高可用,性能,數(shù)據(jù)親和性和需求。

Controller Manager:負(fù)責(zé)管理集群的各種資源,保證資源處于預(yù)期的狀態(tài),它有多種Controller(控制器)組成,包括Replication Controller。Endpoints Controller。 Namespace Controller。 Serviceaccounts Controller等等。

第三方組件:他有可替換方案。Consul,zookeeper。
Etcd:負(fù)責(zé)保存k8s集群的配置信息和各種資源的狀態(tài)信息,當(dāng)數(shù)據(jù)發(fā)生變化時(shí),etcd會(huì)快速的通知k8s相關(guān)組件。

**Pod:k8s集群的最小組成單位,一個(gè)Pod內(nèi),可以運(yùn)行一個(gè)或多個(gè)容器。大多數(shù)情況下,一個(gè)Pod內(nèi)只有一個(gè)Container容器。

Flannel:是k8s集群網(wǎng)絡(luò)方案,可以保證Pod的跨主機(jī)通信。
第三方解決方案,也有替換方案。

可以查看IP地址,以及運(yùn)行在那個(gè)節(jié)點(diǎn)之上。
[root@master ~]# kubectl get pod --all-namespaces -o wide

Node 節(jié)點(diǎn):
Kubelet:他是node的agent(代理),當(dāng)scheduler確定某個(gè)Node上運(yùn)行Pod之后,會(huì)將Pod的具體配置信息發(fā)送給該節(jié)點(diǎn)的kubelet,kubelet會(huì)根據(jù)這些信息創(chuàng)建和運(yùn)行容器,并向Master報(bào)告運(yùn)行狀態(tài)。

kube-proxy:負(fù)責(zé)將訪問service的TCP/UDP數(shù)據(jù)流轉(zhuǎn)發(fā)到后端的容器,如果有多個(gè)副本,kube-proxy會(huì)實(shí)現(xiàn)負(fù)載均衡。

Cadvisor:控制

//運(yùn)行一個(gè)例子:
創(chuàng)建一個(gè)deployment資源對(duì)象,pod控制器
kubectl run test-web --image=httpd --replicas=2
查看:
[root@master ~]# kubectl get pod -o wide
[root@master ~]# kubectl get deployments.

分析各個(gè)組件的作用以及架構(gòu)工作流程。
1》kubectl發(fā)送部署請(qǐng)求到API server
2》APIserver通知Controller Manager創(chuàng)建一個(gè)Deployment資源
3》Scheduler執(zhí)行調(diào)度任務(wù),將兩個(gè)副本Pod分發(fā)到node01和node02上
4》node01和node2上的kubelet在各自節(jié)點(diǎn)上創(chuàng)建并運(yùn)行Pod。
補(bǔ)充:
1.應(yīng)用的配置和當(dāng)前的狀態(tài)信息保存在etcd中,執(zhí)行kubectl get pod 是API server會(huì)從etcd中讀取這些數(shù)據(jù)。
2.Flannel會(huì)為每個(gè)Pod分配一個(gè)IP,但此時(shí)沒有創(chuàng)建Service資源,目前kube-proxy還沒有參與進(jìn)來。

kubectl run test-web --image=httpd --replicas=2

kubectl get nodes
19 kubectl get deployments.
20 kubectl get pod
21 kubectl get pod -o wide
22 systemctl restart kubelet.service
23 kubectl get pod -o wide
24 kubectl delete pod test-web-5b56bdff65-fwp4l
26 kubectl get pod -o wide

2.Flannel回味每個(gè)pod分配一個(gè)ip,但此時(shí)沒有闖進(jìn)啊service資源,目前kube-proxy還沒有參與進(jìn)來

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI