节点存在node.kubernetes.io/memory-pressure:NoSchedule,但节点内存充足

前言

环境:k8s1.20、3节点 node1、node2、node3

问题

执行ubectl describe node | grep -i taints 命令时发现node2节点存在污点,显示内存不足
Taints: node.kubernetes.io/memory-pressure:NoSchedule
查看节点的详情:
在这里插入图片描述
在这里插入图片描述
从上面的节点详情可以看出,node2节点可分配的内存时36G,已分配才是55Mi (0%),所以为什么会有内存不足的污点呢?尝试重启kubelet或手动删除污点,结果还是一样,污点会自动加上。
从上面的图中最后的一句Warning信息可以看到,kubelet企图回收内存,但是存在异常了。

查看node2节点内存如下,available内存是25G,free是10G。
在这里插入图片描述
查看node1节点内存:
在这里插入图片描述

查看node3节点内存:
在这里插入图片描述
可以看到,node1和node3的内存,无论是free 还是available,都比node2的小,那么为什么node1和node3没有内存压力污点,而node2有内存污点呢?

解决办法:
1、重启kubelet 、docker,仍然有内存压力污点;
2、排查网络插件flannel,flannel是running状态的,排查节点磁盘,磁盘空间充足。
3、决定清空服务器缓存
echo 3 > /proc/sys/vm/drop_caches
drop_caches的值可以是0-3之间的数字,代表不同的含义:
0:不释放(系统默认值)
1:释放页缓存
2:释放dentries和inodes
3:释放所有缓存

清空缓存后,内存变成了:
在这里插入图片描述
重启kubelet服务,这时没有节点内存压力了,节点正常了。
但是还是不明白为什么上面说的,node1和node3的内存,无论是free 还是available,都比node2的小,那么为什么node1和node3没有内存压力污点,而node2有内存污点呢?

猜你喜欢

转载自blog.csdn.net/MssGuo/article/details/132619411