问题:
docker容器日志导致主机磁盘空间满了。docker logs -f container_name噼里啪啦一大堆,很占用空间,不用的日志可以清理掉了。
解决方案 :
第一种 : 脚本实现
清理脚本:
#!/bin/sh # drift echo "==================== start clean docker containers logs ==========================" logs=$(find /var/lib/docker/containers/ -name *-json.log) for log in $logs do echo "clean logs : $log" cat /dev/null > $log done echo "==================== end clean docker containers logs =========================="
编写定时任务:
00 00 * * * /usr/local/bin/clean_logs.sh >/dev/null &
但是,这样清理之后,随着时间的推移,容器日志会像杂草一样,卷土重来。
第二种: 设置Docker容器日志大小(治本)
设置一个容器服务的日志大小上限,通过配置容器docker-compose的max-size选项来实现
driver: "json-file" options: max-size: "2g" # 日志文件大小 max-file: "10"# 日志的数量
重启容器之后,其日志文件的大小就被限制在2GB,再也不用担心了。
第三种: 全局设置(治根)
配置文件 /etc/docker/daemon.json 添加log-dirver和log-opts参数
{ "log-driver":"json-file", "log-opts": {"max-size":"500m", "max-file":"3"} }
max-size=500m,意味着一个容器日志大小上限是500M,
max-file=3,意味着一个容器有三个日志,分别是id+.json、id+1.json、id+2.json。
重启docker守护进程
systemctl daemon-reload systemctl restart docker
注意:设置的日志大小,只对新建的容器有效。