什麼是 Kubernetes
Kubernetes 是一個集群管理系統,它擁有可移植、擴展和高可用等特性。它用於管理容器(container),然而容器的出現改變了佈署方式。容器類似於 VM 與主機共享內核(kernel),容器有自己的檔案系統(filesystem)、CPU、記憶體(memory)、進程空間(process space)等。因為它們與基礎架構分離,因此可以跨雲(公、私有或混合雲中)和作業系統進行移植。然而容器佈署的數量越多管理難度明顯的會提升,使用者必須對容器進行分組,並對其分配網路、監控或安全等服務。藉由 kubernetes 提供的編排和管理功能,以便完成大規模佈署,且 kubernetes 提供了資源調度、容器擴展等管理功能,這些的作用讓 kubernetes 可以管理容器應用程式的生命週期。
Kubernetes 架構
Kubernetes 匯集多個物理機、虛擬機將其變成一個集群。如下圖

- master
- 是用戶端與集群之間的核心聯絡重要位置
- 追蹤其它服務器的健康狀態
- 以最佳方式調度工作的負載
- 編排其它組件之間的任務
- node
- 集群中的工作節點,負責接收來自 master 的工作調度
- 創建或銷毀
POD - 調整網路好讓路由與轉發流量
- 創建或銷毀
- 集群中的工作節點,負責接收來自 master 的工作調度
- POD
Kubernetes中嘴小運算單元- 封裝多個容器
- 一個
POD中的容器共享namespace和儲存資源,但彼此又在mount、user、PID等名稱空間保持隔離
在 kubernetes 中有很多的組件會來支撐整個集群的運作邏輯,像是編排、暴露、恢復等,之後文章會慢慢的提到。
master 組件
API Server
負責輸出 RESTful 的 Kubernetes API,負責接收和驗證相關的請求,其狀態資源會被存入 etcd 中。
etcd
該 etcd 會確保生產環境的可用性。它會提供監聽的機制,用於推送和監聽變更。只要有發生變化便會與 API Server 溝通,並做出適當的動作向客戶端輸出。
Controller Manager
控制器完成的功能包括生命週期和 API 一些邏輯。
- 生命週期
namespace創建Event垃圾回收POD終止相關垃圾回收- 等等
- API
ReplicaSetDaemonSet- 等等
Scheduler
當 API Server 確認 POD 對象的建立請求後,需要由 Scheduler 根據集群內各節點的可用資源狀態,以及要運行的容器資源需求做出調度決策。總而言之就是幫助 API Server 尋找合適節點部署。
使用以下流程進行容器佈署
- Filtering
- 淘汰不適合的節點
- 可能從以下資源進行過濾
- CPU
- Memory
- GPU
- Scoring
- 進行加權,將過濾的節點進行,分數比較。可能是不要跟某節點一起等
- Deploying
- 從 scoring 選擇最高分數,並回傳
API Server由它處裡
- 從 scoring 選擇最高分數,並回傳
Node 組件
kubelete
運行於工作節點之上的一個進程,從 API Server 接收關於 POD 對象的配置訊息並確保處於期望的狀態。同時也會向 master 報告節點資源狀態。kubelet 依賴於 CRI 來創建容器。
kube-proxy
工作節點的進程,按需為 Service 資源對象生成 iptables 或 ipvs 規則,進而擷取存取當前 Service 的 ClusterIP 的流量並將其轉發至正確的 POD 上。總而言之網路部分由它負責。
Container-runtime
- CRI
- 抽象的,因為能運行的容器不只有
Docker,而每個容器的設計都不一樣。
- 抽象的,因為能運行的容器不只有
- 負責建立 container
其他
- CoreDNS
- 用於服務發現和註冊的動態名稱解析服務
- Prometheus
- 資源監控
- Ingress Controller
- 負載均衡器,實現在第七層