Docker在不重建容器的情况下,日志文件默认会一直追加,时间一长会逐渐占满服务器的硬盘的空间,内存消耗也会一直增加。
查出占用磁盘较大的文件
Docker 的日志文件存在 /var/lib/docker/containers
目录中,通过下面的命令可以将日志文件夹根据升序的方式罗列出来。
sudo du -d1 -h /var/lib/docker/containers | sort -h
40K /var/lib/docker/containers/7bbec35275e8f63784107d486c9c40cb62902afd6815c569b36947f0b0ed6405
40K /var/lib/docker/containers/7df78d67728173c13b4a238518b79d4b4a384d38026102a61aef290e53f2f1a6
32G /var/lib/docker/containers/c28a096b0594349c7b6cbf9d9931e652ac9f72a0d2c033a2fcb022c154aaf4e6
32G /var/lib/docker/containers
清理单个文件
感觉哪个容器的日志太大就清理哪个
sudo sh -c "cat /dev/null > ${log_file}"
${log_file}
就是日志文件
可以通过find
命令查找全部日志
sudo find /var/lib/docker/containers -name *.log
控制容器日志大小
以上只是临时解决的方式,最好是创建容器时就控制日志的大小。
运行时控制
启动容器时,我们可以通过参数来控制日志的文件个数和单个文件的大小
# max-size 最大数值``# max-file 最大日志数``$ docker run -it --log-opt max-size=10m --log-opt max-file=3 redis
一两个容器还好,但是如果有很多容器需要管理,这样就很不方便了,最好还是可以统一管理。
全局配置
创建或修改文件 /etc/docker/daemon.json
,并增加以下配置
{
"log-driver":"json-file",
"log-opts":{
"max-size" :"50m","max-file":"3"
}
}
max-size=50m,意味着一个容器日志大小上限是50M,
max-file=3,意味着一个容器有三个日志,分别是id+.json、id+1.json、id+2.json。可以存在的最大日志文件数。如果超过最大值,则会删除最旧的文件。**仅在max-size设置时有效。默认为5。
随后重启 Docker 服务
sudo systemctl daemon-reload``sudo systemctl restart docker
不过已存在的容器不会生效,需要重建才可以
删除最大日志文件后 磁盘空间没有释放。显示磁盘空间还是很小
通过停止容器 重新启动容器命令 来释放磁盘空间
#停止容器
docker stop 200cfb7a8db4
#启动容器
docker start 200cfb7a8db4