k8s(3)-Pods和Nodes的概念

   Pod是什麼?

    在前面建立部署時,Kubernetes建立了一個Pod來託管您的應用程序實例。Pod是一個Kubernetes抽象,表示一組一個或多個應用程序容器(如Docker或rkt),以及這些容器的一些共享資源。這些資源包括:node

  • 共享存儲,做爲卷
  • 網絡,做爲惟一的羣集IP地址
  • 有關如何運行每一個容器的信息,例如容器映像版本或要使用的特定端口

Pod爲特定於應用程序的「邏輯主機」建模,而且能夠包含相對緊密耦合的不一樣應用程序容器。例如,Pod可能既包含帶有Node.js應用程序的容器,也包含一個不一樣的容器,用於提供Node.js網絡服務器要發佈的數據。Pod中的容器共享IP地址和端口空間,始終位於同一位置並共同調度,並在同一節點上的共享上下文中運行。服務器

Pod是Kubernetes平臺上的原子單元。當咱們在Kubernetes上建立部署時,該部署會在其中建立包含容器的Pod(而不是直接建立容器)。每一個Pod都與調度它的節點綁定,並保持在那裏直到終止(根據重啓策略)或刪除。若是節點發生故障,則會在羣集中的其餘可用節點上調度相同的Pod。網絡

 

Pods概念圖


 

Nodes是什麼?

   

    Pod老是在節點上運行Node是Kubernetes中的工做機器,能夠是虛擬機器,也能夠是物理機器,具體取決於集羣。每一個節點由Master管理。節點能夠有多個pod,Kubernetes master會自動處理在羣集中的節點上調度pod。Master的自動調度考慮了每一個節點上的可用資源。spa

每一個Kubernetes節點至少運行:資源

  • Kubelet,負責Kubernetes Master和Node之間通訊的過程; 它管理Pod和機器上運行的容器。
  • 容器運行時(如Docker,rkt)負責從註冊表中提取容器映像,解壓縮容器以及運行應用程序。
 

相關文章
相關標籤/搜索