天天看點

Kubernetes必備知識: Kubernetes資源模型requests

所屬技術領域:

Kubernetes

|名詞定義|

Requests是容器請求要使用的資源,Kubernetes 會保證 Pod 能使用到這麼多的資源。請求的資源是排程的依據,隻有當節點上的可用資源大于 Pod 請求的各種資源時,排程器才會把 Pod 排程到該節點上(如果 CPU 資源足夠,記憶體資源不足,排程器也不會選擇該節點)。

需要注意的是,排程器隻關心節點上可配置設定的資源,以及節點上所有 Pods 請求的資源,而不關心節點資源的實際使用情況,換句話說,如果節點上的 Pods 申請的資源已經把節點上的資源用滿,即使它們的使用率非常低,比如說 CPU 和記憶體使用率都低于 10%,排程器也不會繼續排程 Pod 上去。

|技術特點|

 通過 request 和 limit 的組合來确定我們想要的 QoS level。

  1. Guaranteed Pod
    Kubernetes必備知識: Kubernetes資源模型requests

Kubernetes 裡面有一個要求:如果你要建立出一個 Guaranteed Pod,那麼你的基礎資源(包括 CPU 和 memory),必須它的 request==limit,其他的資源可以不相等。隻有在這種條件下,它建立出來的 pod 才是一種 Guaranteed Pod,否則它會屬于 Burstable,或者是 BestEffort Pod。

  1. Burstable Pod
    Kubernetes必備知識: Kubernetes資源模型requests

比如說上面的例子,可以不用填寫 memory 的資源,隻要填寫 CPU 的資源,它就是一種 Burstable Pod。

  1. BestEffort Pod
    Kubernetes必備知識: Kubernetes資源模型requests

第三類 BestEffort Pod,它也是條件比較死的一種使用方式。它必須是所有資源的 request/limit 都不填,才是一種 BestEffort Pod。

 不同的 QoS 表現

接下來,為大家介紹一下:不同的 QoS 在排程和底層表現有什麼樣的不同?不同的 QoS,它其實在排程和底層表現上都有一些不一樣。比如說排程表現,排程器隻會使用 request 進行排程,也就是說不管你配了多大的 limit,它都不會進行排程使用。

在底層上,不同的 Qos 表現更不相同。比如說 CPU,它是按 request 來劃分權重的,不同的 QoS,它的 request 是完全不一樣的,比如說像 Burstable 和 BestEffort,它可能 request 可以填很小的數字或者不填,這樣的話,它的時間片權重其實是非常低的。像 BestEffort,它的權重可能隻有 2,而 Burstable 或 Guaranteed,它的權重可以多到幾千。

 requests的特點

1.requests用于schedule階段,在排程pod保證所有pod的requests總和小于node能提供的計算能力

2.requests.cpu被轉成docker的--cpu-shares參數,與cgroup cpu.shares功能相同

 設定容器的cpu的相對權重

 該參數在CPU資源不足時生效,根據容器requests.cpu的比例來配置設定cpu資源

 CPU資源充足時,requests.cpu不會限制container占用的最大值,container可以獨占CPU

3.requests.memory沒有對應的docker參數,作為k8s排程依據

4.使用requests來設定各容器需要的最小資源

 關于Requests的底層實作機制:

Kubernetes必備知識: Kubernetes資源模型requests

|資料來源|

名詞定義:

https://blog.51cto.com/dangzhiqiang/2298673

技術特點:

https://blog.csdn.net/zhonglinzhang/article/details/80663249 https://blog.csdn.net/qq180782842/article/details/87719739