機(jī)房有一臺(tái)服務(wù)器上面部署了多個(gè)docker容器, 并且每個(gè)docker容器都往stderr中源源不斷的輸出日志,導(dǎo)致磁盤被占滿了。Docker容器在啟動(dòng)/重啟的時(shí)候會(huì)往/var/lib/docker中寫數(shù)據(jù),如果你在啟動(dòng)docker容器遇到"No space left on device"的問題旱物,可以按照下面的步驟進(jìn)行清理相關(guān)的日志操作。
1)對(duì)/var/lib/docker/containers下的文件夾進(jìn)行排序卫袒,看看哪個(gè)容器占用了太多的磁盤空間
下面命令會(huì)按照升序的方式對(duì)于容器文件夾進(jìn)行排序宵呛,并列出容器文件夾的大小:
[root@docker ~]# du -d1 -h /var/lib/docker/containers | sort -h
36K /var/lib/docker/containers/4d91f92dd7604216f2e9e123572e9a80d7bbee3d8c8ce7be2ed241c572816fb
640K /var/lib/docker/containers/374aa0ba92b37d829012282ff15c1bb838d95dedb54589874c4285991be2d4aa
40K /var/lib/docker/containers/7cfdbc453b2f7109b52e974061754266e6cdc0ccaee62ab4a5887865113e1144
40K /var/lib/docker/containers/84ee24989ad52383c6e99eaa4d236e600095aa7f855e81fbafe10416b75ceefb
40K /var/lib/docker/containers/aeced3ef3e23df27e52f65743bb05448b46a2c660acc5b0aab12604e060779b4
40K /var/lib/docker/containers/ebd1bd211a1b9d02bb39bfb80eec3d0960a5b25e18f54d7371781ec456e7a1e8
176K /var/lib/docker/containers/1fe0a241e5ce9726c547c68739793633f9dd906768a36fe80e8fb80373aa3bfb
17M /var/lib/docker/containers/ac30e68d454b37d22b3964053a2b52ba043baa1add13556a09c0e3e05589104f
25M /var/lib/docker/containers/872ca4e3d005594591ca2df0e832d36eef448981ab2820c69df4ff1399f8423e
2)選擇你要清理的容器進(jìn)行清理
cat /dev/null > /var/lib/docker/containers/container_id/container_log_name
如下命令會(huì)清空對(duì)應(yīng)的日志,如:
[root@docker ~]# cat /dev/null > /var/lib/docker/containers/374aa0ba92b37d829012282ff15c1bb838
3)限制docker容器日志文件的大小
啟動(dòng)容器時(shí),可以通過參數(shù)設(shè)置日志文件的大小夕凝、日志文件的格式宝穗。
[root@docker ~]# docker run -it --log-opt max-size=10m --log-opt max-file=3 centos
docker日常運(yùn)維中幾個(gè)常用小命令
列出所有的容器 ID
#docker ps -aq
停止所有的容器
# docker stop $(docker ps -aq)
刪除所有的容器
# docker rm $(docker ps -aq)
刪除所有的鏡像
# docker rmi $(docker images -q)
復(fù)制文件
# docker cp mycontainer:/opt/file.txt /data/html