如何处理ephemeral-storage 不足问题

一、问题现象

# describe不能启动的pod,发现两条关键日志:
A. 0/1 nodes are available: 1 node(s) had taints that the pod didn't tolerate.
说明当前所在work-node资源不容许此pod部署,发生了pod驱逐。
B. The node was low on resource: ephemeral-storage.
说明了发生pod驱逐的原因。

二、问题查证过程

2.1 ephemeral-storage(短暂存储)的概念和作用

ephemeral-storage是为了管理和调度Kubernetes中运行的应用的短暂存储。

在每个Kubernetes的节点上,kubelet的根目录(默认是/var/lib/kubelet)和日志目录(/var/log)保存在节点的主分区上,这个分区同时也会被Pod的EmptyDir类型的volume、容器日志、镜像的层、容器的可写层所占用。ephemeral-storage便是对这块主分区进行管理,通过应用定义的需求(requests)和约束(limits)来调度和管理节点上的应用对主分区的消耗。

我们使用df -h可以看到/var/lib下有很多容器相关的目录,这些都是ephemeral-storage

2.2 image镜像重新下载

pod在启动时要重新下载相关镜像,说明由于磁盘容量不够时,kubernetes会清理镜像文件去腾空磁盘,省出资源去优先启动pod。

符合上述1中所述的“镜像层占用ephemeral-storage”。

2.3 本地pv存储占用磁盘

如2所述,kubernetes中的allinone的各个组件的持久化存储都是用的本地盘(系统盘)。

2.4 有些容器化组件没有使用持久存储

造成应用的日志全部打印到了容器里,也就是/var/log目录下,耗用了ephemeral-storage。

三、原因总结

根本原因:Kubernetes使用的系统盘容量不足;触发项如下:

1.image镜像太多,耗用太多ephemeral-storage;

2.本地pv存储全部挂载了系统盘目录下;

3.有些容器没有使用持久化存储,日志等全部打印到了ephemeral-storage。

四、解决方式

原则:让ephemeral-storage只存储kubernetes体系下的日志,系统盘容量要充足。

1.image镜像层的存储指定非系统盘;

2.本地pv存储挂载非系统盘;(生产环境禁止使用本地磁盘,必须使用独立盘或者云存储)

3.容器必须都使用持久化存储,禁止把日志都打到容器里。

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

CN-FuWei

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

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

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

打赏作者

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

抵扣说明:

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

余额充值