2016-02-16 107 views
1

我正在託管一些簡單的碼頭容器。我想知道容器的尺寸會隨着時間的推移而迅速增加,我不知道如何找出問題所在。碼頭磁盤使用情況

由泊塢報道尺寸:

[email protected]:~$ sudo docker ps -s 
CONTAINER ID  IMAGE    COMMAND     CREATED    STATUS    PORTS        NAMES    SIZE 
02b30add1cb3  my-service    "npm start"    23 hours ago  Up 23 hours   3001/tcp, 0.0.0.0:9017->9017/tcp my-service-frontend  0 B (virtual 776.4 MB) 
20a2be4931e7  my-service    "phantomjs src/sites/" 23 hours ago  Up 23 hours   0.0.0.0:3007->3001/tcp    my-service-5  6.144 kB (virtual 776.4 MB) 
ba340ba08941  my-service    "phantomjs src/sites/" 23 hours ago  Up 23 hours   0.0.0.0:3006->3001/tcp    my-service-4  6.144 kB (virtual 776.4 MB) 
7b5411d8a171  my-service    "phantomjs src/sites/" 23 hours ago  Up 23 hours   0.0.0.0:3003->3001/tcp    my-service-1  6.144 kB (virtual 776.4 MB) 
b583a544b37d  my-service    "phantomjs src/sites/" 23 hours ago  Up 23 hours   0.0.0.0:3001->3001/tcp    my-service-0  6.144 kB (virtual 776.4 MB) 
91373086e06e  foo_bar     "/bin/sh -c 'git pull" 47 hours ago  Up 47 hours   0.0.0.0:12776->8080/tcp   kickass_murdock  11.26 MB (virtual 1.081 GB) 

尺寸由du主機報告:

[email protected]:~$ sudo du -h -d 1 /var/lib/docker/containers 
14G  /var/lib/docker/containers/20a2be4931e7a10b2e29260b541e3c4d6581462650e47d59682f84626843752b 
1,6G /var/lib/docker/containers/7b5411d8a171a35a3c937d62dbdea141fc0a9f3c4de25a2da3a0b94ea71a8f3d 
9,6M /var/lib/docker/containers/02b30add1cb3ba6d5be1c36b2c9dd141d8d70cb88a021d2363af5684ef3c220f 
480K /var/lib/docker/containers/91373086e06ea83269465e0b026cfe7ca0158a1315b0df04da9a1d1b4ee52823 
13G /var/lib/docker/containers/b583a544b37db6144f17a4819ca2f636126b11d668caab3dcdbf4c3a33dedc65 
13G /var/lib/docker/containers/ba340ba08941d47af45230be328ef7289c19b6bb6a0d120cf2098cbdd9983f65 
40G /var/lib/docker/containers` 

尺寸由du用於容器(類似的輸出對於所有其它容器)報道:

[email protected]:~$ sudo docker exec -it my-service-4 du -h -d1 -c/
58M /root 
0 /dev 
3.0M /etc 
706M /usr 
1.4M /tmp 
14M /var 
9.0M /bin 
32M /lib 
4.0K /home 
8.0K /run 
4.0K /mnt 
4.0K /boot 
0 /sys 
4.0K /opt 
4.0K /srv 
4.0K /lib64 
3.9M /sbin 
du: cannot access '/proc/12642/task/12642/fd/3': No such file or directory 
du: cannot access '/proc/12642/task/12642/fdinfo/3': No such file or directory 
du: cannot access '/proc/12642/fd/3': No such file or directory 
du: cannot access '/proc/12642/fdinfo/3': No such file or directory 
0 /proc 
4.0K /media 
825M /
825M total 

所以:容器和docker ps報告磁盤使用量低於1G,但實際的容器文件大小超過10 GB(至少對某些用戶來說)。任何人都可以幫助我並告訴發生了什麼?我想我的容器內有一些麻煩,儘管我現在不知道該去哪裏看。任何人都知道我必須做什麼?

回答

1

無論何時將更改存儲到映像中,Docker都會在其洋蔥文件系統上放置一層。當您刪除容器docker rmi -f CONTAINERID時,應該會看到/ var/lib/docker /容器使用較少的空間。

當您構建圖像時,會更改圖像。如果您只是使用圖片 - 運行容器 - 更改的數據只是「保留」。所以你應該調查你的容器中發生了什麼。 ESP。看看你的幻影服務器在文件系統中產生了什麼。 ncdu將是一個很好的工具。

從ncdu開始,然後將生成的文件存儲在主機文件系統的附加文件夾中。 docker run -it -v FULLPATHATHOST:FULLPATHWITHINCONTAINER CONTAINERID

測試

運行一個簡單的容器,含無非OS以上(在我的情況高山)

docker run -it stk/alpine:base sh 

在主機去/var/lib/docker/aufs/diff/與ncdu列出包含目錄。 (當然你可以使用任何其他程序,你要確定diretories大小)

ncdu 1.10 ~ Use the arrow keys to navigate, press ? for help      
--- /var/lib/docker/aufs/diff -------------------------------------------------- 
         /..              
    286,4MiB [##########] /39f3e2ea0dfe17366b8cd7b0...bf3681b99a1081e33ad62a509f28 
    214,3MiB [####### ] /2de39307b9361cae12f0116e...d28056e4699b21b9a4d34f374461 
    207,7MiB [####### ] /92ec6d044cb3e39ae0050012...78d0591675f2231daafbf0877778 
    154,0MiB [#####  ] /9f3806e6bedc8fb01929131b...e01aa1980aadba914fdd9d2f96ae 
    149,5MiB [#####  ] /5f0ca2331640639507d85b83...693659438367311abb0c792b8a62 
    136,8MiB [####  ] /902b87aaaec929e805414868...1f529ad7f37ab300d4ef9f3a0dbf 
    136,2MiB [####  ] /222ba86561913d299deb9e0e...6b5f5ec117b01386a4156d092687 
    132,6MiB [####  ] /8b3a9a9eeaf8ed59f24f21a2...dfe8d033890a2fa44b445deb2e3c 
    128,5MiB [####  ] /72b3edf317a8d682466c1500...a5e2cad31c8305ed42c41cd61149 
    117,0MiB [####  ] /818e3763e72ef82b28b0552e...b9f163dc601d266e94e46fd26bb0 
    57,4MiB [##  ] /eeffdfafed9f60771b5bf87a...e8bbd16b572f77899c8e689d174d 
    56,1MiB [#   ] /6976ce3ed5fab37382d90467...37578332417ffcf35a1d499eba52 
    51,3MiB [#   ] /a5a6e0549d247f1c8b81a350...c5071f46d17afe2f8988817360b3 
Total disk usage: 2,7GiB Apparent size: 2,7GiB Items: 168658       

在容器內執行類似

tr -dc A-Za-z0-9 </dev/urandom | head -c 409600000 > a.txt && ls a.txt -all -h 

,將創建一個名爲a.txt隨機數據的文件我選用了大小409600000比286,4MiB更大 - 在/var/lib/docker/aufs/diff/最大的文件夾 - 這樣ncdu應顯示它在頂部

ncdu 1.10 ~ Use the arrow keys to navigate, press ? for help      
--- /var/lib/docker/aufs/diff -------------------------------------------------- 
         /..              
    390,6MiB [##########] /0720a07653a57d938c861cf3...e61c81c29f12289759f0560aa38f 
    286,4MiB [####### ] /39f3e2ea0dfe17366b8cd7b0...bf3681b99a1081e33ad62a509f28 
    214,3MiB [#####  ] /2de39307b9361cae12f0116e...d28056e4699b21b9a4d34f374461 
    207,7MiB [#####  ] /92ec6d044cb3e39ae0050012...78d0591675f2231daafbf0877778 
    154,0MiB [###  ] /9f3806e6bedc8fb01929131b...e01aa1980aadba914fdd9d2f96ae 
    149,5MiB [###  ] /5f0ca2331640639507d85b83...693659438367311abb0c792b8a62 
    136,8MiB [###  ] /902b87aaaec929e805414868...1f529ad7f37ab300d4ef9f3a0dbf 
    136,2MiB [###  ] /222ba86561913d299deb9e0e...6b5f5ec117b01386a4156d092687 
    132,6MiB [###  ] /8b3a9a9eeaf8ed59f24f21a2...dfe8d033890a2fa44b445deb2e3c 
    128,5MiB [###  ] /72b3edf317a8d682466c1500...a5e2cad31c8305ed42c41cd61149 
    117,0MiB [##  ] /818e3763e72ef82b28b0552e...b9f163dc601d266e94e46fd26bb0 
    57,4MiB [#   ] /eeffdfafed9f60771b5bf87a...e8bbd16b572f77899c8e689d174d 
    56,1MiB [#   ] /6976ce3ed5fab37382d90467...37578332417ffcf35a1d499eba52 
Total disk usage: 3,0GiB Apparent size: 3,0GiB Items: 168678       

現在我知道它是以0720a07653a57d9...開頭的目錄是我必須尋找的。進入它並列出內容

[email protected]:/var/lib/docker/aufs/diff# cd 0720a07653a57d938c861cf32f4bee87fa4be61c81c29f12289759f0560aa38f 
[email protected]:/var/lib/docker/aufs/diff/0720a07653a57d938c861cf32f4bee87fa4be61c81c29f12289759f0560aa38f# ls -all -h 
insgesamt 391M 
drwxr-xr-x 5 root root 4,0K Feb 23 10:55 . 
drwxr-xr-x 674 root root 80K Feb 23 10:55 .. 
-rw-r--r-- 1 root root 391M Feb 23 10:57 a.txt 
drwx------ 2 root root 4,0K Feb 23 10:55 root 
-r--r--r-- 1 root root 0 Feb 23 10:55 .wh..wh.aufs 
drwx------ 2 root root 4,0K Feb 23 10:55 .wh..wh.orph 
drwx------ 2 root root 4,0K Feb 23 10:55 .wh..wh.plnk 

正如你所看到的,有文件a.txt列出。

現在重新運行程序,創建隨機文件並重新連接ncdu(只需在ncdu中點擊r即可。)

ncdu應該告訴你,還有ls應該這樣做,即目錄大小沒有變化。所以docker fs中的數據就被覆蓋了。如果你選擇一個小尺寸,它會變小。

那麼這對你有什麼幫助? 正如我上面顯示的那樣,文件內的數據更改沒有文件增長。你可以找到女巫目錄包含你的文件系統,並看到你的容器內添加/更改文件的普通文件結構。

希望這有助於查找您的容器內的文件。

如果退出容器並再次通過同一命令重新啓動它,則會創建一個新實例,並創建一個新的實例,並創建它自己的fs圖層。

你可以找到你停止容器的id使用

docker ps -a | grep Exited | grep stk/alpine:base | awk '{print $1 }' 

看到的是前delete一個發現...

docker ps -a | grep Exited | grep stk/alpine:base 

7b7d3f6e857a  stk/alpine:base   "sh"      22 minutes ago  Exited (0) 2 minutes ago       gigantic_swartz 
2f51ea988a28  stk/alpine:base   "sh"      23 minutes ago  Exited (0) 22 minutes ago       cranky_euler 
4bfafbb034fe  stk/alpine:base   "sh"      34 minutes ago  Exited (0) 25 minutes ago       sick_williams 
80cd5687fcd7  stk/alpine:base   "sh"      44 minutes ago  Exited (137) 37 minutes ago      determined_panini 
a2179a8dd543  stk/alpine:base   "sh"      58 minutes ago  Exited (130) 44 minutes ago      agitated_shockley 
8596cd310292  stk/alpine:base   "sh"      3 days ago   Exited (137) 3 days ago       dreamy_murdock 
33db61a7830b  stk/alpine:base   "sh"      3 days ago   Exited (0) 3 days ago        desperate_hodgkin 
2f96c15dc8a1  stk/alpine:base   "sh"      2 weeks ago   Exited (0) 2 weeks ago       determined_babbage 

連接| xargs -r docker rm刪除它們

一號線解決方案

docker ps -a | grep Exited | grep stk/alpine:base | awk '{print $1 }' | xargs -r docker rm 

Docker將檢查圖像是否未被其他圖像使用,並且抱怨如果您無法刪除圖像docker rmi。但在這種情況下,您希望容器而不是圖像被刪除。因此,使用rm代替rmi(我更新了答案)

享受

+0

感謝。是的,當我移除我的容器時,磁盤空間再次釋放。問題是我找不到在我的容器中創建的任何文件。我使用'sudo docker exec -it my-service-4 du -h -d1 -c /'來調查正在運行的容器的磁盤使用情況。雖然/ var/lib/docker/containers中的容器不斷增加,但這個磁盤使用量始終保持不變。 – Thomas

相關問題