具有高磁盘使用率的Kubernetes节点由docker overlay引起

时间:2017-06-22 10:58:29

标签: docker amazon-ec2 kubernetes cadvisor aws-ebs

我在AWS上部署kubernetes节点时遇到问题。 (具有3个节点和1个主节点的集群在m3.large实例上运行,每个节点大约25GB)

在(大约3天)之后,磁盘上剩下0KB并且群集卡住了。

/ var / lib / docker / overlay /使用所有存储(或多或少)。 在此文件夹中大约有500个或更多这些文件:

drwx------ 3 root root 4096 Jun 20 15:33 ed4f90bd7a64806f9917e995a02974ac69883a06933033ffd5049dd31c13427a
drwx------ 3 root root 4096 Jun 20 15:28 ee9344fea422c38d71fdd2793ed517c5693b0c8a890964e6932befa1ebe5aa63
drwx------ 3 root root 4096 Jun 20 16:17 efed310a549243e730e9796e558b2ae282e07ea3ce0840a50c0917a435893d42
drwx------ 3 root root 4096 Jun 20 14:39 eff7f04f17c0f96cff496734fdc1903758af1dfdcd46011f6c3362c73c6086c2
drwx------ 3 root root 4096 Jun 20 15:29 f5bfb696f5a6cad888f7042d01bfe146c0621517c124d58d76e77683efa1034e
drwx------ 3 root root 4096 Jun 20 15:26 f5fa9d5d2066c7fc1c8f80970669634886dcaccc9e73ada33c7c250845d2fe8c
drwx------ 3 root root 4096 Jun 20 14:38 f8fd64fb1e0ab26708d5458dddd2d5a70018034237dfed3db48ada5666fcf77f
drwx------ 3 root root 4096 Jun 20 14:46 faa143ebd7a4079eaa45ddbf17dcfc9163e3035983f2e334e32a60e89452fa94
drwx------ 3 root root 4096 Jun 20 14:48 fb93c0c64e0d4935bf67fc8f70df2b8a4cffe59e294ee8a876dfdf6b57486da5
drwx------ 3 root root 4096 Jun 20 14:46 fd0a420d5655fb7d022c397effdb95968ff7e722c58fcc7915f97e8df47cd080

群集在Kubernetes 1.6.4和Docker 1.12.6上运行。

似乎是kubernetes垃圾收集器的问题。运行cAdvisor / validate会给我以下消息

 None of the devices support 'cfq' I/O scheduler. No disk stats can be reported.
     Disk "xvda" Scheduler type "none".

运行这些语句journalctl -u kubelet | grep -i garbage也会出现错误消息: Jun 20 14:35:21 ip-172-21-4-239 kubelet[1551]: E0620 14:35:21.986898 1551 kubelet.go:1165] Image garbage collection failed: unable to find data for container /

如何让垃圾收集器再次运行?

1 个答案:

答案 0 :(得分:0)

通过使用du -s /var/lib/docker/overlay/编辑kops cluster.spec,我能够解决因kops edit cluster [cluster_name]而导致节点重复出现高IO的类似问题。 我在规格下添加了以下内容:

docker:
    logDriver: json-file
    logLevel: warn
    storage: overlay2

默认情况下kops似乎将docker配置为使用overlay作为默认存储驱动程序,而docker建议使用overlay2更新,更稳定,更快。