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

詳解kubernetes pod的編排和生命周期

 更新時(shí)間:2021年04月01日 10:29:39   作者:DBA隨筆  
這篇文章主要介紹了kubernetes pod的編排和生命周期的相關(guān)資料,幫助大家更好的理解和學(xué)習(xí)使用K8S,感興趣的朋友可以了解下

K8S Master基本架構(gòu)

      K8S的集群運(yùn)行依賴Master節(jié)點(diǎn)和Node節(jié)點(diǎn)的通信,為了更好的理解第4部分的Pod生命周期,我們這里先給出K8S Master的簡單架構(gòu)圖,后續(xù)的文章中,我們會分析Master、Node和Pod之間的關(guān)系。

Master的架構(gòu)圖:

其中:

API Server提供了HTTP Rest接口,它是k8s中的所有資源增刪改查的唯一入口,也是集群控制的入口;

Scheduler是負(fù)責(zé)資源調(diào)度的進(jìn)程;

Controller Manager是所有資源對象的自動化控制中心;

Etcd提供資源對象的數(shù)據(jù)保存服務(wù)

其中每個(gè)組件都有很多知識點(diǎn),這里我們只要有個(gè)宏觀的印象就可以了,后續(xù)的文章中,我們會逐一分析。

Pod的編排思想

     上一篇文章末尾,我們提到了應(yīng)用程序往k8s搬遷過程中的注意事項(xiàng)。這里重申一下,當(dāng)我們想要把虛擬機(jī)上的應(yīng)用程序搬遷到k8s中時(shí),我們需要用Pod來構(gòu)建我們應(yīng)用程序模塊。這個(gè)時(shí)候,比較重要的一點(diǎn)是劃分我們應(yīng)用程序模塊,因?yàn)槿萜骱吞摂M機(jī)的設(shè)計(jì)模式不同,但是為了更好的理解和對比這二者的關(guān)系,我們可以設(shè)想下面的對應(yīng)關(guān)系:

k8s-----操作系統(tǒng)

Pod----虛擬機(jī)

容器----進(jìn)程

1、k8s相當(dāng)于物理機(jī)的操作系統(tǒng),k8s管理Pod相當(dāng)于物理機(jī)的操作系統(tǒng)管理虛擬機(jī)

2、Pod相當(dāng)于虛擬機(jī),Pod里面可能包含多個(gè)容器,對應(yīng)于虛擬機(jī)中的很多進(jìn)程

3、容器相當(dāng)于進(jìn)程,容器的本質(zhì),其實(shí)就是一個(gè)進(jìn)程。

    有了這樣的概念,去理解Pod可能會更加形象。再說回我們的應(yīng)用程序遷移,假設(shè)我們的應(yīng)用程序存在:

web服務(wù)、日志分析、MySQL數(shù)據(jù)庫

三個(gè)關(guān)鍵的模塊,其中:

web服務(wù)和日志分析存在"超親密關(guān)系",因?yàn)槿罩痉治瞿K要消費(fèi)web服務(wù)模塊產(chǎn)生的日志,所以他們必須部署在同一個(gè)服務(wù)器上。反之、web服務(wù)和MySQL數(shù)據(jù)庫之間完全可以通過TCP-IP的方式來訪問,就沒有必要部署在同一臺機(jī)器上。如果我們用容器運(yùn)行這個(gè)應(yīng)用,那么web服務(wù)需要和日志分析模塊打包在同一個(gè)Pod中,而MySQL數(shù)據(jù)庫服務(wù)單獨(dú)部署在一個(gè)Pod中即可,我們的應(yīng)用程序遷移到k8s中,可能就是下面的結(jié)構(gòu):

將不同的進(jìn)程或者任務(wù),編排在同一個(gè)Pod中,這本質(zhì)上,就是Pod的一種編排思想

Pod對象的屬性和容器的屬性?

     從上面的分析中不難看出,容器是隸屬于Pod中的一個(gè)元素,從yaml文件上看,容器就是Pod的整個(gè)yaml文件中的一個(gè)字段?,F(xiàn)在我們看看Pod和容器有哪些重要屬性。

先看Pod的屬性:

1、凡是調(diào)度、網(wǎng)絡(luò)、存儲、安全相關(guān)的屬性,基本都是Pod相關(guān)的。

    調(diào)度,自然不用說,Pod是k8s的最小調(diào)度單元;網(wǎng)絡(luò),同一個(gè)Pod中的容器共享Pod的網(wǎng)絡(luò);存儲,可以通過Pod掛載卷的方式讓不同的容器共享Pod的存儲;安全,也是以Pod為維度來控制的。

2、凡是跟容器的Linux Namespace相關(guān)的屬性,也是Pod級別的。

    Pod的設(shè)計(jì)初衷,就是要容器之間共享Namespace。

3、凡是Pod中的容器要共享宿主機(jī)的Namespace,也一定是Pod級別的。

  這個(gè)更加容易理解,因?yàn)镻od要共享主機(jī)的Namespace,那么Pod中的容器必然是要共享相同的Namespace,所以這個(gè)設(shè)置一定是Pod級別的。

再看Container的2個(gè)重要屬性:

1、ImagePullPolicy:這個(gè)屬性定義了鏡像拉取的策略,它的默認(rèn)值是always,也就是每次創(chuàng)建Pod都拉取一次鏡像,它還有2個(gè)其他的取值,分別是never和ifnotpresent,這兩個(gè)比較容易理解,一種是從來不拉取鏡像,一種是只有在不存在鏡像的時(shí)候才拉取鏡像。這里需要注意一點(diǎn),如果我們的版本號配置的是latest這種的,那么ImagePullPolicy會被默認(rèn)值always。

2、Lifecycle:顧名思義,它是在容器的生命周期中執(zhí)行某些動作,它有兩個(gè)常見的參數(shù),分別是postStart和preStop,就是在容器開始后或者容器結(jié)束前執(zhí)行的一個(gè)特定操作。

Pod的生命周期

Pod的生命周期,主要體現(xiàn)在Pod的API的status部分,Pod的生命周期從開始到結(jié)束包含下面的幾個(gè)過程:

1、Pending,表示Pod的yaml文件已經(jīng)交給k8s,并且保存在etcd(etcd是k8s中的元信息庫)中了。但是它由于調(diào)度不成功等原因沒有被創(chuàng)建。

2、Running,這個(gè)詞語具有迷惑性,它表示Pod已經(jīng)調(diào)度成功,跟一臺具體的節(jié)點(diǎn)服務(wù)器綁定,Pod中的容器不一定全部都正常運(yùn)行了,但是至少有一個(gè)在運(yùn)行。

3、Succeeded,這個(gè)狀態(tài)意味著所有的容器都啟動完畢,并且已經(jīng)退出。

4、Failed,這個(gè)很好理解,就是Pod中的容器至少有一個(gè)以非0狀態(tài)退出,也就是異常退出了。

5、Unknow。這是一個(gè)異常狀態(tài),表示當(dāng)前Pod的狀態(tài)不能正常的匯報(bào)給kube-apiserver了,這可能是主從節(jié)點(diǎn)之間的通信有問題。

如下所示為一個(gè)狀態(tài)為running的Pod

[root@VM-16-13-centos ~]# kubectl get pod
NAME                                READY     STATUS             RESTARTS   AGE
mysql-pd7jr                         1/1       Running            0          118d
myweb-60r22                         1/1       Running            0          80d

[root@VM-16-13-centos ~]# 
[root@VM-16-13-centos ~]# kubectl get pod mysql-pd7jr -o yaml
apiVersion: v1
kind: Pod
metadata:
  ...
spec:
  ...
status:
  ...
  hostIP: 127.0.0.1
  phase: Running
  podIP: 172.17.0.2
  startTime: 2020-11-20T09:01:39Z

以上就是詳解kubernetes pod的編排和生命周期的詳細(xì)內(nèi)容,更多關(guān)于kubernetes pod的編排和生命周期的資料請關(guān)注腳本之家其它相關(guān)文章!

相關(guān)文章

  • K8S部署Kafka界面管理工具(kafkamanager)方法詳解

    K8S部署Kafka界面管理工具(kafkamanager)方法詳解

    這篇文章主要介紹了K8S部署Kafka界面管理工具(kafkamanager)方法詳解,需要的朋友可以參考下
    2022-01-01
  • Rainbond對前端項(xiàng)目Vue及React的持續(xù)部署

    Rainbond對前端項(xiàng)目Vue及React的持續(xù)部署

    這篇文章主要為大家介紹了Rainbond對前端項(xiàng)目Vue及React的持續(xù)部署,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-04-04
  • K8s實(shí)戰(zhàn)教程之容器和?Pods資源分配問題

    K8s實(shí)戰(zhàn)教程之容器和?Pods資源分配問題

    這篇文章主要介紹了K8s實(shí)戰(zhàn)教程之容器和?Pods資源分配,本篇文章通過配置集群中運(yùn)行的容器的?CPU?請求和限制,你可以有效利用集群上可用的?CPU?資源,通過將?Pod?CPU?請求保持在較低水平,可以使?Pod?更有機(jī)會被調(diào)度,需要的朋友可以參考下
    2022-07-07
  • 一文講解如何獲取k8s容器里運(yùn)行的jar包

    一文講解如何獲取k8s容器里運(yùn)行的jar包

    K8S是Google開源的容器集群管理系統(tǒng),其設(shè)計(jì)目標(biāo)是在主機(jī)集群之間提供一個(gè)能夠自動化部署、可拓展、應(yīng)用容器可運(yùn)營的平臺,這篇文章主要給大家介紹了關(guān)于如何獲取k8s容器里運(yùn)行的jar包的相關(guān)資料,需要的朋友可以參考下
    2022-09-09
  • Spark三種屬性配置方式詳解

    Spark三種屬性配置方式詳解

    有時(shí)間還是多學(xué)習(xí)知識比較好,這篇文章主要介紹了Spark三種屬性配置方式詳解,具有一定參考價(jià)值,需要的朋友可以了解下。
    2017-10-10
  • 如何使用Kubernetes自定義資源(CRD)詳解

    如何使用Kubernetes自定義資源(CRD)詳解

    自定義資源定義(CRD)是Kubernetes API擴(kuò)展,可以定義新的對象類型,下面這篇文章主要給大家介紹了關(guān)于如何使用Kubernetes自定義資源(CRD)的相關(guān)資料,需要的朋友可以參考下
    2022-09-09
  • 二進(jìn)制方式安裝?Kubernetes1.18.3版本實(shí)現(xiàn)腳本

    二進(jìn)制方式安裝?Kubernetes1.18.3版本實(shí)現(xiàn)腳本

    這篇文章主要為大家介紹了二進(jìn)制方式安裝Kubernetes1.18.3版本實(shí)現(xiàn)腳本,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-03-03
  • k8s中如何實(shí)現(xiàn)pod自動擴(kuò)縮容詳解

    k8s中如何實(shí)現(xiàn)pod自動擴(kuò)縮容詳解

    在實(shí)際生產(chǎn)系統(tǒng)中,經(jīng)常會遇到某個(gè)服務(wù)需要擴(kuò)容的場景,可能會遇到由于資源緊張或者工作負(fù)載降低而需要減少服務(wù)實(shí)例數(shù)量的場景,下面這篇文章主要給大家介紹了關(guān)于k8s中如何實(shí)現(xiàn)pod自動擴(kuò)縮容的相關(guān)資料,需要的朋友可以參考下
    2022-08-08
  • K8S部署lnmp項(xiàng)目全過程

    K8S部署lnmp項(xiàng)目全過程

    這篇文章主要介紹了K8S部署lnmp項(xiàng)目全過程,具有很好的參考價(jià)值,希望對大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2024-07-07
  • 詳解k8s?NetworkPolicy?網(wǎng)絡(luò)策略是怎么樣的

    詳解k8s?NetworkPolicy?網(wǎng)絡(luò)策略是怎么樣的

    這篇文章主要為大家介紹了k8s?NetworkPolicy?網(wǎng)絡(luò)策略是怎么樣的深入解析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-04-04

最新評論