k8s修改 Kubelet 配置文件,避免乱驱逐!!!

这个文件是 kubelet基础服务文件 。但是,请先不要急着直接改这个文件里面的 ExecStart

修改时一定要记得做备份!!!!!!

⚠️ 重要提醒:不要直接改这里(99% 无效)

如果你是用 kubeadm 安装的集群(大部分情况都是),这个文件里的 ExecStart 会被另一个"覆盖文件"(Drop-in file)给忽略掉

那个覆盖文件通常在 /etc/systemd/system/kubelet.service.d/10-kubeadm.conf,它会清空这里的设置并用自己的参数启动。

所以,想要修改驱逐阈值,有以下两种真正有效的方法:


方法一:修改 Kubelet 配置文件(✅ 推荐,最稳妥)

这是官方推荐的方式。请检查你的节点上有没有 /var/lib/kubelet/config.yaml 这个文件。

1. 编辑配置文件

bash 复制代码
vim /var/lib/kubelet/config.yaml

2. 在文件末尾(或者合适的位置)添加 evictionHard 配置

注意缩进(YAML格式),要和 apiVersion 同级,或者直接加在文件最后(确保没有重复的 key):

yaml 复制代码
evictionHard:
  memory.available: "100Mi"    # 内存剩 100Mi 才驱逐
  nodefs.available: "5%"       # 磁盘剩 5% 才驱逐
  nodefs.inodesFree: "5%"
  imagefs.available: "5%"      # 镜像盘剩 5% 才驱逐

3. 重启生效

bash 复制代码
systemctl daemon-reload
systemctl restart kubelet

方法二:修改环境变量文件(✅ 仅次于配置文件)

如果你非要通过启动参数改,或者找不到 config.yaml,请修改 /etc/sysconfig/kubelet(CentOS)或者 /etc/default/kubelet(Ubuntu)。

1. 编辑环境文件

bash 复制代码
vim /etc/sysconfig/kubelet
# 如果文件不存在,就新建一个

2. 添加 KUBELET_EXTRA_ARGS

在里面写入:

bash 复制代码
KUBELET_EXTRA_ARGS="--eviction-hard=memory.available<100Mi,nodefs.available<5%,imagefs.available<5%"

3. 重启生效

bash 复制代码
systemctl daemon-reload
systemctl restart kubelet

方法三:如果你非要改你发的这个文件(❌ 不推荐)

只有 在你确定没有 安装 kubeadm,且没有 /etc/systemd/system/kubelet.service.d/ 目录的情况下,改这里才有用。

修改 ExecStart 这一行,把参数接在后面:

ini 复制代码
[Service]
# 修改下面这一行,加上 --eviction-hard 参数
ExecStart=/usr/bin/kubelet --eviction-hard=memory.available<100Mi,nodefs.available<5%,imagefs.available<5%
Restart=always
StartLimitInterval=0
RestartSec=10

改完后执行:

bash 复制代码
systemctl daemon-reload
systemctl restart kubelet

总结

建议直接用 方法一 (改 config.yaml)。如果你改了你发的那个文件但重启后发现没效果,肯定是因为被 kubeadm 的配置覆盖了,请回头用方法一或方法二。

相关推荐
阿里云云原生3 天前
阿里云获评 Agentic AI 开发平台领导者,函数计算 AgentRun 赢下关键分!
云原生
阿里云云原生4 天前
MSE Nacos Prompt 管理:让 AI Agent 的核心配置真正可治理
微服务·云原生
阿里云云原生4 天前
当 AI Agent 接管手机:移动端如何进行观测
云原生·agent
阿里云云原生4 天前
AI 原生应用开源开发者沙龙·深圳站精彩回顾 & PPT下载
云原生
阿里云云原生4 天前
灵感启发:日产文章 100 篇,打造“实时热点洞察”引擎
云原生
~莫子4 天前
Haproxy七层负载详解+实验详细代码
云原生
阿里云云原生4 天前
OpenTelemetry + 云监控 2.0:打造你的云原生全栈可观测
云原生
阿狸猿4 天前
云原生数据库
云原生·软考
至此流年莫相忘4 天前
Kubernetes实战篇之配置与存储
云原生·容器·kubernetes
阿里云云原生4 天前
OpenClaw 在严肃场景下的实践:迁移 Ingress NGINX
云原生