内射老阿姨1区2区3区4区_久久精品人人做人人爽电影蜜月_久久国产精品亚洲77777_99精品又大又爽又粗少妇毛片

Kubernetes垃圾回收機(jī)制的示例分析

這篇文章主要介紹了Kubernetes垃圾回收機(jī)制的示例分析,具有一定借鑒價值,感興趣的朋友可以參考下,希望大家閱讀完這篇文章之后大有收獲,下面讓小編帶著大家一起了解一下。

創(chuàng)新互聯(lián)堅(jiān)持“要么做到,要么別承諾”的工作理念,服務(wù)領(lǐng)域包括:網(wǎng)站制作、網(wǎng)站建設(shè)、企業(yè)官網(wǎng)、英文網(wǎng)站、手機(jī)端網(wǎng)站、網(wǎng)站推廣等服務(wù),滿足客戶于互聯(lián)網(wǎng)時代的古縣網(wǎng)站設(shè)計(jì)、移動媒體設(shè)計(jì)的需求,幫助企業(yè)找到有效的互聯(lián)網(wǎng)解決方案。努力成為您成熟可靠的網(wǎng)絡(luò)建設(shè)合作伙伴!

Kubernetes垃圾回收機(jī)制

問題發(fā)現(xiàn)

測試環(huán)境上,node節(jié)點(diǎn)上面鏡像,突然被刪除,故查明下刪除的原理機(jī)制

垃圾回收機(jī)制

Kubelet的GC功能將清理未使用的image和container。Kubelet每分鐘對container執(zhí)行一次GC,每5分鐘對image執(zhí)行一次GC。不建議使用外部垃圾收集工具,因?yàn)檫@些工具可能破壞Kubelet。

image

Kubernetes與Cadvisor配合,通過ImageManager管理所有image的生命周期。
image的GC策略包含高閾值和低閾值,高于高閾值的磁盤使用率將觸發(fā)GC,刪除最近最少使用的圖像,直到滿足低閾值為止。

container

container的GC主要有3個用戶定義變量:
MinAge:容器被GC的最短時間
MaxPerPodContainer: 允許每個PodContainer中死容器的最大數(shù)目,PodContainer指1個Container而非pod
MaxContainers:死容器的最大數(shù)目
Minage=0,MaxPerPodContainer和MaxContainers <0, 表示禁用這些變量
GC用于unidentified、deleted或超出邊界的容器(3個用戶定義變量)。
最舊的container通常首先被移除。
如果MaxPerPodContainer>MaxContainers,maxperpodcontainer會進(jìn)行調(diào)整,直至降級為1,并逐出最舊的容器。
pods所擁有的已刪除的容器一旦超過MinAge,就會被刪除。
未由Kubelet管理的容器不受容器垃圾收集的約束。

配置 GC

通過修改kubelet flags來實(shí)現(xiàn)。
image gc參數(shù):
image-gc-high-threshold  image GC 高閾值百分比,缺省為85%
image-gc-low-threshold    image GC 低閾值百分比,缺省為80%
minimum-container-ttl-duration                      MinAge參數(shù),缺省為0
maximum-dead-containers-per-container       MaxPerPodContainer,缺省為1.
maximum-dead-containers       MaxContainers,缺省為-1, 也就是沒有限制
Container可能在其到期之前被GC,Container包含日志和其他對故障排除有用的數(shù)據(jù)。強(qiáng)烈建議MaxPerPodContainer和maximum-dead-containers  足夠大。

Kubernetes垃圾回收機(jī)制的示例分析

GC效果

配置一個10s后會失敗的container 配置文件pod-gc.yaml

apiVersion: v1
kind: Pod
metadata:
  name: gc-test
spec:
  containers:
  - name: busybox-gc-1
    image: busybox:v1
    command:
    - /bin/sh
    - -c
    - 'sleep 10 && hello'

使用yaml創(chuàng)建pod

kubectl apply -f pod-gc.yaml

查看docker的狀態(tài),當(dāng)出現(xiàn)2個exit的container時,就會出發(fā)GC,回收最早的一個container

# docker ps -a | grep busybox-gc
8ddbfcf4ebee        59788edf1f3e             "/bin/sh -c 'sleep 1…"   2 seconds ago        Up 1 second                                           k8s_busybox-gc-1_gc-test_default_3651c167-75f0-11e9-bc74-52540005f38a_5
7d7c1ade82af        59788edf1f3e             "/bin/sh -c 'sleep 1…"   About a minute ago   Exited (127) About a minute ago                       k8s_busybox-gc-1_gc-test_default_3651c167-75f0-11e9-bc74-52540005f38a_4
# docker ps -a | grep busybox-gc
8ddbfcf4ebee        59788edf1f3e             "/bin/sh -c 'sleep 1…"   10 seconds ago       Up 9 seconds                                          k8s_busybox-gc-1_gc-test_default_3651c167-75f0-11e9-bc74-52540005f38a_5
7d7c1ade82af        59788edf1f3e             "/bin/sh -c 'sleep 1…"   About a minute ago   Exited (127) About a minute ago                       k8s_busybox-gc-1_gc-test_default_3651c167-75f0-11e9-bc74-52540005f38a_4
# docker ps -a | grep busybox-gc
8ddbfcf4ebee        59788edf1f3e             "/bin/sh -c 'sleep 1…"   11 seconds ago       Exited (127) Less than a second ago                       k8s_busybox-gc-1_gc-test_default_3651c167-75f0-11e9-bc74-52540005f38a_5
7d7c1ade82af        59788edf1f3e             "/bin/sh -c 'sleep 1…"   About a minute ago   Exited (127) About a minute ago                           k8s_busybox-gc-1_gc-test_default_3651c167-75f0-11e9-bc74-52540005f38a_4
# docker ps -a | grep busybox-gc
8ddbfcf4ebee        59788edf1f3e             "/bin/sh -c 'sleep 1…"   12 seconds ago      Exited (127) 1 second ago                       k8s_busybox-gc-1_gc-test_default_3651c167-75f0-11e9-bc74-52540005f38a_5

修改配置文件/var/lib/kubelet/kubeadm-flags.env增加參數(shù)–maximum-dead-containers-per-container=2

KUBELET_KUBEADM_ARGS=--cgroup-driver=systemd --network-plugin=cni --pod-infra-container-image=k8s.gcr.io/pause:3.1 --maximum-dead-containers-per-container=2
systemctl restart kubelet	##重啟kubelet服務(wù)
kubectl delete -f pod-gc.yaml	##刪除前面的pod
kubectl apply -f pod-gc.yaml	##重新添加pod

可以看到,當(dāng)exit的容器達(dá)到3個時,才會觸發(fā)gc

# docker ps -a | grep busybox-gc
c8677098e9aa        af2f74c517aa             "/bin/sh -c 'sleep 1…"   8 seconds ago       Up 8 seconds                                      k8s_busybox-gc-1_gc-test_default_3425a55b-75f5-11e9-bc74-52540005f38a_2
f0bc1b7893bd        af2f74c517aa             "/bin/sh -c 'sleep 1…"   34 seconds ago      Exited (127) 23 seconds ago                       k8s_busybox-gc-1_gc-test_default_3425a55b-75f5-11e9-bc74-52540005f38a_1
9e7fa118b1d3        af2f74c517aa             "/bin/sh -c 'sleep 1…"   45 seconds ago      Exited (127) 35 seconds ago                       k8s_busybox-gc-1_gc-test_default_3425a55b-75f5-11e9-bc74-52540005f38a_0
# docker ps -a | grep busybox-gc
c8677098e9aa        af2f74c517aa             "/bin/sh -c 'sleep 1…"   9 seconds ago       Up 9 seconds                                      k8s_busybox-gc-1_gc-test_default_3425a55b-75f5-11e9-bc74-52540005f38a_2
f0bc1b7893bd        af2f74c517aa             "/bin/sh -c 'sleep 1…"   35 seconds ago      Exited (127) 24 seconds ago                       k8s_busybox-gc-1_gc-test_default_3425a55b-75f5-11e9-bc74-52540005f38a_1
9e7fa118b1d3        af2f74c517aa             "/bin/sh -c 'sleep 1…"   46 seconds ago      Exited (127) 36 seconds ago                       k8s_busybox-gc-1_gc-test_default_3425a55b-75f5-11e9-bc74-52540005f38a_0
# docker ps -a | grep busybox-gc
c8677098e9aa        af2f74c517aa             "/bin/sh -c 'sleep 1…"   10 seconds ago      Exited (127) Less than a second ago                       k8s_busybox-gc-1_gc-test_default_3425a55b-75f5-11e9-bc74-52540005f38a_2
f0bc1b7893bd        af2f74c517aa             "/bin/sh -c 'sleep 1…"   36 seconds ago      Exited (127) 25 seconds ago                               k8s_busybox-gc-1_gc-test_default_3425a55b-75f5-11e9-bc74-52540005f38a_1
9e7fa118b1d3        af2f74c517aa             "/bin/sh -c 'sleep 1…"   47 seconds ago      Exited (127) 36 seconds ago                               k8s_busybox-gc-1_gc-test_default_3425a55b-75f5-11e9-bc74-52540005f38a_0
# docker ps -a | grep busybox-gc
c8677098e9aa        af2f74c517aa             "/bin/sh -c 'sleep 1…"   11 seconds ago      Exited (127) 1 second ago                         k8s_busybox-gc-1_gc-test_default_3425a55b-75f5-11e9-bc74-52540005f38a_2
f0bc1b7893bd        af2f74c517aa             "/bin/sh -c 'sleep 1…"   37 seconds ago      Exited (127) 26 seconds ago                       k8s_busybox-gc-1_gc-test_default_3425a55b-75f5-11e9-bc74-52540005f38a_1

感謝你能夠認(rèn)真閱讀完這篇文章,希望小編分享的“Kubernetes垃圾回收機(jī)制的示例分析”這篇文章對大家有幫助,同時也希望大家多多支持創(chuàng)新互聯(lián),關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道,更多相關(guān)知識等著你來學(xué)習(xí)!

標(biāo)題名稱:Kubernetes垃圾回收機(jī)制的示例分析
本文地址:http://www.rwnh.cn/article20/jdcsco.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供營銷型網(wǎng)站建設(shè)、網(wǎng)站策劃做網(wǎng)站、自適應(yīng)網(wǎng)站、移動網(wǎng)站建設(shè)、用戶體驗(yàn)

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)

成都網(wǎng)站建設(shè)公司
溧阳市| 托克托县| 大同市| 科尔| 司法| 开远市| 永安市| 石泉县| 江达县| 永川市| 永宁县| 克拉玛依市| 陆良县| 江孜县| 开阳县| 威海市| 离岛区| 阿拉善盟| 宜昌市| 平乡县| 泊头市| 同仁县| 安西县| 古丈县| 宜城市| 贵定县| 综艺| 怀远县| 成安县| 林周县| 洪湖市| 韩城市| 武夷山市| 富锦市| 山阴县| 香格里拉县| 奈曼旗| 内乡县| 大城县| 莲花县| 乌鲁木齐县|