色哟哟视频在线观看-色哟哟视频在线-色哟哟欧美15最新在线-色哟哟免费在线观看-国产l精品国产亚洲区在线观看-国产l精品国产亚洲区久久

0
  • 聊天消息
  • 系統消息
  • 評論與回復
登錄后你可以
  • 下載海量資料
  • 學習在線課程
  • 觀看技術視頻
  • 寫文章/發帖/加入社區
會員中心
創作中心

完善資料讓更多小伙伴認識你,還能領取20積分哦,立即完善>

3天內不再提示

深入研究Kubernetes調度

阿銘linux ? 來源:K8sMeetup社區 ? 作者:Ron Sobol ? 2021-08-23 10:39 ? 次閱讀

“本文從 Pod 和節點的配置開始,介紹了 Kubernetes Scheduler 框架、擴展點、API 以及可能發生的與資源相關的瓶頸,并展示了性能調整設置,涵蓋了 Kubernetes 中調度的大多方面。

Kubernetes Scheduler 是 Kubernetes 控制平面的核心組件之一。它在控制平面上運行,將 Pod 分配給節點,同時平衡節點之間的資源利用率。將 Pod 分配給新節點后,在該節點上運行的 kubelet 會在 Kubernetes API 中檢索 Pod 定義,根據節點上的 Pod 規范創建資源和容器。換句話說,Scheduler 在控制平面內運行,并將工作負載分配給 Kubernetes 集群。

本文將對 Kubernetes Scheduler 進行深入研究,首先概述一般的調度以及具有親和力(affinity)和 taint 的驅逐調度,然后討論調度程序的瓶頸以及生產中可能遇到的問題,最后研究如何微調調度程序的參數以適合集群。

調度簡介

Kubernetes 調度是將 Pod 分配給集群中匹配節點的過程。Scheduler 監控新創建的 Pod,并為其分配最佳節點。它會根據 Kubernetes 的調度原則和我們的配置選項選擇最佳節點。最簡單的配置選項是直接在 PodSpec 設置 nodeName:

apiVersion: v1

kind: Pod

metadata:

name: nginx

spec:

containers

- name: nginx

image: nginx

nodeName: node-01

上面的 nginx pod 默認情況下將在 node-01 上運行,但是 nodeName 有許多限制導致無法正常運行 Pod,例如云中節點名稱未知、資源節點不足以及節點網絡間歇性問題等。因此,除了測試或開發期間,我們最好不使用 nodeName。

如果要在一組特定的節點上運行 Pod,可以使用 nodeSelector。我們在 PodSpec 中將 nodeSelector 定義為一組鍵值對:

apiVersion: v1

kind: Pod

metadata:

name: nginx

spec:

containers:

- name: nginx

image: nginx

nodeSelector:

disktype: ssd

對于上面的 nginx pod,Kubernetes Scheduler 將找到一個磁盤類型為 ssd 的節點。當然,該節點可以具有其他標簽。我們可以在 Kubernetes 參考文檔中查看標簽的完整列表。

地址:https://kubernetes.io/docs/reference/kubernetes-api/labels-annotations-taints/

使用 nodeSelector 有約束 Pod 可以在有特定標簽的節點上運行。但它的使用僅受標簽及其值限制。Kubernetes 中有兩個更全面的功能來表達更復雜的調度需求:節點親和力(node affinity),標記容器以將其吸引到一組節點上;taint 和 toleration,標記節點以排斥 Pod。這些功能將在下面討論。

節點親和力

節點親和力(Node Affinity)是在 Pod 上定義的一組約束,用于確定哪些節點適合進行調度,即使用親和性規則為 Pod 的節點分配定義硬性要求和軟性要求。例如可以將 Pod 配置為僅運行帶有 GPU 的節點,并且最好使用 NVIDIA_TESLA_V100 運行深度學習工作負載。Scheduler 會評估規則,并在定義的約束內找到合適的節點。與 nodeSelectors 相似,節點親和性規則可與節點標簽一起使用,但它比 nodeSelectors 更強大。

我們可以為 podspec 添加四個相似性規則:

requiredDuringSchedulingIgnoredDuringExecution

requiredDuringSchedulingRequiredDuringExecution

preferredDuringSchedulingIgnoredDuringExecution

preferredDuringSchedulingRequiredDuringExecution

這四個規則由兩個條件組成:必需或首選條件,以及兩個階段:計劃和執行。以 required 開頭的規則描述了必須滿足的嚴格要求。以 preferred 開頭的規則是軟性要求,將強制執行但不能保證。調度階段是指將 Pod 首次分配給節點。執行階段適用于在調度分配后節點標簽發生更改的情況。

如果規則聲明為 IgnoredDuringExecution,Scheduler 在第一次分配后不會檢查其有效性。但如果使用 RequiredDuringExecution 指定了規則,Scheduler 會通過將容器移至合適的節點來確保規則的有效性。

以下是示例:

apiVersion: v1kind: Pod

metadata:

name: nginx

spec:

affinity:

nodeAffinity:

requiredDuringSchedulingIgnoredDuringExecution:

nodeSelectorTerms

- matchExpressions:

- key: topology.kubernetes.io/region

operator: In

values:

- us-east

preferredDuringSchedulingIgnoredDuringExecution:

- weight: 1

preference:

matchExpressions:

- key: topology.kubernetes.io/zone

operator: In

values:

- us-east-1

- us-east-2

containers:

- name: nginx

image: nginx

上面的 Nginx Pod 具有節點親和性規則,該規則讓 Kubernetes Scheduler 將 Pod 放置在 us-east 的節點上。第二條規則指示優先使用 us-east-1 或 us-east-2。

使用親和性規則,我們可以讓 Kubernetes 調度決策適用于自定義需求。

Taint 與 Toleration

集群中并非所有 Kubernetes 節點都相同。某些節點可能具有特殊的硬件,例如 GPU、磁盤或網絡功能。同樣,我們可能需要將一些節點專用于測試、數據保護或用戶組。我們可以將 Taint 添加到節點以排斥 Pod,如以下示例所示:

kubectl taint nodes node1 test-environment=true:NoSchedule

使用 test-environment=true:NoScheduletaint 時,除非在 podspec 具有匹配的 toleration,否則 Kubernetes Scheduler 將不會分配任何 pod:

apiVersion: v1kind: Pod

metadata:

name: nginx

spec:

containers:

- name: nginx

image: nginx

tolerations:

- key: “test-environment”

operator: “Exists”

effect: “NoSchedule”

taint 和 tolerations 共同發揮作用,讓 Kubernetes Scheduler 專用于某些節點并分配特定 Pod。

調度瓶頸

盡管 Kubernetes Scheduler 能選擇最佳節點,但是在 Pod 開始運行之后,“最佳節點”可能會改變。所以從長遠來看,Pod 的資源使用及其節點分配可能存在問題。

資源請求(Request)和限制(Limit):“Noisy Neighbor”

“Noisy Neighbor”并不特定于 Kubernetes。任何多租戶系統都是它們的潛在地。假設有兩個容器 A 和 B,它們在同一節點上運行。如果 Pod B 試圖通過消耗所有 CPU 或內存來創造 noise,Pod A 將出現問題。如果我們為容器設置了資源請求和限制就能控制住 neighbor。Kubernetes 將確保為容器安排其請求的資源,并且不會消耗超出其資源限制的資源。如果在生產中運行 Kubernetes,最好設置資源請求和限制以確保系統可靠。

系統進程資源不足

Kubernetes 節點主要是連接到 Kubernetes 控制平面的虛擬機。因此,節點上也有自己的操作系統和相關進程。如果 Kubernetes 工作負載消耗了所有資源,則這些節點將無法運行,并會發生各種問題問題。我們需要在 kubelet 中使用 –system -reserved 設置保留資源,以防止發生這種情況。

搶占或調度 Pod

如果 Kubernetes Scheduler 無法將 Pod 調度到可用節點,則可以從節點搶占(preempt)或驅逐(evict)一些 Pod 以分配資源。如果看到 Pod 在集群中移動而沒有發現特定原因,可以使用優先級類對其進行定義。同樣,如果沒有調度好 Pod,并且正在等待其他 Pod,也需要檢查其優先級。

以下是示例:

apiVersion: scheduling.k8s.io/v1kind: PriorityClass

metadata:

name: high-priority-nonpreempting

value: 100000preemptionPolicy: NeverglobalDefault: false

description: “This priority class will not preempt other pods.”

可以通過以下方式在 podspec 中為分配優先級:

apiVersion: v1kind: Pod

metadata:

name: nginx

spec:

containers:

- name: nginx

image: nginx

priorityClassName: high-priority-nonpreempting

調度框架

Kubernetes Scheduler 具有可插拔的調度框架架構,可向框架添加一組新的插件。插件實現 Plugin API,并被編譯到調度程序中。下面我們將討論調度框架的工作流、擴展點和 Plugin API。

工作流和擴展點

調度 Pod 包括兩個階段:調度周期(scheduling cycle)和綁定周期(binding cycle)。在調度周期中,Scheduler 會找到一個可用節點,然后在綁定過程中,將決策應用于集群。

工作流中的以下幾點對插件擴展開放:

QueueSort:對隊列中的 Pod 進行排序

PreFilter:檢查預處理 Pod 的相關信息以安排調度周期

Filter:過濾不適合該 Pod 的節點

PostFilter:如果找不到可用于 Pod 的可行節點,調用該插件

PreScore:運行 PreScore 任務以生成一個可共享狀態供 Score 插件使用

Score:通過調用每個 Score 插件對過濾的節點進行排名

NormalizeScore:合并分數并計算節點的最終排名

Reserve:在綁定周期之前選擇保留的節點

Permit:批準或拒絕調度周期結果

PreBind:執行任何先決條件工作,例如配置網絡卷

Bind:將 Pod 分配給 Kubernetes API 中的節點

PostBind:通知綁定周期的結果

插件擴展實現了 Plugin API,是 Kubernetes Scheduler 的一部分。我們可以在 Kubernetes 存儲庫中檢查。插件應使用以下名稱進行注冊:

// Plugin is the parent type for all the scheduling framework plugins.

type Plugin interface {

Name() string

}

插件還實現了相關的擴展點,如下所示:

// QueueSortPlugin is an interface that must be implemented by “QueueSort” plugins.

// These plugins are used to sort pods in the scheduling queue. Only one queue sort plugin may be enabled at a time.

type QueueSortPlugin interface {

Plugin

// Less are used to sort pods in the scheduling queue.

Less(*QueuedPodInfo, *QueuedPodInfo) bool

}

Scheduler 性能調整

Kubernetes Scheduler 有一個工作流來查找和綁定 Pod 的可行節點。當集群中的節點數量非常多時,Scheduler 的工作量將成倍增加。在大型集群中,可能需要很長時間才能找到最佳節點,因此要微調調度程序的性能,以在延遲和準確性之間找到折中方案。

percentageOfNodesToScore 將限制節點的數量來計算自己的分數。默認情況下,Kubernetes 在 100 節點集群的 50% 和 5000 節點集群的 10% 之間設置線性閾值。默認最小值為 5%,它要確保至少考慮集群中 5% 節點的調度。

下面的示例展示了如何通過性能調整 kube-scheduler 來手動設置閾值:

apiVersion: kubescheduler.config.k8s.io/v1alpha1

kind: KubeSchedulerConfiguration

algorithmSource:

provider: DefaultProvider

percentageOfNodesToScore: 50

如果有一個龐大的集群并且 Kubernetes 工作負載不能承受 Kubernetes Scheduler 引起的延遲,那么更改百分比是個好主意。

總結

本文涵蓋了 Kubernetes 調度的大多方面,從 Pod 和節點的配置開始,包括 nodeSelector、親和性規則、taint 和 toleration,然后介紹了 Kubernetes Scheduler 框架、擴展點、API 以及可能發生的與資源相關的瓶頸,最后展示了性能調整設置。盡管 Kubernetes Scheduler 能簡單地將 Pod 分配給節點,但是了解其動態性并對其進行配置以實現可靠的生產級 Kubernetes 設置至關重要。

原文鏈接:https://thenewstack.io/a-deep-dive-into-kubernetes-scheduling/

作者:Ron Sobol. 翻譯:Bach(才云)

校對:星空下的文仔(才云)、bot(才云)

責任編輯:haq

聲明:本文內容及配圖由入駐作者撰寫或者入駐合作網站授權轉載。文章觀點僅代表作者本人,不代表電子發燒友網立場。文章及其配圖僅供工程師學習之用,如有內容侵權或者其他違規問題,請聯系本站處理。 舉報投訴
  • kubernetes
    +關注

    關注

    0

    文章

    227

    瀏覽量

    8738

原文標題:Kubernetes 調度詳解

文章出處:【微信號:aming_linux,微信公眾號:阿銘linux】歡迎添加關注!文章轉載請注明出處。

收藏 人收藏

    評論

    相關推薦

    電容器深入研究:電路保護、濾波和能量存儲

    校參加了一些課程,并獲得了一些關于何時使用電容器以及它們如何工作的真實示例。從電路保護到濾波,從能量存儲到傳感,我正在深入研究簡單而復雜的電容器世界。 這些東西是如何運作的? 事實上,構成電容器的只是由絕緣體隔開的兩個導體。
    的頭像 發表于 01-25 15:13 ?31次閱讀
    電容器<b class='flag-5'>深入研究</b>:電路保護、濾波和能量存儲

    Kubernetes:構建高效的容器化應用平臺

    Kubernetes 作為容器編排的事實標準,在容器化應用部署中發揮著關鍵作用。 搭建 Kubernetes 集群是應用的基礎。可以使用kubeadm工具快速搭建。在主節點執行kubeadm
    的頭像 發表于 01-23 15:22 ?54次閱讀

    使用 Flexus 云服務器 X 實例部署 Kubernetes 圖形化管理平臺

    Kubernetes 作為當今最流行的容器編排平臺,隨著云計算、微服務架構和 DevOps 文化的普及,Kubernetes 在自動化部署、擴展和管理容器化應用程序方面扮演著越來越重要的角色。未來
    的頭像 發表于 01-21 16:14 ?76次閱讀
    使用 Flexus 云服務器 X 實例部署 <b class='flag-5'>Kubernetes</b> 圖形化管理平臺

    《一云多芯算力調度研究報告》聯合發布

    近日,浪潮云海攜手中國軟件評測中心、騰訊云等十余家核心機構與廠商,共同發布了《一云多芯算力調度研究報告》。該報告深入探討了當前一云多芯技術的發展趨勢與挑戰。 報告指出,一云多芯技術正處于從混合部署
    的頭像 發表于 01-10 14:18 ?132次閱讀

    Kubernetes的CNI網絡插件之flannel

    Kubernetes設計了網絡模型,但卻將它的實現講給了網絡插件,CNI網絡插件最重要的功能就是實現Pod資源能夠跨主機通信。
    的頭像 發表于 01-02 09:43 ?271次閱讀

    電力系統中電動車充電樁布局與調度的優化策略探究

    15821697760 摘要:本文深入鉆研電動車充電樁于電力系統布局及調度的問題,融合地理信息系統與電網模型,綜合考慮電力供應能力、民眾電動車出行需求以及充電設備安全等要素,構建多因多目標優化模型
    的頭像 發表于 12-13 16:39 ?394次閱讀
    電力系統中電動車充電樁布局與<b class='flag-5'>調度</b>的優化策略探究

    對于電力系統中新能源電動車充電樁布局與調度優化方法的研究

    本文針對電動車充電樁在電力系統布局及調度方面進行深入研究,借鑒地理信息系統與電網模型,綜合考量電力供應的能力,大眾對電動車出行需求,以及充電設備的安全,多因多目標優化模型誕生。有效地確定充電樁的*優布局方案。
    的頭像 發表于 12-12 08:39 ?299次閱讀
    對于電力系統中新能源電動車充電樁布局與<b class='flag-5'>調度</b>優化方法的<b class='flag-5'>研究</b>

    基于量子計算技術的AGV調度問題研究

    由于自動化和智能化的普及,AGV(自動導引車)調度問題在物流、運輸和生產領域有著廣泛的應用。 隨著AGV數量的增加,經典計算方法難以滿足大規模調度的需求,而玻色量子自研的相干光量子計算技術具有強大
    的頭像 發表于 11-11 09:36 ?323次閱讀
    基于量子計算技術的AGV<b class='flag-5'>調度</b>問題<b class='flag-5'>研究</b>

    Kubernetes集群搭建容器云需要幾臺服務器?

    Kubernetes集群搭建容器云需要幾臺服務器?至少需要4臺服務器。搭建容器云所需的服務器數量以及具體的搭建步驟,會根據所選用的技術棧、業務規模、架構設計以及安全需求等因素而有所不同。以下是一個基于Kubernetes集群的容器云搭建的概述:
    的頭像 發表于 10-21 10:06 ?187次閱讀

    構建語音控制機器人 - 深入研究電路

    2024-07-29 |Annabel Ng S1XT33N項目 正如[之前的博客文章]中提到的,加州大學伯克利分校的 EECS 16B 課程重點關注構建名為 S1XT33N 的語音控制機器人的為期一個學期的項目。然而,這個機器人并不是你在初中或高中時建造的標準機器人汽車。我和我的實驗室伙伴只獲得了基本的兩輪機器人組件,包括輪子、電機、底盤、Arduino Leonardo、電池和面包板,我們必須自己構建和連接其他所有組件。如果您有興趣了解有關該課程的更多信息,請訪問課程網站[https://www.eec
    的頭像 發表于 10-02 16:40 ?275次閱讀
    構建語音控制機器人 - <b class='flag-5'>深入研究</b>電路

    深入探討Linux的進程調度

    Linux操作系統作為一個開源且廣泛應用的操作系統,其內核設計包含了許多核心功能,而進程調度器(Scheduler)就是其中一個至關重要的模塊。進程調度器負責決定在任何給定的時刻哪個進程可以運行
    的頭像 發表于 08-13 13:36 ?981次閱讀
    <b class='flag-5'>深入</b>探討Linux的進程<b class='flag-5'>調度</b>器

    使用Velero備份Kubernetes集群

    Velero 是 heptio 團隊(被 VMWare 收購)開源的 Kubernetes 集群備份、遷移工具。
    的頭像 發表于 08-05 15:43 ?388次閱讀
    使用Velero備份<b class='flag-5'>Kubernetes</b>集群

    如何使用Kubeadm命令在PetaExpress Ubuntu系統上安裝Kubernetes集群

    Kubernetes,通常縮寫為K8s,是一個開源的容器編排平臺,旨在自動化容器化應用的部署、擴展和管理。有了Kubernetes,您可以輕松地部署、更新和擴展應用,而無需擔心底層基礎設施。
    的頭像 發表于 07-15 13:31 ?896次閱讀
    如何使用Kubeadm命令在PetaExpress Ubuntu系統上安裝<b class='flag-5'>Kubernetes</b>集群

    倫敦商學院深入研究中國神州數碼戰略轉型

    China)數字化轉型歷程的深入研究為基礎,共同撰寫了案例研究「神州數碼的轉型:駕馭數據、云和人工智能的潛力(The Transformation of Digital China
    的頭像 發表于 07-02 11:25 ?543次閱讀
    倫敦商學院<b class='flag-5'>深入研究</b>中國神州數碼戰略轉型

    智慧園區安全調度管理都有哪些

    現如今智慧園區深入大家的生活當中,隨著一系列數字化改革方針的出臺,智慧園區作為智慧城市的核心基礎模塊,使用5G、大數據、云計算、物聯網等新技術,整合數據和資源,更加方便了我們管理人員進行管理。而智慧
    的頭像 發表于 04-28 15:13 ?337次閱讀
    智慧園區安全<b class='flag-5'>調度</b>管理都有哪些
    主站蜘蛛池模板: 亚洲第一成年网站视频 | 无码免费视频AAAAAA片草莓 | 嗯啊快停下我是你老师啊H 嗯啊快拔出来我是你老师视频 | 蜜臀久久99精品久久久久久做爰 | 国产偷国产偷亚州清高APP | 野花韩国免费高清电影 | 看了n遍舍不得删的黄文 | 国产成人精品自线拍 | 国产成人理在线观看视频 | 国产精品视频yy9099 | 四虎精品久久 | 伊人网青青草 | 久久精品电影院 | 精品国产乱码久久久久乱码 | 亚洲国产精品免费线观看视频 | 美女拉开腿让男生桶到爽 | 香蕉久久夜色精品国产小优 | 黑人巨茎vide抽搐 | 亚洲精品91 | 伦理片飘花手机在线 | gay台湾无套男同志xnxⅹ | 在线观看国产精美视频 | 午夜性爽视频男人的天堂在线 | 狠狠色综合7777久夜色撩人 | 四虎影院网红美女 | 疯狂小护士 | 工口肉肉彩色不遮挡 | WWW亚洲精品久久久乳 | 9966在线观看免费高清电影 | 亚洲 中文 自拍 无码 | 嗯好舒服嗯好大好猛好爽 | 被送到黑人性奴俱乐部 | 午夜在线视频国产极品片 | 亚洲精品国偷拍电影自产在线 | 湖南电台在线收听 | 欧美片内射欧美美美妇 | 99re精品视频在线播放视频 | 国产毛A片啊久久久久久A | H狠狠躁死你H | 欧美最猛黑人AAAAA片 | 巨胸美女狂喷奶水www网麻豆 |