K8S學(xué)習(xí)筆記之Pod

什么是K8S:Kubernetes是容器集群管理系統(tǒng),是一個(gè)開(kāi)源的平臺(tái)(系統(tǒng)OS,平臺(tái)Platform)。
可以做什么:可以實(shí)現(xiàn)容器集群的自動(dòng)化部署、自動(dòng)擴(kuò)縮容、維護(hù)等功能。

什么是Pod
Pod是K8S最小的管理單位,一個(gè)Pod代表容器集群上正在運(yùn)行的一個(gè)進(jìn)程。
一個(gè)Pod封裝一個(gè)應(yīng)用容器,存儲(chǔ)資源、一個(gè)獨(dú)立的網(wǎng)絡(luò)IP以及管理控制的策略。

Pod和容器的關(guān)系:
1:1個(gè)pod對(duì)應(yīng)一個(gè)容器,K8s最常見(jiàn)的關(guān)系。在這種情況下,可以將pod視為容器,但是K8s是通過(guò)Pod來(lái)管理,而不是通過(guò)容器來(lái)管理。
2: 1個(gè)pod對(duì)應(yīng)多個(gè)容器。這種情況下,Pod變成了Service,來(lái)管理多個(gè)容器之間的關(guān)系和資源,多個(gè)容器之間可以共享資源。(選修,高級(jí)用法)

每個(gè)Pod都是運(yùn)行應(yīng)用(應(yīng)用級(jí)別Application)的單個(gè)實(shí)例,如果需要水平擴(kuò)展,則應(yīng)該使用多個(gè)Pods,以使Pod和實(shí)例呈現(xiàn)一一對(duì)應(yīng)的關(guān)系。水平擴(kuò)展的Pod在K8s里通常稱(chēng)為Replication(復(fù)制的集合)。Replication的Pod通常由Controller創(chuàng)建和管理。

Pod的網(wǎng)絡(luò)和存儲(chǔ):
1個(gè)Pod對(duì)應(yīng)一個(gè)容器時(shí),IP和網(wǎng)絡(luò)資源都是唯一的。對(duì)應(yīng)多個(gè)容器時(shí),IP也是唯一的,但是網(wǎng)絡(luò)資源是共享的,要注意協(xié)調(diào)資源,避免端口沖突。
對(duì)應(yīng)一個(gè)容器時(shí),存儲(chǔ)是獨(dú)立的。多個(gè)容器時(shí),可以指定共享目錄,避免Pod重啟,數(shù)據(jù)丟失。

Pod的生命周期:
Pod被創(chuàng)建后,會(huì)被K8s調(diào)度到集群的Node上,直到Pod的進(jìn)程終止(被刪掉,被驅(qū)逐,故障,執(zhí)行完畢)都會(huì)在Node上。
Pod不會(huì)自愈,如果出現(xiàn)故障,就會(huì)被刪除。K8s雖然可以直接管理Pod,但是抽象出了一層Controller來(lái)對(duì)Pod進(jìn)行管理。

Pod和Controller的關(guān)系:
Controller創(chuàng)建和管理多個(gè)Pod,提供副本管理(Replication)、滾動(dòng)升級(jí)和集群級(jí)別的自愈能力。例如,如果一個(gè)Node故障,Controller就能自動(dòng)將該節(jié)點(diǎn)的Pod調(diào)度到其他健康的Node上。
Controller示例:Deployment,StatefulSet,DaemonSet,通常,Controller是根據(jù)Pod Template來(lái)創(chuàng)建響應(yīng)的Pod。(Pod template:是包含了其他對(duì)象(如Replication Controllers,Jobs和Daemon Sets)中的Pod定義)

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請(qǐng)結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡(jiǎn)書(shū)系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容