k8s中容器創(chuàng)建的全過(guò)程實(shí)踐
Kubernetes 中容器創(chuàng)建的全流程
1. 調(diào)度器選擇節(jié)點(diǎn)
- 資源評(píng)估:Kubernetes 調(diào)度器評(píng)估所有候選節(jié)點(diǎn)的資源狀態(tài),包括 CPU、內(nèi)存、存儲(chǔ)空間等,確保節(jié)點(diǎn)有足夠的資源支持 Pod 的運(yùn)行。
- 調(diào)度策略:根據(jù)預(yù)設(shè)的調(diào)度策略(如節(jié)點(diǎn)親和性、污點(diǎn)和容忍度、反親和性等),選擇一個(gè)最合適的節(jié)點(diǎn)。
- 存儲(chǔ)考慮:確保所選節(jié)點(diǎn)能夠支持 Pod 的存儲(chǔ)需求,如是否有足夠的存儲(chǔ)空間或支持特定存儲(chǔ)類。
2. Kubelet 接收請(qǐng)求
- 節(jié)點(diǎn) Kubelet:選定節(jié)點(diǎn)上的 Kubelet 接收創(chuàng)建 Pod 的請(qǐng)求。
- 預(yù)檢和準(zhǔn)備:Kubelet 執(zhí)行一系列預(yù)檢,確保節(jié)點(diǎn)狀態(tài)正常,資源可用,并為創(chuàng)建 Pod 做準(zhǔn)備,包括獲取 Pod 的詳細(xì)配置和鏡像信息。
3. CRI 請(qǐng)求處理
- CRI 接口調(diào)用:Kubelet 通過(guò)容器運(yùn)行時(shí)接口(CRI)向容器運(yùn)行時(shí)(如 containerd、Docker 等)發(fā)起創(chuàng)建 Pod 的請(qǐng)求。
- CRI 適配層:CRI 適配層(CRI shim)將標(biāo)準(zhǔn)化的 CRI 請(qǐng)求轉(zhuǎn)換為具體容器運(yùn)行時(shí)能夠識(shí)別的指令,確保不同容器運(yùn)行時(shí)之間的兼容性。
4. CSI 插件介入
- 插件發(fā)現(xiàn):Kubelet 發(fā)現(xiàn)已注冊(cè)的 CSI 插件,確定可用的存儲(chǔ)卷類型和操作。
- 存儲(chǔ)卷創(chuàng)建:根據(jù) Pod 的存儲(chǔ)需求,CSI 插件動(dòng)態(tài)創(chuàng)建存儲(chǔ)卷。如果 Pod 使用了 PersistentVolumeClaims(PVC),CSI 插件會(huì)根據(jù)存儲(chǔ)類(StorageClass)創(chuàng)建相應(yīng)的 PersistentVolumes(PV)。
- 卷綁定:CSI 插件將創(chuàng)建的存儲(chǔ)卷綁定到目標(biāo)節(jié)點(diǎn),確保 Pod 可以訪問(wèn)該卷。
- 卷掛載:CSI 插件將存儲(chǔ)卷掛載到 Pod 的文件系統(tǒng)中,確保存儲(chǔ)資源可供 Pod 內(nèi)的容器使用。
- 生命周期管理:CSI 插件管理存儲(chǔ)卷的生命周期,包括創(chuàng)建、綁定、掛載、解綁和刪除,確保存儲(chǔ)資源的高效利用和安全回收。
5. Pod Sandbox 創(chuàng)建與網(wǎng)絡(luò)命名空間處理
- 網(wǎng)絡(luò)命名空間創(chuàng)建:容器運(yùn)行時(shí)創(chuàng)建網(wǎng)絡(luò)命名空間,確保 Pod 的網(wǎng)絡(luò)隔離。每個(gè) Pod 擁有獨(dú)立的網(wǎng)絡(luò)命名空間,包括自己的網(wǎng)絡(luò)接口、路由表和防火墻規(guī)則。
- Pod Sandbox 創(chuàng)建:容器運(yùn)行時(shí)根據(jù)指令創(chuàng)建 Pod Sandbox,為 Pod 內(nèi)的所有容器提供一個(gè)共享的運(yùn)行環(huán)境。在 Linux 環(huán)境下,這表現(xiàn)為一個(gè)命名空間;在 Hypervisor 環(huán)境下,則可能是一個(gè)虛擬機(jī)。Sandbox 的作用是隔離 Pod 的網(wǎng)絡(luò)和文件系統(tǒng),保證 Pod 內(nèi)容器之間的獨(dú)立運(yùn)行。
6. CNI 插件執(zhí)行網(wǎng)絡(luò)配置
- 調(diào)用 CNI 插件:如果 Kubelet 配置了 CNI 插件,在 Pod Sandbox 的網(wǎng)絡(luò)命名空間創(chuàng)建完成后,Kubelet 會(huì)調(diào)用對(duì)應(yīng)的 CNI 插件進(jìn)行網(wǎng)絡(luò)配置。
- 網(wǎng)絡(luò)設(shè)備配置:CNI 插件創(chuàng)建虛擬網(wǎng)卡(如 veth 對(duì)),并將這些虛擬網(wǎng)卡加入到相應(yīng)的網(wǎng)絡(luò)空間中。這包括設(shè)置網(wǎng)絡(luò)設(shè)備的參數(shù),如 MTU(最大傳輸單元)、MAC 地址等。
- IP 地址分配:CNI 插件調(diào)用 IP 地址管理(IPAM)插件為 Pod 分配 IP 地址。IPAM 插件根據(jù)預(yù)設(shè)的規(guī)則(如靜態(tài)分配、DHCP 分配等)為 Pod 分配合適的 IP 地址,確保 Pod 能夠與其他服務(wù)和節(jié)點(diǎn)進(jìn)行通信。
- 網(wǎng)絡(luò)連接:CNI 插件配置 Pod 的網(wǎng)絡(luò)連接,包括設(shè)置默認(rèn)網(wǎng)關(guān)、路由規(guī)則和防火墻策略,確保 Pod 能夠訪問(wèn)集群內(nèi)部和外部的網(wǎng)絡(luò)資源。
7. Container Runtime 管理
- 生命周期管理:容器運(yùn)行時(shí)負(fù)責(zé) Pod Sandbox 的整個(gè)生命周期管理,包括創(chuàng)建、啟動(dòng)和停止。容器運(yùn)行時(shí)確保 Pod Sandbox 在節(jié)點(diǎn)故障或維護(hù)時(shí)能夠正確停止和恢復(fù)。
- 資源隔離與管理:容器運(yùn)行時(shí)提供資源隔離和進(jìn)程管理功能,限制 Pod 對(duì)系統(tǒng)資源(如 CPU、內(nèi)存、磁盤 I/O 等)的使用,確保各個(gè) Pod 之間不會(huì)相互干擾。例如,使用 Linux cgroup 進(jìn)行資源限制和隔離。
- 日志和監(jiān)控:容器運(yùn)行時(shí)記錄 Pod 的運(yùn)行日志,提供實(shí)時(shí)監(jiān)控?cái)?shù)據(jù),幫助用戶了解 Pod 的運(yùn)行狀態(tài)和性能。
8. 啟動(dòng) Pod 內(nèi)其他容器
- 啟動(dòng)業(yè)務(wù)容器:在完成網(wǎng)絡(luò)和存儲(chǔ)配置后,容器運(yùn)行時(shí)啟動(dòng) Pod 內(nèi)的業(yè)務(wù)容器。這些容器共享 Pause 容器創(chuàng)建的網(wǎng)絡(luò)命名空間,實(shí)現(xiàn) Pod 內(nèi)容器間的通信。
- 存儲(chǔ)卷掛載:確保所有業(yè)務(wù)容器能夠訪問(wèn) CSI 插件掛載的存儲(chǔ)卷,確保存儲(chǔ)資源在 Pod 內(nèi)容器之間共享和隔離。
- 容器健康檢查:容器運(yùn)行時(shí)執(zhí)行健康檢查,確保所有容器正常啟動(dòng)并運(yùn)行。健康檢查包括存活探針(Liveness Probe)和就緒探針(Readiness Probe),幫助 Kubernetes 確定容器是否健康并準(zhǔn)備好接受流量。
9. 結(jié)果反饋和狀態(tài)更新
- 處理結(jié)果返回:容器運(yùn)行時(shí)將整個(gè)處理結(jié)果(包括 Pod Sandbox 創(chuàng)建狀態(tài)、網(wǎng)絡(luò)配置結(jié)果、存儲(chǔ)卷掛載狀態(tài)、容器啟動(dòng)狀態(tài)等)返回給 Kubelet。
- 狀態(tài)更新:Kubelet 將 Pod 的創(chuàng)建狀態(tài)更新到 Kubernetes API Server,確保集群狀態(tài)的一致性。API Server 將狀態(tài)變化通知其他組件,如調(diào)度器和控制器管理器,以便進(jìn)行相應(yīng)的資源管理和負(fù)載均衡調(diào)整。
- 錯(cuò)誤處理和重試:如果在創(chuàng)建過(guò)程中出現(xiàn)錯(cuò)誤(如存儲(chǔ)卷掛載失敗、網(wǎng)絡(luò)配置異常等),Kubelet 會(huì)記錄錯(cuò)誤信息,并根據(jù)配置的重試策略進(jìn)行重試或標(biāo)記 Pod 為失敗狀態(tài),觸發(fā)故障恢復(fù)機(jī)制。
10. 故障恢復(fù)和自愈
- 錯(cuò)誤檢測(cè):Kubernetes 監(jiān)控組件(如 kubelet、kube-controller-manager)持續(xù)監(jiān)控 Pod 的狀態(tài),檢測(cè)是否出現(xiàn)故障。
- 自動(dòng)重啟和重調(diào)度:如果 Pod 運(yùn)行失敗或節(jié)點(diǎn)出現(xiàn)故障,Kubernetes 會(huì)自動(dòng)重啟 Pod 或?qū)⑵渲卣{(diào)度到其他健康的節(jié)點(diǎn),確保服務(wù)的高可用性。
- 日志和監(jiān)控分析:通過(guò)集成的日志和監(jiān)控系統(tǒng)(如 ELK Stack、Prometheus、Grafana),用戶可以分析 Pod 創(chuàng)建和運(yùn)行過(guò)程中的日志和指標(biāo),快速定位和解決問(wèn)題。
總結(jié)
以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
Kubernetes k8s configmap 容器技術(shù)解析
這篇文章主要為大家介紹了k8s configmap 容器技術(shù)解析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-08-08
Kubernetes應(yīng)用服務(wù)質(zhì)量管理詳解
這篇文章主要為大家介紹了Kubernetes應(yīng)用服務(wù)質(zhì)量管理詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-11-11
Rainbond對(duì)前端項(xiàng)目Vue及React的持續(xù)部署
這篇文章主要為大家介紹了Rainbond對(duì)前端項(xiàng)目Vue及React的持續(xù)部署,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-04-04
虛擬化技術(shù)概述 虛擬機(jī)安裝與管理手冊(cè)
這篇文章主要為大家詳細(xì)介紹了虛擬化技術(shù)原理,如何安裝與管理虛擬機(jī)virt-manger,virsh等,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2016-10-10
Rainbond應(yīng)用分享與發(fā)布官方文檔說(shuō)明
這篇文章主要為大家介紹了Rainbond應(yīng)用分享與發(fā)布的官方文檔說(shuō)明,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-04-04
kubernetes之statefulset搭建MySQL集群
這篇文章主要為大家介紹了kubernetes之statefulset搭建MySQL集群示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-04-04
K8S?使用EFK日志的統(tǒng)一管理(詳細(xì)步驟)
在Kubernetes中,EFK是一種常見(jiàn)的日志統(tǒng)一管理方案,EFK堆棧允許你收集、存儲(chǔ)、搜素、分析和可視化容器應(yīng)用程序的日志,下面是如何在Kubernetes中使用EFK實(shí)現(xiàn)日志統(tǒng)一管理的詳細(xì)步驟,感興趣的朋友一起看看吧2025-01-01
kubernetes(k8s)安裝metrics-server實(shí)現(xiàn)資源使用情況監(jiān)控方式詳解
這篇文章主要介紹了kubernetes(k8s)安裝metrics-server實(shí)現(xiàn)資源使用情況監(jiān)控,包括Metrics?Server下載方式,?k8s集群安裝部署metrics的問(wèn)題,本文給大家介紹的非常詳細(xì),需要的朋友可以參考下2022-04-04
Google?Kubernetes?Engine?集群實(shí)戰(zhàn)詳解
這篇文章主要為大家介紹了Google?Kubernetes?Engine?集群實(shí)戰(zhàn)詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-08-08

