0
  • 聊天消息
  • 系統(tǒng)消息
  • 評(píng)論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線課程
  • 觀看技術(shù)視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會(huì)員中心
創(chuàng)作中心

完善資料讓更多小伙伴認(rèn)識(shí)你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

如何在Kubernetes中快速啟用Cgroup V2支持

馬哥Linux運(yùn)維 ? 來源:馬哥Linux運(yùn)維 ? 2023-01-29 11:22 ? 次閱讀

Linux 中有兩個(gè) cgroup 版本:cgroup v1 和 cgroup v2。cgroup v2 是新一代的 cgroup API。

Kubernetes 自 v1.25 起 cgroup2 特性正式 stable.

cgroup v2 有哪些優(yōu)勢

cgroup v2 提供了一個(gè)具有增強(qiáng)資源管理能力的統(tǒng)一控制系統(tǒng)

cgroup v2 對(duì) cgroup v1 進(jìn)行了多項(xiàng)改進(jìn),例如:

?API 中單個(gè)統(tǒng)一的層次結(jié)構(gòu)設(shè)計(jì)

?更安全的子樹委派給容器

?更新的功能特性, 例如壓力阻塞信息(Pressure Stall Information,PSI)[1]

?跨多個(gè)資源的增強(qiáng)資源分配管理和隔離

?統(tǒng)一核算不同類型的內(nèi)存分配(網(wǎng)絡(luò)內(nèi)存、內(nèi)核內(nèi)存等)

?考慮非即時(shí)資源變化,例如頁面緩存回寫

一些 Kubernetes 特性專門使用 cgroup v2 來增強(qiáng)資源管理和隔離。例如,MemoryQoS[2] 特性改進(jìn)了內(nèi)存 QoS 并依賴于 cgroup v2 原語。

使用 cgroup v2 前提

cgroup v2 具有以下要求:

?操作系統(tǒng)發(fā)行版啟用 cgroup v2

?Ubuntu(從 21.10 開始,推薦 22.04+)

?Debian GNU/Linux(從 Debian 11 Bullseye 開始)

?Fedora(從 31 開始)

?RHEL 和類似 RHEL 的發(fā)行版(從 9 開始)

?…

?Linux 內(nèi)核為 5.8 或更高版本

?容器運(yùn)行時(shí)支持 cgroup v2。例如:

?containerd[3] v1.4 和更高版本

?cri-o[4] v1.20 和更高版本

?kubelet 和容器運(yùn)行時(shí)被配置為使用 systemd cgroup 驅(qū)動(dòng)[5]

使用 cgroup v2

這里以 Debian 11 Bullseye + containerd v1.4 為例.

啟用并檢查 Linux 節(jié)點(diǎn)的 cgroup v2

Debian 11 Bullseye 默認(rèn)已啟用 cgroup v2.

可以通過如下命令驗(yàn)證:

stat-fc%T/sys/fs/cgroup/

?對(duì)于 cgroup v2,輸出為 cgroup2fs。

?對(duì)于 cgroup v1,輸出為 tmpfs。

如果沒有啟用, 可以通過在 /etc/default/grub 下的 GRUB_CMDLINE_LINUX 中添加 systemd.unified_cgroup_hierarchy=1, 然后執(zhí)行 sudo update-grub

Notes: 如果是樹莓派, 標(biāo)準(zhǔn) Raspberry Pi OS 安裝時(shí)不會(huì)啟用 cgroups。需要 cgroups 來啟動(dòng) systemd 服務(wù)。可以通過將 cgroup_memory=1 cgroup_enable=memory systemd.unified_cgroup_hierarchy=1 附加到 /boot/cmdline.txt 來啟用 cgroups。并重啟生效

kubelet 使用 systemd cgroup 驅(qū)動(dòng)

kubeadm 支持在執(zhí)行 kubeadm init 時(shí),傳遞一個(gè) KubeletConfiguration 結(jié)構(gòu)體。KubeletConfiguration 包含 cgroupDriver 字段,可用于控制 kubelet 的 cgroup 驅(qū)動(dòng)。

說明:在版本 1.22 中,如果用戶沒有在 KubeletConfiguration 中設(shè)置 cgroupDriver 字段, kubeadm init 會(huì)將它設(shè)置為默認(rèn)值 systemd。

這是一個(gè)最小化的示例,其中顯式的配置了此字段:

#kubeadm-config.yaml kind:ClusterConfiguration apiVersion:kubeadm.k8s.io/v1beta3 kubernetesVersion:v1.21.0 --- kind:KubeletConfiguration apiVersion:kubelet.config.k8s.io/v1beta1 cgroupDriver:systemd

這樣一個(gè)配置文件就可以傳遞給 kubeadm 命令了:

kubeadminit--configkubeadm-config.yaml

說明:

Kubeadm 對(duì)集群所有的節(jié)點(diǎn),使用相同的 KubeletConfiguration。KubeletConfiguration 存放于 kube-system 命名空間下的某個(gè) ConfigMap[6] 對(duì)象中。

執(zhí)行 init、join 和 upgrade 等子命令會(huì)促使 kubeadm 將 KubeletConfiguration 寫入到文件 /var/lib/kubelet/config.yaml 中, 繼而把它傳遞給本地節(jié)點(diǎn)的 kubelet。

containerd 使用 systemd cgroup 驅(qū)動(dòng)

編輯 /etc/containerd/config.toml:

[plugins.cri.containerd.runtimes.runc.options] SystemdCgroup=true

升級(jí)監(jiān)控組件以支持 cgroup v2 監(jiān)控

Reference:

cgroup v2 使用一個(gè)與 cgroup v1 不同的 API,因此如果有任何應(yīng)用直接訪問cgroup 文件系統(tǒng), 則需要將這些應(yīng)用更新為支持 cgroup v2 的版本。例如:

? 一些第三方監(jiān)控和安全代理可能依賴于 cgroup 文件系統(tǒng)。你要將這些代理更新到支持 > cgroup v2 的版本。

? 如果以獨(dú)立的 DaemonSet 的形式運(yùn)行 cAdvisor[7] 以監(jiān)控 Pod 和容器, 需將其更> 新到 v0.43.0 或更高版本。

? 如果你使用 JDK,推薦使用 JDK 11.0.16 及更高版本或 JDK 15 及更高版本, 以便> 完全支持 cgroup v2[8]。

完成

總結(jié)

Kubernetes 自 v1.25 起 cgroup2 特性正式 stable. cgroup2 相比 cgroup v1 有以下優(yōu)勢:

? API 中單個(gè)統(tǒng)一的層次結(jié)構(gòu)設(shè)計(jì)

? 更安全的子樹委派給容器

? 更新的功能特性, 例如壓力阻塞信息(Pressure Stall Information,PSI)[9]

? 跨多個(gè)資源的增強(qiáng)資源分配管理和隔離

? 統(tǒng)一核算不同類型的內(nèi)存分配(網(wǎng)絡(luò)內(nèi)存、內(nèi)核內(nèi)存等)

? 考慮非即時(shí)資源變化,例如頁面緩存回寫

推薦在使用 Kubernetes v1.25及以上版本時(shí), 使用支持 cgroup v2 的linux 和 CRI. 并啟用 Kubernetes 的cgroup v2 功能.

聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點(diǎn)僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問題,請聯(lián)系本站處理。 舉報(bào)投訴
  • Linux
    +關(guān)注

    關(guān)注

    87

    文章

    11203

    瀏覽量

    208697
  • kubernetes
    +關(guān)注

    關(guān)注

    0

    文章

    223

    瀏覽量

    8682

原文標(biāo)題:如何在 Kubernetes 中快速啟用 Cgroup V2 支持

文章出處:【微信號(hào):magedu-Linux,微信公眾號(hào):馬哥Linux運(yùn)維】歡迎添加關(guān)注!文章轉(zhuǎn)載請注明出處。

收藏 人收藏

    評(píng)論

    相關(guān)推薦

    請問PCM9211支持HDMI音頻輸入嗎?

    請問PCM9211支持HDMI 2.1 eARC 標(biāo)準(zhǔn)的幀的專用輸入,是否同時(shí)支持HDMI音頻輸入。
    發(fā)表于 10-17 07:53

    請問TAS5727支持幾段EQ?

    TAS5727支持幾段EQ? 比如PCM5121支持7段以上,TAS5727可以么?
    發(fā)表于 10-14 07:02

    TUBS8041支持從設(shè)備嗎?

    TUBS8041支持從設(shè)備么?
    發(fā)表于 08-19 06:22

    請問TL072支持單端供電嗎?

    TL072支持單端供電嗎?看到規(guī)格書上的建議運(yùn)行條件,VCC-的電壓最大值為-5V,沒有0;現(xiàn)在有電路上VCC+接的是12V,VCC-接的是地,單端供電,這樣貌似芯片也能正常運(yùn)行,可靠嗎?
    發(fā)表于 08-02 06:57

    ESP32支持OpenHarmony嗎?

    ESP32支持OpenHarmony嗎,可以用AT命令卡控制鴻蒙智聯(lián)的連接嗎,使用ESP32模組的情況下帶寬是否能支持視頻流的上傳
    發(fā)表于 07-19 06:07

    官方,2K0300支持SD啟動(dòng)系統(tǒng)嗎?

    一般的開發(fā)板,都支持SD卡啟動(dòng)系統(tǒng) 1 查看網(wǎng)盤的06-用戶手冊的廣東龍芯2K300蜂鳥板用戶手冊V0.96文檔,發(fā)現(xiàn)板卡上有一個(gè)SD卡
    發(fā)表于 07-11 18:17

    請問visionFive2支持哪些操作系統(tǒng)?

    visionFive2支持哪些操作系統(tǒng)?
    發(fā)表于 07-03 07:30

    在ESP32-C3安全啟動(dòng)v2支持三個(gè)密鑰簽名的提交,請問具體怎么操作?

    IDFv4.3.2版本,在安全啟動(dòng)V2的文檔中提到\"How To Enable Secure Boot V2\",但是在其中只有指定密鑰,沒有提到密鑰燒錄的位置。 那么我想燒錄三個(gè)密鑰,具體的步驟是什么?
    發(fā)表于 06-17 06:19

    求助,請問ESP32支持MIMO嗎?

    請問ESP32支持MIMO嗎?
    發(fā)表于 06-13 06:00

    請問esp32c2支持ADC連續(xù)轉(zhuǎn)換模式的功能嗎?

    請問esp32c2支持ADC連續(xù)轉(zhuǎn)換模式的功能嗎,我看官網(wǎng)的API沒有這部分的代碼,下了連續(xù)轉(zhuǎn)換的例子,選c2芯片編譯時(shí)也報(bào)相關(guān)API沒對(duì)應(yīng)
    發(fā)表于 06-06 08:15

    請問StarFive VisionFive2支持勞特巴赫的仿真器嗎?

    1、StarFive VisionFive2支持勞特巴赫的仿真器嗎? 2、VisionFive2當(dāng)前可以支持哪些仿真器?
    發(fā)表于 05-21 07:48

    STM32L476支持高速USB通信嗎?

    我的板子是STM32L476的,現(xiàn)在要做一個(gè)usb通信,如果只是做全速USB的話不如直接用串口,所以想做高速USB,這就出現(xiàn)我現(xiàn)在的問題: 1.STM32L476支持高速USB通信嗎? 2.如果支持,應(yīng)該如何切換 3.PC端如果
    發(fā)表于 04-12 07:52

    請問AD9914支持AM以及MSK調(diào)制嗎?

    請問 AD9914支持AM以及MSK調(diào)制嗎? 如果支持 怎么操作呢 謝謝了
    發(fā)表于 12-13 09:35

    ad8616支持±5V雙電源供電嗎?

    ad8616支持±5V雙電源供電嗎?還是說只支持到±2.5V
    發(fā)表于 11-17 06:53

    MAX32660支持哪些系統(tǒng)平臺(tái)?

    MAX32660支持哪些系統(tǒng)平臺(tái)
    發(fā)表于 11-09 08:13