【kubernetes】-6污點與污點容忍

文章目錄

  • 污點與污點容忍
    • 1、 污點(taint)
    • 2、操作命令
    • 3、污點容忍
    • 4、污點擴展

污點與污點容忍

1、 污點(taint)

  • 污點是節點的屬性,用于排斥一類特定的 Pod。
  • 通過污點,可以避免 Pod 被調度到不合適的節點上

污點組成

key=value:effect
  • key:污點的鍵。
  • value:污點的值(可為空)。
  • effect:污點的作用效果。

污點效果(effect)

效果描述
NoSchedule不會將 Pod 調度到具有該污點的節點上。
PreferNoSchedule盡量避免將 Pod 調度到具有該污點的節點上。
NoExecute不會將 Pod 調度到具有該污點的節點上,并驅逐節點上已有的 Pod。

2、操作命令

  • 設置污點
kubectl taint node <節點名稱> <污點key>=<value>:<effect>
#示例
kubectl taint node node01 key1=value1:NoSchedule
  • 查看污點
kubectl describe node <node-name>
kubectl describe nodes <節點名稱> | grep -A 5 Taints
  • 刪除污點
kubectl taint node <節點名稱> <污點key>:<effect>-#示例
kubectl taint node node01 key1:NoSchedule-

3、污點容忍

  • 容忍是 Pod 的屬性,允許 Pod 被調度到具有匹配污點的節點上。

容忍配置

在 Pod 的 YAML 文件中的 spec.tolerations 字段進行配置:

spec:tolerations:- operator: Equal|Existskey: <污點key>value: <污點value>effect: NoSchedule|PreferNoSchedule|NoExecutetolerationSeconds: 3600

字段說明:

字段描述
key污點的鍵,需與節點污點一致。
operator匹配操作符,Equal(值相等)或 Exists(存在即可,忽略值)。
value污點的值(operatorEqual 時需指定)。
effect污點的效果,需與節點污點一致。
tolerationSecondsPod 被驅逐前可在節點上繼續運行的時間(僅對 NoExecute 有效)。

示例:

apiVersion: v1
kind: Pod
metadata:name: myapp01labels:app: myapp01
spec:containers:- name: with-node-affinityimage: soscscs/myapp:v1tolerations:- key: "check"operator: "Equal"value: "mycheck"effect: "NoExecute"tolerationSeconds: 3600

應用場景

  1. 專用節點
    • 為某些節點設置污點,確保只有特定 Pod 可以調度到這些節點。
    • 示例:GPU 節點僅運行需要 GPU 的任務。
  2. 節點維護
    • 設置 NoExecute 污點,驅逐節點上的 Pod 以便維護。
  3. 高可用部署
    • 使用 NoSchedulePreferNoSchedule,確保 Pod 分散在不同節點上。

示例:

設置污點

kubectl taint node node01 check=mycheck:NoExecute

查看污點

kubectl describe node node01

創建容忍pod

kubectl apply -f pod-with-toleration.yaml

驗證pod步驟

kubectl get pods -o wide

4、污點擴展

污點(Taints)注意事項

  1. 容忍所有污點 key

    • 當不指定 key 值時,使用 Exists 操作符可以容忍節點上的所有污點 key。
    tolerations:
    - operator: "Exists"
    
  2. 容忍所有污點作用

    • 當不指定 effect 值時,只要污點的 key 匹配,無論其作用(如 NoSchedule, PreferNoSchedule, NoExecute)是什么,都會被容忍。
    tolerations:
    - key: "key"operator: "Exists"
    
  3. 多 Master 節點設置

    • 在有多個 Master 節點的情況下,為了避免資源浪費,可以將 Master 節點設置為 PreferNoSchedule,這樣默認情況下不會調度 Pod 到 Master 節點,但在必要時可以調度。
    kubectl taint node Master-Name node-role.kubernetes.io/master=:PreferNoSchedule
    

污點應用實例

  • 設置 NoExecute 污點

    • 當某個 Node 需要更新升級系統組件時,可以先在該 Node 上設置 NoExecute 污點,以驅逐該 Node 上的所有 Pod。
    kubectl taint node node01 check=mycheck:NoExecute
    
  • 臨時設置 PreferNoSchedule 污點

    • 如果其他 Node 資源不足,可以臨時將 Master 節點設置為 PreferNoSchedule,允許在必要時調度 Pod 到 Master 節點。
    kubectl taint node master node-role.kubernetes.io/master=:PreferNoSchedule --overwrite
    
  • 移除污點

    • 更新操作完成后,移除之前設置的污點。
    kubectl taint node node01 check=mycheck:NoExecute-  
    

節點維護操作

  1. 查看節點

    • 使用 kubectl get nodes 查看集群中的所有節點。
  2. 標記節點為不可調度

    • 使用 kubectl cordon <NODE_NAME> 將節點標記為不可調度狀態,防止新創建的 Pod 調度到此節點。
    kubectl cordon <NODE_NAME>
    
  3. 驅逐節點上的 Pod

    • 使用 kubectl drain <NODE_NAME> 命令驅逐節點上的所有 Pod,并設置節點為不可調度狀態。
    kubectl drain <NODE_NAME> --ignore-daemonsets --delete-emptydir-data --force
    
    • 參數解釋:
      • --ignore-daemonsets:忽略 DaemonSet 管理的 Pod。
      • --delete-emptydir-data:強制刪除掛載了本地卷的 Pod。
      • --force:強制驅逐非控制器管理的 Pod。
  4. 標記節點為可調度

    • 使用 kubectl uncordon <NODE_NAME> 將節點標記為可調度狀態,允許新 Pod 調度到此節點。
    kubectl uncordon <NODE_NAME>
    

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

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

相關文章

定義損失函數并以此訓練和評估模型

基礎神經網絡模型搭建 【Pytorch】數據集的加載和處理&#xff08;一&#xff09; 【Pytorch】數據集的加載和處理&#xff08;二&#xff09; 損失函數計算模型輸出和目標之間的距離。通過torch.nn 包可以定義一個負對數似然損失函數&#xff0c;負對數似然損失對于訓練具有多…

電子書轉PDF格式教程,實現epub轉PDF步驟

EPUB 格式屬于流式文檔&#xff0c;在屏幕尺寸各異的設備上都能自動適配顯示。然而&#xff0c;要是你使用的是特定的閱讀設備&#xff0c;像打印機、不支持 EPUB 格式的電子閱讀器&#xff08;例如某些早期的 Kindle 型號&#xff09;&#xff0c;或者需要在固定尺寸的屏幕上展…

Java學習第六十九部分——RabbitMQ

目錄 一、前言提要 二、基本信息 1. 關鍵定義 2. 核心角色 3. 交換機類型 三、消息生命周期與可靠性機制 四、生態集成——與Java 五、應用場景 六、性能與選型對比 七、生產級最佳實踐——基于Java 八、應用場景 九、一句話總結 一、前言提要 Spring AMQP是…

MDAC2.6問題解決指南:解決.NET Framework數據訪問煩惱

MDAC2.6問題解決指南&#xff1a;解決.NET Framework數據訪問煩惱 【下載地址】MDAC2.6問題解決指南 MDAC 2.6 問題解決指南為您提供了針對.NET Framework數據提供程序要求使用Microsoft Data Access Components (MDAC) 2.6或更高版本的全面解決方案。本指南詳細介紹了如何在開…

會話跟蹤模式

一、圖片講了什么&#xff1f;這張圖片主要講的是“會話跟蹤技術”&#xff0c;也就是網站怎么記住你是誰、你做了什么。1. 什么是會話&#xff1f;會話&#xff08;Session&#xff09;就像你和網站的一次聊天&#xff0c;從你打開網頁到關閉網頁&#xff0c;這段時間就是一次…

C語言開發工具Win-TC

如你所知&#xff0c;WIN-TC是一個turbo C2 WINDOWS 平臺開發工具&#xff0c;最大特點是支持中文界面&#xff0c;支持鼠標操作&#xff0c;程序段復制&#xff0c;為初學 c 語言、對高等編程環境不熟悉的同志們非常有幫助。該軟件使用 turbo C2 為內核&#xff0c;提供 WINDO…

lwIP學習記錄5——裸機lwIP工程學習后的總結

1、ping包的TTL生存時間如何修改當我們把工程燒錄到板子上是&#xff0c;我們對板子的IP進行ping包&#xff0c;看到信息如下圖這時候我好奇TTL是什么作用&#xff0c;為什么有的設備是64有的設備是128有的是255&#xff1f;解&#xff1a;TTL&#xff08;Time to Live&#xf…

利用Trae將原型圖轉換為可執行的html文件,感受AI編程的魅力

1、UI設計原型效果2、通過Tare對話生成的效果圖&#xff08;5分鐘左右&#xff09;3、查資料做的效果圖&#xff08;30分鐘左右&#xff09;&#xff09;通過以上對比&#xff0c;顯然差別不多能滿足要求&#xff0c;只需要在繼續優化就能搞定&#xff1b; 4、Trae生成的源碼&l…

Chessboard and Queens

題目描述Your task is to place eight queens on a chessboard so that no two queens are attacking each other. As an additional challenge, each square is either free or reserved, and you can only place queens on the free squares. However, the reserved squares …

菜鳥教程R語言一二章閱讀筆記

菜鳥教程R語言一二章閱讀筆記 一.R語言基礎教程 R 語言是為數學研究工作者設計的一種數學編程語言&#xff0c;主要用于統計分析、繪圖、數據挖掘。側重于數學工作者 R語言特點如下&#xff1a; R 語言環境軟件屬于 GNU 開源軟件&#xff0c;兼容性好、使用免費 語法十分有利于…

Tactile-VLA:解鎖視覺-語言-動作模型的物理知識,實現觸覺泛化

25年7月來自清華、中科大和上海交大的論文“Tactile-VLA: Unlocking Vision-Language- Action Model’s Physical Knowledge For Tactile Generalization ”。 視覺-語言-動作 (VLA) 模型已展現出卓越的成就&#xff0c;這得益于其視覺-語言組件豐富的隱性知識。然而&#xff0…

HTML初學者第五天

<1>表格標簽1.1基本語法<table><tr><td>單元格內的文字</td>...</tr>... </table>1.<table></table>是用于定義表格的標簽。2.<tr></tr>標簽用于定義表格中的行&#xff0c;必須嵌套在<table></ta…

FastAPI入門:demo、路徑參數、查詢參數

demo from fastapi import FastAPIapp FastAPI()app.get("/") async def root():return {"message": "Hello World"}在終端運行 fastapi dev main.py結果如下&#xff1a;打開http://127.0.0.1:8000&#xff1a;交互式API文檔&#xff1a;位于h…

pytest中的rerunfailures的插件(失敗重試)

目錄 1-- 安裝rerunfailures插件 2-- rerunfailures的使用 3-- 重試案例 安裝rerunfailures插件 pip install pytest-rerunfailures點擊左下角的控制臺面板 輸入 pip install pytest-rerunfailures 出現上圖的情況就算安裝完成了 rerunfailures的使用 可以添加一下參數使用&…

SpringMVC——建立連接

建立連接 將用戶&#xff08;瀏覽器&#xff09;和java程序連接起來&#xff0c;也就是訪問一個地址能夠調用到我們的Spring程序。在 Spring MVC 中使用 RequestMapping來實現URL 路由映射&#xff0c;也就是瀏覽器連接程序的作用。 1.RequestMapping注解介紹 RequestMapping…

蘑菇云路由器使用教程

1: 手機連接路由器的Wi-Fi&#xff0c;在瀏覽器輸入背面IP地址&#xff1a;192.168.132.1進入路由管理界面1.1: 電腦連接路由器網線在瀏覽器輸入背面IP地址&#xff1a;192.168.132.1進入路由管理界面賬號&#xff1a;admin密碼&#xff1a;123456782:選擇上網模式2.1&#xff…

ubuntu的tar解壓指令相關

1. 指令說明參數作用-xextract&#xff0c;解包-z通過 gzip 解壓&#xff08;.tar.gz、.tgz&#xff09;-vverbose&#xff0c;顯示過程-ffile&#xff0c;后面緊跟壓縮包文件名2. 什么時候用z參數場景是否加 -z結果.tar.gz / .tgz? 必須加 -z正常解壓.tar.gz / .tgz? 沒加 -…

車載診斷刷寫 --- Flash關于擦除和寫入大小

我是穿拖鞋的漢子,魔都中堅持長期主義的汽車電子工程師。 老規矩,分享一段喜歡的文字,避免自己成為高知識低文化的工程師: 簡單,單純,喜歡獨處,獨來獨往,不易合同頻過著接地氣的生活,除了生存溫飽問題之外,沒有什么過多的欲望,表面看起來很高冷,內心熱情,如果你身…

【Verilog HDL 入門教程】 —— 學長帶你學Verilog(基礎篇)

文章目錄一、Verilog HDL 概述1、Verilog HDL 是什么2、Verilog HDL產生的背景3、Verilog HDL 和 VHDL的區別二、Verilog HDL 基礎知識1、Verilog HDL 語言要素1.1、命名規則1.2、注釋符1.3、關鍵字1.4、數值1.4.1、整數及其表示1.4.2、實數及其表示1.4.3、字符串及其表示2、數…

SQL Developer Data Modeler:一款免費跨平臺的數據庫建模工具

SQL Developer Data Modeler 是由 Oracle 公司開發的一款免費的圖形化數據建模和數據庫設計工具&#xff0c;用于創建、瀏覽和編輯邏輯模型、關系模型、物理模型、多維模型和數據類型模型。 SQL Developer Data Modeler 既是一個獨立的應用程序&#xff0c;同時也被集成到了 Or…