在线观看www成人影院-在线观看www日本免费网站-在线观看www视频-在线观看操-欧美18在线-欧美1级

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

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

3天內不再提示

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

馬哥Linux運維 ? 來源:馬哥Linux運維 ? 2023-01-29 11:22 ? 次閱讀

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

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

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

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

cgroup v2 對 cgroup v1 進行了多項改進,例如:

?API 中單個統(tǒng)一的層次結構設計

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

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

?跨多個資源的增強資源分配管理和隔離

?統(tǒng)一核算不同類型的內存分配(網絡內存、內核內存等)

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

一些 Kubernetes 特性專門使用 cgroup v2 來增強資源管理和隔離。例如,MemoryQoS[2] 特性改進了內存 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 內核為 5.8 或更高版本

?容器運行時支持 cgroup v2。例如:

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

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

?kubelet 和容器運行時被配置為使用 systemd cgroup 驅動[5]

使用 cgroup v2

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

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

Debian 11 Bullseye 默認已啟用 cgroup v2.

可以通過如下命令驗證:

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

?對于 cgroup v2,輸出為 cgroup2fs。

?對于 cgroup v1,輸出為 tmpfs。

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

Notes: 如果是樹莓派, 標準 Raspberry Pi OS 安裝時不會啟用 cgroups。需要 cgroups 來啟動 systemd 服務。可以通過將 cgroup_memory=1 cgroup_enable=memory systemd.unified_cgroup_hierarchy=1 附加到 /boot/cmdline.txt 來啟用 cgroups。并重啟生效

kubelet 使用 systemd cgroup 驅動

kubeadm 支持在執(zhí)行 kubeadm init 時,傳遞一個 KubeletConfiguration 結構體。KubeletConfiguration 包含 cgroupDriver 字段,可用于控制 kubelet 的 cgroup 驅動。

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

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

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

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

kubeadminit--configkubeadm-config.yaml

說明:

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

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

containerd 使用 systemd cgroup 驅動

編輯 /etc/containerd/config.toml:

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

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

Reference:

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

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

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

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

完成

總結

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

? API 中單個統(tǒng)一的層次結構設計

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

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

? 跨多個資源的增強資源分配管理和隔離

? 統(tǒng)一核算不同類型的內存分配(網絡內存、內核內存等)

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

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

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

    關注

    87

    文章

    11479

    瀏覽量

    213080
  • kubernetes
    +關注

    關注

    0

    文章

    242

    瀏覽量

    9011

原文標題:如何在 Kubernetes 中快速啟用 Cgroup V2 支持

文章出處:【微信號:magedu-Linux,微信公眾號:馬哥Linux運維】歡迎添加關注!文章轉載請注明出處。

收藏 人收藏

    評論

    相關推薦
    熱點推薦

    K230支持ONVIF上傳視頻嗎?

    K230支持ONVIF上傳視頻嗎
    發(fā)表于 06-20 07:11

    請問STM32CubeIDE v1.16.1支持代碼補全功能嗎?如何開啟呢?

    STM32CubeIDE v1.16.1支持代碼補全功能嗎?如何開啟呢?
    發(fā)表于 03-14 06:47

    請問ADS1255/6支持菊花鏈嗎?

    ADS1255/6支持菊花鏈嗎?連接方法是否同ADS1271?菊花鏈連接以后各ADC是否同步采集,順序輸出數據?
    發(fā)表于 02-12 06:05

    P82B96支持HDCP嗎?

    你好:我用P89B96用做HDMI的DDC通道的I2C的轉換,我現在是解決了II2問題,但是它里面有個HDCP保護協(xié)議通過DDC通道,感覺它有延時一樣,不穩(wěn)定。請問是否用P82B96支持HDCP?
    發(fā)表于 12-27 07:01

    ADS1256支持菊花鏈連接嗎?

    求助:1、ADS1256支持菊花鏈連接嗎? 2、如果不支持菊花鏈連接,能否把多片ADS1256掛在同一個SPI(CLK,MISO,MOSI)總線上,通過不同的CS來選擇芯片? 3、多片ADS1256能否
    發(fā)表于 12-24 06:03

    TLV320AIC3104-Q1支持PCM的音頻接口嗎?

    各位TI的工程師,我想問下支持TLV320AIC3104-Q1支持PCM的音頻接口嗎?Datasheet說能支持I2S,但是沒說能不能
    發(fā)表于 10-28 06:35

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

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

    請問TAS5727支持幾段EQ?

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

    TUBS8041支持從設備嗎?

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

    TPA6120A2支持單電源應用的話焊盤接地還是接1/2電源電壓?

    如題,如果TPA6120A2支持單電源應用的話焊盤接地還是接1/2電源電壓?
    發(fā)表于 08-15 08:23

    請問TL072支持單端供電嗎?

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

    ESP32支持OpenHarmony嗎?

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

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

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

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

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

    esp32-S3支持arduino編程嗎?

    arduino選開發(fā)板的時候沒有es32-s3, 只有s2可選。 請問: 1. esp32-S3支持arduino編程嗎 2. arduino下sample下的BLE庫能用嗎? 3. esp32-s3能作為usb host嗎?
    發(fā)表于 06-27 08:23
    主站蜘蛛池模板: 亚洲资源在线播放 | 国产人成精品免费视频 | 伊人狠狠丁香婷婷综合色 | 欧美日本综合 | 8090yy理论三级在线观看 | 亚洲国产综合人成综合网站00 | 国产永久视频夜色资源网 | 国产乱子伦一区二区三区 | 99久久国产免费福利 | 午夜韩国理论片在线播放 | 亚洲成在人线影视天堂网 | 欧美黑人粗暴另类多交 | 一级视频在线观看 | 四虎国产精品视频免费看 | 色综合久久中文字幕网 | 国产小视频在线观看www | 国产在线色视频 | 六月丁香色婷婷 | 91成人免费在线视频 | 特黄视频免费看 | 自拍偷拍福利 | 绝色村妇的泛滥春情 | 性色视频免费 | 手机看片午夜 | 免费视频不卡一区二区三区 | 久久精品国产亚洲5555 | 黄色3急| 黄色网视频 | 国产高清一区二区 | 久久久久久88色偷偷 | 亚洲操综合| 人人人人澡 | 怡红院网址 | 上课被同桌强行摸下面小黄文 | 七月婷婷精品视频在线观看 | 网站四虎1515hhcom | 四虎影视在线影院4hu | 狠狠做深爱婷婷久久一区 | 亚洲黄网站wwwwww | 日本不卡高清免费v日本 | 在线观看永久免费视频网站 |