欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

k8s中容器創(chuàng)建的全過(guò)程實(shí)踐

 更新時(shí)間:2025年07月04日 09:23:26   作者:愛(ài)吃芝麻湯圓  
這篇文章主要介紹了k8s中容器創(chuàng)建的全過(guò)程,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教

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ù)解析

    Kubernetes k8s configmap 容器技術(shù)解析

    這篇文章主要為大家介紹了k8s configmap 容器技術(shù)解析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-08-08
  • Kubernetes應(yīng)用服務(wù)質(zhì)量管理詳解

    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ù)部署

    這篇文章主要為大家介紹了Rainbond對(duì)前端項(xiàng)目Vue及React的持續(xù)部署,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-04-04
  • 虛擬化技術(shù)概述 虛擬機(jī)安裝與管理手冊(cè)

    虛擬化技術(shù)概述 虛擬機(jī)安裝與管理手冊(cè)

    這篇文章主要為大家詳細(xì)介紹了虛擬化技術(shù)原理,如何安裝與管理虛擬機(jī)virt-manger,virsh等,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2016-10-10
  • Rainbond應(yīng)用分享與發(fā)布官方文檔說(shuō)明

    Rainbond應(yīng)用分享與發(fā)布官方文檔說(shuō)明

    這篇文章主要為大家介紹了Rainbond應(yīng)用分享與發(fā)布的官方文檔說(shuō)明,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-04-04
  • kubectl?命令詳解

    kubectl?命令詳解

    這篇文章主要介紹了kubectl?命令的相關(guān)資料,包括常用命令,基本命令和使用說(shuō)明,本文給大家介紹的非常詳細(xì),感興趣的朋友一起看看吧
    2025-04-04
  • kubernetes之statefulset搭建MySQL集群

    kubernetes之statefulset搭建MySQL集群

    這篇文章主要為大家介紹了kubernetes之statefulset搭建MySQL集群示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-04-04
  • K8S?使用EFK日志的統(tǒng)一管理(詳細(xì)步驟)

    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)控方式詳解

    這篇文章主要介紹了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)詳解

    這篇文章主要為大家介紹了Google?Kubernetes?Engine?集群實(shí)戰(zhàn)詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-08-08

最新評(píng)論