【2】Kubernetes 架構總覽

Kubernetes 架構總覽

主節點與工作節點

主節點

Kubernetes 的主節點(Master)是組成集群控制平面的關鍵部分,負責整個集群的調度、狀態管理和決策。控制平面由多個核心組件構成,包括:

  • kube-apiserver:集群的通信中心,所有組件和用戶請求都要經過它API Server通過443端口對外提供
    RESTful風格的接口。
  • kube-controller-manager:負責各種控制循環,如副本控制、節點狀態監控等(注意,這里有非常多的不同功能的controller被管理,例如Replication Controller,Deployment Controller)
  • kube-scheduler:負責將新創建的 Pod 調度到合適的工作節點上
  • etcd:用于保存所有集群狀態數據的分布式數據庫。(所有控制組件的狀態數據都存儲在 etcd 中,它是整個 Kubernetes 的“單一數據源”。
    主節點

一種最簡單的部署方式是將這些控制組件部署在同一臺主機上,這適合實驗或測試環境。而在生產環境中,主節點的高可用部署是必不可少的。

通常建議使用 3 或 5 個主節點副本來實現高可用。

(為什么是奇數個?🤔)

因為控制平面依賴 etcd 數據庫,而 etcd 的一致性機制需要多數派(quorum)投票。使用奇數個副本可以有效避免腦裂,保證集群穩定性。

工作節點

工作節點

它是Kubernetes集群中的工作者。從整體上看,工作節點主要負責監聽API Server分派的新任務,執行這些任務,向控制平面回復任務執行的結果(通過API Server),那么他的主要組件如下:

  • kubelet:與控制平面通信,監聽API Server分派的新任務,接收任務并管理本節點的 Pod;
  • kube-proxy:維護網絡規則(iptables/ipvs)和服務的負載均衡;
  • 容器運行時(如 containerd):用于真正運行容器。
  • Kubernetes DNS:Kubernetes集群自己內部的DNS服務,這對于集群操作也是非常重要的。

集群DNS服務有一個靜態IP地址,并且這個IP地址集群總每個Pod上都是硬編碼的,這意味著每個容器以及Pod都能找到DNS服務。每個新服務都會自動注冊到集群DNS服務上,這樣所有集群中的組件都能根據名稱找到相應的服務。一些其他的組件也會注冊到集群DNS服務,例如Statefulset以及由Statefulset管理的獨立Pod。

它是基于CoreDNS來實現的。

工作節點

一般來說,工作節點就是運行的我們的各種服務,當然也包含工作節點專屬的組件(kubeletkube-proxy、容器運行時)。

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/bicheng/77676.shtml
繁體地址,請注明出處:http://hk.pswp.cn/bicheng/77676.shtml
英文地址,請注明出處:http://en.pswp.cn/bicheng/77676.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

如何對docker鏡像存在的gosu安全漏洞進行修復——筑夢之路

這里以mysql的官方鏡像為例進行說明,主要流程為: 1. 分析鏡像存在的安全漏洞具體是什么 2. 根據分析結果有針對性地進行修復處理 3. 基于當前鏡像進行修復安全漏洞并復核驗證 # 鏡像地址mysql:8.0.42 安全漏洞現狀分析 dockerhub網站上獲取該鏡像的…

【Tauri2】026——Tauri+Webassembly

前言 不多廢話 直言的說,筆者看到這篇文章大佬的文章 【04】Tauri 入門篇 - 集成 WebAssembly - 知乎https://zhuanlan.zhihu.com/p/533025312嘗試集成一下WebAssembly,直接開始 正文 準備工作 新建一個項目 安裝 vite的rsw插件和rsw pnpm instal…

OpenHarmony Camera開發指導(五):相機預覽功能(ArkTS)

預覽是在相機啟動后實時顯示場景畫面,通常在拍照和錄像前執行。 開發步驟 創建預覽Surface 如果想在屏幕上顯示預覽畫面,一般由XComponent組件為預覽流提供Surface(通過XComponent的getXcomponentSurfaceId方法獲取surfaceid)&…

puzzle(0531)腦力航跡

目錄 腦力航跡 規則 解法 簡單模式 中等模式 困難模式 專家模式 腦力航跡 規則 2條航跡會產生一個相對航跡: 根據相對航跡和其中一個航跡推導另外一個航跡。 解法 沒有任何需要推理的地方,就是純粹的2個矢量相加。 簡單模式 中等模式 困難模…

在win上安裝Ubuntu安裝Anaconda(linx環境)

一,安裝Ubuntu 1. 在 Microsoft 商城去下載Ubuntu(LTS:是長期維護的版本) 2.安裝完之后啟動程序,再重新打開一個黑窗口: wsl --list --verbose 3.關閉Ubuntu wsl --shutdown Ubuntu-22.04 WSL2 Ubuntu-20.04文件太占c盤空間,…

NEAT 算法解決 Lunar Lander 問題:從理論到實踐

NEAT 算法解決 Lunar Lander 問題:從理論到實踐 0. 前言1. 定義環境2. 配置 NEAT3. 解決 Lunar lander 問題小結系列鏈接0. 前言 在使用 NEAT 解決強化學習問題一節所用的方法只適用于較簡單的強化學習 (reinforcement learning, RL) 環境。在更復雜的環境中使用同樣的進化解…

【KWDB 創作者計劃】_上位機知識篇---ESP32-S3Arduino

文章目錄 前言1. ESP32-S3核心特性2. 開發環境搭建(1) 安裝Arduino IDE(2) 添加ESP32-S3支持(3) 選擇開發板(4) 關鍵配置3. 基礎代碼示例(1) 串口通信(USB/硬件串口)(2) Wi-Fi連接(3) 藍牙LE廣播4. 高級功能開發(1) USB OTG功能(2) AI加速(MicroTensorFlow)(3) 雙核任務處理…

JavaScript學習教程,從入門到精通,DOM節點操作語法知識點及案例詳解(21)

DOM節點操作語法知識點及案例詳解 一、語法知識點 1. 獲取節點 // 通過ID獲取 const element document.getElementById(idName);// 通過類名獲取(返回HTMLCollection) const elements document.getElementsByClassName(className);// 通過標簽名獲取…

PCA 降維實戰:從原理到電信客戶流失數據應用

一、簡介 在機器學習領域,數據的特征維度往往較高,這不僅會增加計算的復雜度,還可能導致過擬合等問題。主成分分析(Principal Component Analysis,簡稱 PCA)作為一種經典的降維技術,能夠在保留數…

信創時代編程開發語言選擇指南:國產替代背景下的技術路徑與實踐建議

🧑 博主簡介:CSDN博客專家、CSDN平臺優質創作者,高級開發工程師,數學專業,10年以上C/C, C#, Java等多種編程語言開發經驗,擁有高級工程師證書;擅長C/C、C#等開發語言,熟悉Java常用開…

Arcgis10.1的漢化包及破解文件分享

Arcgis10.1的漢化包分享 網上有好多10.2的漢化包,但是10.1的漢化包很少,特在此分析出來給大家 Arcgis10.1破解文件及漢化包: (訪問密碼: 9784) license manager破解安裝文件 另外也分享了license manager破解安裝文件,也在相同的分享鏈接里…

CrewAI Community Version(一)——初步了解以及QuickStart樣例

目錄 1. CrewAI簡介1.1 CrewAI Crews1.2 CrewAI Flows1.3 Crews和Flows的使用情景 2. CrewAI安裝2.1 安裝uv2.2 安裝CrewAI CLI 3. 官網QuickStart樣例3.1 創建CrewAI Crews項目3.2 項目結構3.3 .env3.4 智能體角色及其任務3.4.1 agents.yaml3.4.2 tasks.yaml 3.5 crew.py3.6 m…

word選中所有的表格——宏

Sub 選中所有表格()Dim aTable As TableApplication.ScreenUpdating FalseActiveDocument.DeleteAllEditableRanges wdEditorEveryoneFor Each aTable In ActiveDocument.TablesaTable.Range.Editors.Add wdEditorEveryoneNextActiveDocument.SelectAllEditableRanges wdEdito…

Tkinter與ttk模塊對比:構建現代 Python GUI 的進化之路

在 Python GUI 開發中,標準庫 tkinter 及其子模塊 ttk(Themed Tkinter)常被同時使用。本文通過功能對比和實際案例,簡單介紹這兩個模塊的核心差異。 1. 區別 Tkinter:Python 標準 GUI 工具包(1994年集成&…

Linux系統之部署Dillinger個人文本編輯器

Linux系統之部署Dillinger個人文本編輯器 一、Dillinger介紹1.1 Dillinger簡介1.2 Dillinger特點1.3 使用場景二、本地環境介紹2.1 本地環境規劃2.2 本次實踐介紹三、檢查本地環境3.1 檢查本地操作系統版本3.2 檢查系統內核版本四、部署Node.js 環境4.1 下載Node.js安裝包4.2 解…

從malloc到free:動態內存管理全解析

1.為什么要有動態內存管理 我們已經掌握的內存開辟方法有: int main() {int val 20;//在棧空間上開辟四個字節char arr[20] { 0 };//在棧空間上開辟10個字節的連續空間return 0; }上述開辟的內存空間有兩個特點: 1.空間開辟的時候大小已經固定 2.數組…

健身房管理系統設計與實現(springboot+ssm+vue+mysql)含萬字詳細文檔

健身房管理系統設計與實現(springbootssmvuemysql)含萬字詳細文檔 健身房管理系統是一個全面的解決方案,旨在幫助健身房高效管理日常運營。系統主要功能模塊包括個人中心、會員管理、員工管理、會員卡管理、會員卡類型管理、教練信息管理、解聘管理、健身項目管理、…

seate TCC模式案例

場景描述 用戶下單時,需要創建訂單并從用戶賬戶中扣除相應的余額。如果訂單創建成功但余額劃扣失敗,則需要回滾訂單創建操作。使用 Seata 的 TCC 模式來保證分布式事務的一致性。 1. 項目結構 假設我們有兩個微服務: Order Service&#x…

【Linux】Rhcsa復習5

一、Linux文件系統權限 1、文件的一般權限 文件權限針對三類對象進行定義: owner 屬主,縮寫u group 屬組, 縮寫g other 其他,縮寫o 每個文件針對每類訪問者定義了三種主要權限: r:read 讀 w&…

《Operating System Concepts》閱讀筆記:p748-p748

《Operating System Concepts》學習第 64 天,p748-p748 總結,總計 1 頁。 一、技術總結 1.Transmission Control Protocol(TCP) 重點是要自己能畫出其過程,這里就不贅述了。 二、英語總結(生詞:3) transfer, transport, tran…