Kubernetes(k8s)-Pod親和性(Affinity)和反親和性(Anti-affinity)

作者介紹:簡歷上沒有一個精通的運維工程師。請點擊上方的藍色《運維小路》關注我,下面的思維導圖也是預計更新的內容和當前進度(不定時更新)。

圖片

我們上一章介紹了Docker基本情況,目前在規模較大的容器集群基本都是Kubernetes,但是Kubernetes涉及的東西和概念確實是太多了,而且隨著版本迭代功能在還增加,筆者有些功能也確實沒用過,所以只能按照我自己的理解來講解。

我們上小節介紹了Node親和性(Affinity)和反親和性(Anti-affinity)本質上還是屬于Node和Pod的之間的調度規則。如果我們有一個需求要求同一個Deployment下的Pod不能調度到同一個節點,避免將同一個應用全部調度到某臺服務器。避免出現服務器宕機導致某一應用高可用失效的情況(雖然Kubernetes會在把Pod調度到其他節點,但是這個中間是有時間差的)。我在生產環境也是遇到過類似的故障。或者相反的要求一個控制器下的Pod必須和某個Pod在一起,則可以通過Pod親和性(Affinity)和反親和性(Anti-affinity)來解決。

Pod 親和性

Pod 親和性用于將新 Pod 安排到與現有 Pod 相近的位置,這些現有 Pod 可能是同一個應用的不同實例或者是相互協作的服務。以下是一個 Pod 親和性的示例:

apiVersion: apps/v1
kind: Deployment
metadata:name: myapp-deployment
spec:replicas:?3selector:matchLabels:app: myapptemplate:metadata:labels:app: myappspec:affinity:podAffinity:# 強制性(硬性)親和性規則requiredDuringSchedulingIgnoredDuringExecution:- labelSelector:matchExpressions:- key: appoperator: Invalues:- myapptopologyKey:?"kubernetes.io/hostname"# 不強制性(軟性)親和性規則preferredDuringSchedulingIgnoredDuringExecution:- weight:?1podAffinityTerm:labelSelector:matchExpressions:- key: appoperator: Invalues:- myapptopologyKey:?"kubernetes.io/hostname"containers:- name: myapp-containerimage: myapp-image:latest

強制親和性:要求必須匹配標簽:app:myapp的Pod,如果已經有一個帶有標簽?app: myapp?的 Pod 調度到了節點 A,那么當前的 Deployment 中的 Pod 副本也會嘗試調度到節點 A。適合哪些強相關的應用,他們必須(盡量)要在一個節點,如果沒有合適的標簽Pod可能會導致導讀失敗。

Pod 反親和性

Pod 反親和性用于將新 Pod 安排到與具有特定標簽的現有 Pod 不同的節點上,這有助于實現高可用性和故障隔離。以下是一個 Pod 反親和性的示例:

apiVersion: apps/v1
kind: Deployment
metadata:name: myapp-deployment
spec:replicas:?3selector:matchLabels:app: myapptemplate:metadata:labels:app: myappspec:affinity:podAntiAffinity:requiredDuringSchedulingIgnoredDuringExecution:- labelSelector:matchExpressions:- key: appoperator: Invalues:- myapptopologyKey:?"kubernetes.io/hostname"

首次調度:當第一個app=myapp Pod被調度時,由于沒有其他app=myapp Pod存在,它可以被自由地分配到任何節點上。

后續調度:當你嘗試創建第二個app=myapp Pod時,Kubernetes調度器會根據podAntiAffinity規則檢查各個節點。如果某個節點上已經存在一個app=myapp Pod,則新的Pod不會被調度到該節點上。相反,它會被調度到另一個沒有app=myapp Pod的節點上。從而就實現了一個Deployment被調度到不同的節點。

拓撲域topologyKey?代表 Kubernetes?集群中的拓撲域,如節點、機架、區域、可用區等。它通常是一個節點標簽的鍵,用于定義 Pod 親和性和反親和性規則的上下文,如果上面的拓撲域是Zone,則可以把Pod調度到不同的Zone,從而提供集群的可用性。

這里實際上一共有4個配置,我們可以根據自己的需求選擇其中一個或者多個進行組合配置,以滿足自己的特殊的需求。

Node的親和性主要滿足的是Pod和Node匹配關系,而Pod的親和性主要滿足的是Pod和Pod的之間的關系,雖然最后選擇的也是用來選擇Node。

到這里我們用了5個小節來講解調度相關的內容,這些都是Kubernetes默認的自帶的調度功能,如果不滿足要求還可以自帶定義調度器功能。

運維小路

一個不會開發的運維!一個要學開發的運維!一個學不會開發的運維!歡迎大家騷擾的運維!

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

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

相關文章

ESP32-C3物聯網方案,智能設備創新升級,無線交互控制通信應用

在物聯網技術迅猛發展的今天,各類智能設備如雨后春筍般涌現,深度融入我們生活與工作的各個角落,物聯網正以一種前所未有的速度改變著我們的世界。 想象一下,清晨,當第一縷陽光灑進房間,智能窗簾自動緩緩拉…

Python自動化測試 之 DrissionPage 的下載、安裝、基本使用詳解

Python自動化測試 之 DrissionPage 使用詳解 🏡前言:一、??DrissionPage的基本概述二、 🗺?環境安裝2.1 ???運行環境2.2 ???一鍵安裝 三、🗺?快速入門3.1 頁面類🛰?ChromiumPage🛫 SessionPage&…

【操作系統安全】任務3:Linux 網絡安全實戰命令手冊

目錄 一、基礎網絡信息獲取 1. 網絡接口配置 2. 路由表管理 3. 服務端口監控 二、網絡監控與分析 1. 實時流量監控 2. 數據包捕獲 3. 網絡協議分析 三、滲透測試工具集 1. 端口掃描 2. 漏洞利用 3. 密碼破解 四、日志審計與分析 1. 系統日志處理 2. 入侵檢測 3…

社群經濟4.0時代:開源鏈動模式與AI技術驅動的電商生態重構

摘要:在Web3.0技術浪潮與私域流量紅利的雙重驅動下,電商行業正經歷從"流量收割"到"用戶深耕"的范式轉變。本文基于社群經濟理論框架,結合"開源鏈動21模式"、AI智能名片、S2B2C商城小程序源碼等創新工具&#x…

從技術架構和生態考慮,不是單純的配置優化,還有哪些方式可以提高spark的計算性能

從技術架構和生態系統層面提升Spark的計算性能,可采取以下核心策略: 一、計算模型重構與執行引擎升級 1. 彈性分布式數據集(RDD)的血統優化 通過RDD的Lineage(血統)機制實現容錯時,采用增量式…

AI對軟件工程(software engineering)的影響在哪些方面?

AI對軟件工程(software engineering)的影響是全方位且深遠的,它不僅改變了傳統開發流程,還重新定義了工程師的角色和軟件系統的構建方式。以下是AI影響軟件工程的核心維度: 一、開發流程的智能化重構 需求工程革命 ? …

數據庫取證分析

目錄 一.多表關聯 1.一對多聯結 2.子查詢 二.數據庫示例分析 1.多表關聯 三.選擇SQL分析的原因 四.數據庫概述 五.SQL語言 一.多表關聯 1.一對多聯結 2.子查詢 二.數據庫示例分析 1.多表關聯 三.選擇SQL分析的原因 四.數據庫概述 五.SQL語言 1.select 字段

Docker 部署 Graylog 日志管理系統

Docker 部署 Graylog 日志管理系統 前言一、準備工作二、Docker Compose 配置三、啟動 Graylog 服務四、訪問 Graylog Web 界面總結 前言 Graylog 是一個開源的日志管理平臺,專為實時日志收集、分析和可視化設計。它支持強大的搜索功能,并且與 Elastics…

Matlab2024a免費版下載教程

Matlab是一個高性能的數學計算與仿真軟件,廣泛應用于科學計算、數據分析、算法開發以及工程繪圖等多個領域。它提供了強大的矩陣運算能力、豐富的內置函數庫以及靈活的編程環境,使得用戶能夠高效地解決復雜的數學問題。本文,我將為大家詳細介…

網絡運維學習筆記(DeepSeek優化版) 022 HCIP-Datacom路由概念、BFD協議詳解與OSPF第一課

文章目錄 路由概念、BFD協議詳解與OSPF第一課一、路由協議優先級與選路原則1.1 路由協議優先級對照表1.2 路由選路核心原則 二、BFD(Bidirectional Forwarding Detection,雙向轉發檢測)的配置與應用2.1 雙向心跳探測(雙端配置&…

【基礎】Windows 中通過 VSCode 使用 GCC 編譯調試 C++

準備 安裝 VSCode 及 C 插件。通過 MSYS2 安裝 MinGW-w64 工具鏈,為您提供必要的工具來編譯代碼、調試代碼并配置它以使用IntelliSense。參考:Windows 中的 Linux 開發工具鏈 驗證安裝: gcc --version g --version gdb --version三個核心配…

python機器學習——新手入門學習筆記

一,概論 1.什么是機器學習 定義: 機器學習是從數據中自動分析獲得模型,并利用模型對未知數據進行預測。 其實就是通過問題和數據,發現規律,并進行預測,與人腦相似。目的就是從歷史數據當中獲得規律&#x…

Jackson使用ArrayNode對象實現JSON列表數據(二):增、刪、改、查

JSON數據的操作,系列文章: 《Jackson的核心類與API方法:ObjectMapper、JsonNode、ObjectNode、ArrayNode》 《Jackson的使用與創建Jackson工具類》 《Jackson使用ObjectNode對象實現JSON對象數據(一):增、刪、改、查》 《Jackson使用ArrayNode對象實現JSON列表數據(二)…

Packaging Process

Packaging Process 軟包裝流程,在我們自動化設備的情況下,最后實現自動化工具 一小盒2袋,一大盒3小盒,一大盒6袋

地理信息系統(GIS)在智慧城市中的40個應用場景案例

在智慧城市發展進程中,地理信息系統(GIS)作為關鍵技術之一,正扮演著不可或缺的角色,堪稱智慧城市的神經中樞。通過空間數據分析優化城市管理,GIS技術為智慧城市的構建提供了強大的支持。 本文分享了GIS在智…

在 Jenkins Pipeline 中利用 Groovy 的閉包特性創建自定義語法糖

在 Jenkins Pipeline 中利用 Groovy 的閉包特性創建自定義語法糖,可以讓流水線代碼更簡潔易讀。以下是實現思路和示例: 1. 基礎閉包方法定義 // 定義一個優雅的 stage 語法 def elegantStage(String name, Closure body) { stage(name) { ec…

【藍橋杯】每日練習 Day11 逆序對問題和多路歸并

目錄 前言 超快速排序 分析 代碼 小朋友排隊 分析 代碼 魚塘釣魚 分析 代碼 前言 本來計劃今天寫五道題的,結果計劃趕不上變化,誰能告訴我我的時間都去哪了。。。 今天給大家帶來三道題目,兩道逆序對問題,分別用歸并排…

OpenCV 圖像基本操作

之前幾篇文章介紹了OpenCV的一些模塊概念,并沒有細說每個模塊具體的方法和使用。接下來就會詳細介紹每個模塊模塊包含的方法和使用。 本文將詳細介紹圖像的四種基本操作:訪問和修改像素值、圖像 ROI (Region of Interest) 操作、圖像通道分離與合并、以及圖像的縮放、旋轉、…

酷淘商場項目【從零到一詳解】Web端

?博客主頁: https://blog.csdn.net/m0_63815035?typeblog 💗《博客內容》:.NET、Java.測試開發、Python、Android、Go、Node、Android前端小程序等相關領域知識 📢博客專欄: https://blog.csdn.net/m0_63815035/cat…

Gemini 2.0 Flash 圖片去水印測試

Gemini 2.0 Flash 模型不僅會生成包含名人和受版權保護角色的圖像,還會去除現有照片中的水印。 據 X 和 Reddit 上的多位用戶指出,Gemini 2.0 Flash 模型不僅會去除水印,還會嘗試填補因水印刪除而產生的空白區域。其他基于人工智能的工具也能…