Docker / var / lib / docker / devicemapper / devicemapper使用2.7GB

时间:2016-07-04 08:32:07

标签: java docker device-mapper

我是codiva online ide的开发人员。每次用户运行java程序时,我们都会启动一个新容器。我们使用devicemapper存储驱动程序,因为这是我们能够设置容器大小上限的唯一方法。

使用几个月后,我们发现磁盘使用率正在增加,而/ var / lib / docker / devicemapper / devicemapper大约需要2.7GB。

我删除了所有未运行的docker容器,以及任何悬空卷,不幸的是,/ var / lib / docker / devicemapper / devicemapper的磁盘使用量仍然显示为2.7GB。

收回这个空间的最佳方法是什么?我们不需要任何持久存储,我们可以删除所有数据,因为任何需要存储的数据,我们直接挂载主机目录,并且这些文件在docker之外管理。

sudo docker ps -a
CONTAINER ID        IMAGE               COMMAND                  CREATED             STATUS              PORTS               NAMES

没有正在运行或甚至停止的容器。 这里的码头信息结果。

$ sudo docker info
Containers: 1
Images: 14
Server Version: 1.9.1
Storage Driver: devicemapper
 Pool Name: docker-202:1-143417-pool
 Pool Blocksize: 65.54 kB
 Base Device Size: 107.4 GB
 Backing Filesystem: ext4
 Data file: /dev/loop0
 Metadata file: /dev/loop1
 Data Space Used: 2.591 GB
 Data Space Total: 107.4 GB
 Data Space Available: 1.469 GB
 Metadata Space Used: 2.531 MB
 Metadata Space Total: 2.147 GB
 Metadata Space Available: 1.469 GB
 Udev Sync Supported: true
 Deferred Removal Enabled: false
 Deferred Deletion Enabled: false
 Deferred Deleted Device Count: 0
 Data loop file: /var/lib/docker/devicemapper/devicemapper/data
 Metadata loop file: /var/lib/docker/devicemapper/devicemapper/metadata
 Library Version: 1.02.77 (2012-10-15)
Execution Driver: native-0.2
Logging Driver: json-file
Kernel Version: 3.13.0-76-generic
Operating System: Ubuntu 14.04.3 LTS
CPUs: 1
Total Memory: 992.5 MiB
Name: ip-172-31-26-50
ID: NIQ5:2NDW:SB77:ZNZU:UO6G:EYLB:JIW7:SQLL:QLWY:LNRM:SU6P:ZS7X
WARNING: No swap limit support

没有悬空或孤儿卷。

sudo docker volume ls
DRIVER              VOLUME NAME

唯一的图片是java:8

sudo docker images
REPOSITORY          TAG                 IMAGE ID            CREATED             VIRTUAL SIZE
java                8                   289bdffc37d7        3 weeks ago         669.2 MB

我已按照说明https://lebkowski.name/docker-volumes/进行操作,但仍然使用了不必要的额外空间。

EDIT1: 我添加了docker images -a的结果。这显示了大量未命名的图像。大小似乎很可疑,因为所有这些图像的总和高达4.5GB,但我的整个/var/lib/docker只有大约2.7GB。

$ sudo docker images -a
REPOSITORY          TAG                 IMAGE ID            CREATED             VIRTUAL SIZE
java                8                   289bdffc37d7        3 weeks ago         669.2 MB
<none>              <none>              5d7cc49c4372        3 weeks ago         668.8 MB
<none>              <none>              9e756f3b105a        3 weeks ago         310.9 MB
<none>              <none>              7615ebf33bb7        3 weeks ago         310.9 MB
<none>              <none>              ac079291ad51        3 weeks ago         310.9 MB
<none>              <none>              cd02ed4609aa        3 weeks ago         310.9 MB
<none>              <none>              07bbd1c2007f        3 weeks ago         310.9 MB
<none>              <none>              6331ed9a346a        3 weeks ago         310.9 MB
<none>              <none>              b647ad8e0a08        3 weeks ago         310.9 MB
<none>              <none>              f23012d4423e        3 weeks ago         310.9 MB
<none>              <none>              0d3e866c82f3        3 weeks ago         301 MB
<none>              <none>              c28cbef85c39        3 weeks ago         169.7 MB
<none>              <none>              3f0d3d140ce1        3 weeks ago         125.1 MB
<none>              <none>              17bd2058e0c6        3 weeks ago         125.1 MB

在尝试其中一个时,我得到了错误。     $ sudo docker rmi 5d7cc49c4372     来自守护程序的错误响应:冲突:无法删除5d7cc49c4372(无法强制) - 图像具有依赖子图像     错误:无法删除图像:[5d7cc49c4372]

在阅读它时,似乎唯一需要的图像java:8取决于这些子图像。

$ sudo docker history 289bdffc37d7
IMAGE               CREATED             CREATED BY                                      SIZE                COMMENT
289bdffc37d7        3 weeks ago         /bin/sh -c /var/lib/dpkg/info/ca-certificates   418.2 kB            
5d7cc49c4372        3 weeks ago         /bin/sh -c set -x  && apt-get update  && apt-   357.9 MB            
7615ebf33bb7        3 weeks ago         /bin/sh -c #(nop) ENV CA_CERTIFICATES_JAVA_VE   0 B                 
9e756f3b105a        3 weeks ago         /bin/sh -c #(nop) ENV JAVA_DEBIAN_VERSION=8u9   0 B                 
ac079291ad51        3 weeks ago         /bin/sh -c #(nop) ENV JAVA_VERSION=8u91         0 B                 
07bbd1c2007f        3 weeks ago         /bin/sh -c #(nop) ENV JAVA_HOME=/usr/lib/jvm/   0 B                 
cd02ed4609aa        3 weeks ago         /bin/sh -c {   echo '#!/bin/sh';   echo 'set    87 B                
b647ad8e0a08        3 weeks ago         /bin/sh -c #(nop) ENV LANG=C.UTF-8              0 B                 
6331ed9a346a        3 weeks ago         /bin/sh -c echo 'deb http://httpredir.debian.   61 B                
f23012d4423e        3 weeks ago         /bin/sh -c apt-get update && apt-get install    9.93 MB             
0d3e866c82f3        3 weeks ago         /bin/sh -c apt-get update && apt-get install    131.2 MB            
c28cbef85c39        3 weeks ago         /bin/sh -c apt-get update && apt-get install    44.67 MB            
3f0d3d140ce1        3 weeks ago         /bin/sh -c #(nop) CMD ["/bin/bash"]             0 B                 
17bd2058e0c6        3 weeks ago         /bin/sh -c #(nop) ADD file:76679eeb94129df23c   125.1 MB 

这意味着,无法删除未标记的图像,我认为设计使用的总大小仍应为~670MB,因为docker仅存储相关图像的差异。

请告诉我如何减少devicemapper的磁盘使用情况。

2 个答案:

答案 0 :(得分:1)

您必须删除与容器关联的卷!

要实现此目的,请使用以下命令:

docker rm -v $(docker ps -a -q -f status=exited)

答案 1 :(得分:0)

这似乎是old bug with devicemapper,特别是如果您使用的是ext3。如果您使用的是ext3,那么upgrading to ext4可能会解决您的问题。该错误的主要症状是devicemapper不会释放已删除的图像和卷​​。

除此之外,你可以完全清除/ var / lib / docker并重新安装,因为你说你没有数据丢失。