k8s學習 - 概念 - master/node

k8s學習 - 概念 - master/node

在k8s中,有各類各樣的概念和術語。這些概念是必需要學習和掌握的。咱們先羅列下全部概念,而後再一個個看具體實例。html

大概說一下這些概念:node

  • Master: k8s的主控組件,對應的對象是node。
  • Node: 是k8s集羣的機器節點,至關於master-node。一個node就對應一個具體的物理機或者虛擬機。
  • Container: 是一個鏡像容器,一個container是一個鏡像實例
  • Pod: 是k8s集羣的最小單元,一個pod能夠包含一個或者多個container
  • Service: 多個相同的pod組成一個服務,統一對外提供服務。
  • Volume: 存儲卷,pod對外暴露的共享目錄,它能夠掛載在宿主機上,這樣就能讓同node上多個pod共享一個目錄。
  • Replication Controller: 用於控制pod集羣的控制器,能夠制定各類規則來讓它控制一個service中的多個pod的建立和消亡, 不少地方簡稱爲rc。
  • Namespace: 命名空間,用於將一個k8s集羣隔離成不一樣的空間,pod, service, rc, volume 均可以在建立的時候指定其namespace。
  • StatefulSet: 有狀態集羣,好比一個主從的mysql集羣就是有狀態集羣,須要先啓動主再啓動從,這就是一種有狀態的集羣。
  • Persistent Volume: 持久存儲卷。以前說的volume是掛載在一個pod上的,多個pod(非同node)要共享一個網絡存儲,就須要使用持久存儲卷,簡稱爲pv。
  • Persistent Volume Claim: 持久存儲卷聲明。他是爲了聲明pv而存在的,一個持久存儲,先申請空間,再申明,才能給pod掛載volume,簡稱爲pvc。
  • Label: 標籤。咱們能夠給大部分對象概念打上標籤,而後能夠經過selector進行集羣內標籤選擇對象概念,並進行後續操做。
  • Secret: 私密憑證。密碼保存在pod中實際上是不利於分發的。k8s支持咱們建立secret對象,並將這個對象打到pod的volume中,pod中的服務就以文件訪問的形式獲取密鑰。
  • EndPoint: 用於記錄 service 和 pod 訪問地址的對應關係。只有 service 配置了 selector, endpoint controller 纔會自動建立endpoint對象。

若是不理解沒啥關係,看一遍有印象下,下面咱們一個個琢磨琢磨。mysql

master

k8s的master節點上有三個進程,它們都是以docker的形式存在的。咱們在k8s的master節點看docker ps 就能夠看到這幾個進程:sql

8824aad1ee95        e851a7aeb6e8                     "kube-apiserver --ad…"   3 days ago          Up 3 days                               k8s_kube-apiserver_kube-apiserver-docker-for-desktop_kube-system_f23c0965aad6df9f61b1c9c4bb953cf5_0
a9ce81ec9454        978cfa2028bf                     "kube-controller-man…"   3 days ago          Up 3 days                               k8s_kube-controller-manager_kube-controller-manager-docker-for-desktop_kube-system_1dc44822f21a9cbd68cc62b1a4684801_0
85da3f6e700f        d2c751d562c6                     "kube-scheduler --ad…"   3 days ago          Up 3 days                               k8s_kube-scheduler_kube-scheduler-docker-for-desktop_kube-system_b6155a27330304c86badfef38a6b483b_0

其中的 apiserver 是提供 k8s 的 rest api 服務的進程。固然它也包括了 restapi 的權限認證機制。 k8s 的 apiserver 提供了三種權限認證機制:docker

  • https
  • http + token
  • http + base(username + password)

咱們也能夠經過使用kubectl proxy 在 master 上來建立一個代理,從而外部能夠訪問這個 k8s 集羣。api

kube-controller-manager 是用來管理全部的 controller 的。以前咱們說的 Replication Controller 就是一種管控 Pod 副本的Controller, 其餘相關的 Controller 還有:網絡

  • Replication Controller
  • Node Controller: 實時獲取Node的相關信息,實現管理和監控集羣中的各個Node節點的相關控制功能
  • ResourceQuota Controller: 確保指定的資源對象在任什麼時候候都不會超量佔用系統物理資源
  • NameSpace Controller: 定時經過API Server讀取這些Namespace信息
  • ServiceAccount Controller: 監聽Service變化,若是是一個LoadBalancer類型的Service,則確保外部的雲平臺上對該Service對應的LoadBalancer實例被相應地建立、刪除及更新路由轉發表
  • Token Controller
  • Service Controller
  • EndPoint Controller : Service 和選擇 Pod 的對應關係。

kube-scheduler 負責 Pod 調度,接收 Controller Manager 建立的新的Pod,爲其選擇一個合適的Node,而且在Node上建立Pod。學習

一個k8s集羣只有一個master節點,因此 master 節點的高可用性是一個問題,一旦 master 節點掛了,整個集羣也就掛了。這點真有點神奇。因此網上關於搭建高可用的k8s Master 節點的方案有不少:spa

https://jishu.io/kubernetes/kubernetes-master-ha/
https://blog.51cto.com/ylw6006/2164981
https://jimmysong.io/kubernetes-handbook/practice/master-ha.html命令行

Node

Node 是 k8s 的工做節點,Node 通常是一個虛擬機或者物理機,每一個 node 上都運行三個服務:

  • docker
  • kubelet
  • kube-proxy

docker 就是 docker server,它提供

kubelet 是一個管理系統,它管理本個node上的容器的生命週期。它主要功能就是定時從某個地方獲取節點上pod/container的指望狀態,並調用對應的容器平臺接口,來達成這個狀態。它能夠設置 http 監控,命令行監控等方式。

kube-proxy 是管理 service 的訪問入口,包括集羣內 pod 到 service 的訪問,以及集羣外訪問service。

可用性

其實k8s自身的可用性是比較弱的,若是master掛了,那麼master上的三個服務也就掛了。node掛了,若是node上的pod是被 controller控制住的話,controller會在其餘node上啓動對應的pod。

相關文章
相關標籤/搜索