配置 kubelet 垃圾回收策略

垃圾回收是 kubelet 的一个有用功能,它将清理未使用的镜像和容器。Kubelet 将每分钟对容器执行一次垃圾回收,每五分钟对镜像执行一次垃圾回收。

不建议使用外部垃圾收集工具,因为这些工具可能会删除原本期望存在的容器进而破坏 kubelet 的行为。

镜像回收

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

镜像垃圾回收策略只考虑两个因素:HighThresholdPercentLowThresholdPercent。磁盘使用率超过上限阈值(HighThresholdPercent)将触发垃圾回收。垃圾回收将删除最近最少使用的镜像,直到磁盘使用率满足下限阈值(LowThresholdPercent)。

容器回收

容器垃圾回收策略考虑三个用户定义变量。MinAge 是容器可以被执行垃圾回收的最小生命周期。MaxPerPodContainer 是每个 pod 内允许存在的死亡容器的最大数量。MaxContainers 是全部死亡容器的最大数量。可以分别独立地通过将 MinAge 设置为 0,以及将 MaxPerPodContainerMaxContainers 设置为小于 0 来禁用这些变量。

Kubelet 将处理无法辨识的、已删除的以及超出前面提到的参数所设置范围的容器。最老的容器通常会先被移除。MaxPerPodContainerMaxContainer 在某些场景下可能会存在冲突,例如在保证每个 pod 内死亡容器的最大数量(MaxPerPodContainer)的条件下可能会超过允许存在的全部死亡容器的最大数量(MaxContainer)。MaxPerPodContainer 在这种情况下会被进行调整:最坏的情况是将 MaxPerPodContainer 降级为 1,并驱逐最老的容器。此外,pod 内已经被删除的容器一旦年龄超过 MinAge 就会被清理。

不被 kubelet 管理的容器不受容器垃圾回收的约束。

用户配置

用户可以使用以下 kubelet 参数调整相关阈值来优化镜像垃圾回收:

  • image-gc-high-threshold,触发镜像垃圾回收的磁盘使用率百分比。默认值为 85%。

  • image-gc-low-threshold,镜像垃圾回收试图释放资源后达到的磁盘使用率百分比。默认值为 80%。

我们还允许用户通过以下 kubelet 参数自定义垃圾收集策略:

  • minimum-container-ttl-duration,完成的容器在被垃圾回收之前的最小年龄,默认是 0 分钟,这意味着每个完成的容器都会被执行垃圾回收。

  • maximum-dead-containers-per-container,每个容器要保留的旧实例的最大数量。默认值为 1。

  • maximum-dead-containers,要全局保留的旧容器实例的最大数量。默认值是 -1,这意味着没有全局限制。

容器可能会在其效用过期之前被垃圾回收。这些容器可能包含日志和其他对故障诊断有用的数据。强烈建议为 maximum-dead-containers-per-container 设置一个足够大的值,以便每个预期容器至少保留一个死亡容器。由于同样的原因,maximum-dead-containers 也建议使用一个足够大的值。

查阅 这个问题 获取更多细节。

弃用

这篇文档中的一些 kubelet 垃圾收集(Garbage Collection)功能将在未来被 kubelet 驱逐回收(eviction)所替代。

包括:

现存参数新参数解释
—image-gc-high-threshold—eviction-hard—eviction-soft现存的驱逐回收信号可以触发镜像垃圾回收
—image-gc-low-threshold—eviction-minimum-reclaim驱逐回收实现相同行为
—maximum-dead-containers一旦旧日志存储在容器上下文之外,就会被弃用
—maximum-dead-containers-per-container一旦旧日志存储在容器上下文之外,就会被弃用
—minimum-container-ttl-duration一旦旧日志存储在容器上下文之外,就会被弃用
—low-diskspace-threshold-mb—eviction-hard or eviction-soft驱逐回收将磁盘阈值泛化到其他资源
—outofdisk-transition-frequency—eviction-pressure-transition-period驱逐回收将磁盘压力转换到其他资源

接下来

查阅 配置驱逐回收资源的策略 获取更多细节。

反馈

此页是否对您有帮助?

感谢反馈。如果您有一个关于如何使用 Kubernetes 的特定的、需要答案的问题,可以访问Stack Overflow.在 GitHub 仓库上登记新的问题报告问题或者提出改进建议.