kubernetes簡介
創(chuàng)新互聯(lián)公司是一家集網(wǎng)站建設(shè),疊彩企業(yè)網(wǎng)站建設(shè),疊彩品牌網(wǎng)站建設(shè),網(wǎng)站定制,疊彩網(wǎng)站建設(shè)報價,網(wǎng)絡(luò)營銷,網(wǎng)絡(luò)優(yōu)化,疊彩網(wǎng)站推廣為一體的創(chuàng)新建站企業(yè),幫助傳統(tǒng)企業(yè)提升企業(yè)形象加強(qiáng)企業(yè)競爭力??沙浞譂M足這一群體相比中小企業(yè)更為豐富、高端、多元的互聯(lián)網(wǎng)需求。同時我們時刻保持專業(yè)、時尚、前沿,時刻以成就客戶成長自我,堅持不斷學(xué)習(xí)、思考、沉淀、凈化自己,讓我們?yōu)楦嗟钠髽I(yè)打造出實(shí)用型網(wǎng)站。
kubernetes,簡稱K8s,是用8代替8個字符“ubernete”而成的縮寫。是一個開源的,用于管理云平臺中多個主機(jī)上的容器化的應(yīng)用,Kubernetes的目標(biāo)是讓部署容器化的應(yīng)用簡單并且高效(powerful),Kubernetes提供了應(yīng)用部署,規(guī)劃,更新,維護(hù)的一種機(jī)制。
Kubelet是Kubernetes中最主要的控制器,它是Pod和Node API的主要實(shí)現(xiàn)者,Kubelet負(fù)責(zé)驅(qū)動容器執(zhí)行層。在Kubernetes中,應(yīng)用容器彼此是隔離的,并且與運(yùn)行其的主機(jī)也是隔離的,這是對應(yīng)用進(jìn)行獨(dú)立解耦管理的關(guān)鍵點(diǎn)。
Controller Manager:負(fù)責(zé)管理集群的各種資源,保證資源處于預(yù)期的狀態(tài)。它由多種Controller組成,包括Replication Controller、Endpoints Controller.
Namespace Controller、Serviceaccounts Controller等等。
Etcd:負(fù)責(zé)保存k8s集群的配置信息和各種資源的狀態(tài)信息。當(dāng)數(shù)據(jù)發(fā)生變化時,etcd會快速的通知k8s相關(guān)組件。第三方組件,它有可替換方案。Consul、 zookeeper
Pod: k8s集群的最小組成單位。一個Pod內(nèi),可以運(yùn)行一個或多個容器。大多數(shù)情況下,一個Pod內(nèi)只有一個Container容器。
Flanner:是k8s集群網(wǎng)路方案,可以保證Pod的跨主機(jī)通信。第三方解決方案,也有替換方案。
查看應(yīng)用在哪個節(jié)點(diǎn)
[root@master ~]# kubectl get pod --all-namespaces
查看應(yīng)用在哪個節(jié)點(diǎn)的詳細(xì)信息
[root@master ~]# kubectl get pod --all-namespaces -o wide
Kubeler:他是Node的agent(代理),當(dāng)Scheduler確定某個Node上運(yùn)行Pod之后,會將Pod的具體配置信息發(fā)送給該節(jié)點(diǎn)的Kubelet,Kubeler會根據(jù)這些信息創(chuàng)建和運(yùn)行容器,并向Master報告運(yùn)行狀態(tài)。
Kube-proxy:負(fù)責(zé)將訪問service的TCP/UDP數(shù)據(jù)流轉(zhuǎn)發(fā)到后端的容器。如果有多個副本,kube-proxy會實(shí)現(xiàn)負(fù)載均衡。
運(yùn)行一個例子:三臺都導(dǎo)入httpd鏡像導(dǎo)成docker鏡像
創(chuàng)建一個deployment資源對象。Pod控制器。
[root@master ~]# kubectl run test-web --image=httpd --replicas=2
查看節(jié)點(diǎn):
[root@master ~]# kubectl get deployments.
簡寫:
[root@master ~]# kubectl get deploy
[root@master ~]# kubectl get pod
哪臺dang掉重啟kuelet:
[root@master ~]# systemctl restart kubelet
[root@master ~]# kubectl get pod -o wide
刪除節(jié)點(diǎn):
[root@master ~]# kubectl delete pod test-web-5b56bdff65-j6g75
還是兩個:這就是控制器的原因
分析各個組件的作用以及架構(gòu)工作流程:
1)kubectl發(fā)送部署請求到API server
2)API server 通知Controller Manager創(chuàng)建一個Deployment資源
3)Scheduler執(zhí)行調(diào)度任務(wù),將兩個副本Pod分發(fā)到node01和node02上
4)node01和node02上的kubelet在各自節(jié)點(diǎn)上創(chuàng)建并運(yùn)行Pod。
補(bǔ)充:
1.應(yīng)用的配置和當(dāng)前的狀態(tài)信息保存在etcd中,執(zhí)行kubectl get pod時API server會從etcd中讀取這些數(shù)據(jù)。
2.flannel回味每個Pod分配一個IP。但此時沒有創(chuàng)建Service資源,目前kube-proxy還沒有參與進(jìn)來。
網(wǎng)頁題目:kubernetes架構(gòu)介紹
文章來源:http://chinadenli.net/article10/jgggdo.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供微信小程序、定制網(wǎng)站、網(wǎng)站改版、自適應(yīng)網(wǎng)站、網(wǎng)站維護(hù)、電子商務(wù)
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)