kubelet---关于垃圾镜像/容器回收策略

本文详细介绍了Kubernetes Kubelet中关于镜像和容器的垃圾回收策略。镜像回收依赖于cadvisor,基于磁盘使用率的HighThresholdPercent和LowThresholdPercent触发。容器回收涉及MinAge、MaxPerPodContainer和MaxContainers等参数,用于管理死亡容器的数量。用户可以通过调整kubelet参数如image-gc-high-threshold和minimum-container-ttl-duration来优化回收策略。
摘要由CSDN通过智能技术生成

kubelet—关于垃圾镜像/容器回收策略

镜像回收

Kubernetes 借助于 cadvisor 通过 imageManager 来管理所有镜像的生命周期。

镜像垃圾回收策略只考虑两个因素:HighThresholdPercent 和 LowThresholdPercent。 磁盘使用率超过上限

阈值(HighThresholdPercent)将触发垃圾回收。 垃圾回收将删除最近最少使用的镜像,直到磁盘使用率满足下

限阈值(LowThresholdPercent)。

容器回收

容器垃圾回收策略考虑三个用户定义变量。MinAge 是容器可以被执行垃圾回收的最小生命周期 。

MaxPerPodContainer 是每个 pod 内允许存在的死亡容器的最大数量。 MaxContainers 是全部死亡容器的最大数

量。可以分别独立地通过将 MinAge 设置为 0,以及将 MaxPerPodContainer 和 MaxContainers 设置为小于 0 来

禁用这些变量。 Kubelet 将处理无法辨识的、已删除的以及超出前面提到的参数所设置范围的容器。最老的容器通常会先被移除。 MaxPerPodContainer 和 MaxContainer 在某些场景下可能会存在冲突,例如在保证每个 pod 内死亡容器的最大数 量(MaxPerPodContainer࿰

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
首先,你需要确保已经安装了Kubernetes集群和Dashboard。然后,按照以下步骤安装和配置kubelet-dashboard: 1. 将kubelet-dashboard的镜像文件下载到本地: ``` $ docker pull mirrorgooglecontainers/kubelet-dashboard-amd64:v1.10.1 ``` 2. 将镜像文件推送到Kubernetes集群中的所有节点: ``` $ docker save mirrorgooglecontainers/kubelet-dashboard-amd64:v1.10.1 > kubelet-dashboard-amd64.tar $ scp kubelet-dashboard-amd64.tar user@node1:/tmp/ $ scp kubelet-dashboard-amd64.tar user@node2:/tmp/ $ scp kubelet-dashboard-amd64.tar user@node3:/tmp/ $ ssh user@node1 "docker load < /tmp/kubelet-dashboard-amd64.tar" $ ssh user@node2 "docker load < /tmp/kubelet-dashboard-amd64.tar" $ ssh user@node3 "docker load < /tmp/kubelet-dashboard-amd64.tar" ``` 3. 创建kubelet-dashboard的ServiceAccount和ClusterRoleBinding: ``` $ kubectl create -f https://raw.githubusercontent.com/kubernetes/dashboard/v1.10.1/src/deploy/recommended/kubernetes-dashboard.yaml ``` 4. 创建kubelet-dashboard的ConfigMap: ``` $ kubectl create configmap kubelet-dashboard-config --from-literal=kubelet_url=https://localhost:10250 ``` 5. 创建kubelet-dashboard的Deployment: ``` $ kubectl create -f https://raw.githubusercontent.com/kubernetes/dashboard/v1.10.1/src/deploy/recommended/kubernetes-dashboard.yaml ``` 6. 将kubelet-dashboard的Service暴露出来,以便能够通过Web浏览器访问: ``` $ kubectl expose deployment kubernetes-dashboard --type=NodePort --port=443 --target-port=8443 ``` 7. 获取kubelet-dashboard的访问地址: ``` $ kubectl describe service kubernetes-dashboard ``` 8. 通过Web浏览器访问kubelet-dashboard的访问地址,使用创建的ServiceAccount登录即可。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

意海还念か

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值