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 的配置覆盖了,请回头用方法一或方法二。

相关推荐
飞舞花下5 小时前
微服务架构栈
微服务·云原生·架构
垂金烟柳11 小时前
使用 sealos 部署 k8s
云原生·容器·kubernetes
java1234_小锋11 小时前
Zookeeper集群数据是如何同步的?
分布式·zookeeper·云原生
沛沛老爹13 小时前
Web开发者实战A2A智能体交互协议:从Web API到AI Agent通信新范式
java·前端·人工智能·云原生·aigc·交互·发展趋势
Wilson Chen15 小时前
从“手搓”到云原生:某 B2B 平台服装 AI 搜索架构演进实战
人工智能·云原生·架构
Elastic 中国社区官方博客1 天前
使用 Elastic Cloud Serverless 扩展批量索引
大数据·运维·数据库·elasticsearch·搜索引擎·云原生·serverless
南宫乘风1 天前
Kubernetes 本地存储实战:Open-Local 从部署到生产级应用
云原生·容器·kubernetes
小股虫1 天前
分布式事务:在增长中台,我们如何做到“发出去的内容”和“记录的数据”不打架?
分布式·微服务·云原生·架构·团队建设·方法论
忧郁蓝调261 天前
Redis不停机数据迁移:基于 redis-shake 的跨实例 / 跨集群同步方案
运维·数据库·redis·阿里云·缓存·云原生·paas
java1234_小锋1 天前
ZooKeeper集群中服务器之间是怎样通信的?
分布式·zookeeper·云原生