docker容器在運行一定時間后會產生大量的日志,導致磁盤空間問題出現。
容器范圍內
docker run或dokcer create時添加參數
如創建並運行
docker run --log-opt max-size=10m --log-opt max-file=3
全局范圍內
修改docker daemon.json文件,配置日志文件參數
默認 /etc/docker/daemon.json(注:添加時,直接全部復制下面的內容,在原有的配置下面另起一行粘貼)
{
"log-driver": "json-file",
"log-opts": {
"max-size": "50m",
"max-file": "1"
}
}
較全的daemon.json配置
$ cat <<EOF > /etc/docker/daemon.json
{
"registry-mirrors": ["https://xxxx"],
"live-restore": true,
"default-shm-size": "128M",
"max-concurrent-downloads": 10,
"oom-score-adjust": -1000,
"debug": false,
"exec-opts": ["native.cgroupdriver=cgroupfs"],
"data-root": "/mnt/data/docker-data",
"log-driver": "json-file",
"log-opts": {
"max-size": "20m",
"max-file": "3"
},
"storage-driver": "overlay2",
"storage-opts": [
"overlay2.override_kernel_check=true"
]
}
EOF
修改后,docker需要重新加載配置文件和重啟。
systemctl daemon-reload systemctl restart docker
注意:新創建的容器會生效,原有容器不生效。
log-opts max-size 容器日志文件上限大小
log-opts max-file 窗口日志文件上限個數
查出Docker容器日志並刪除腳本
默認查找目錄 /var/lib/docker/containers/
#!/bin/sh
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 ========"
docker容器正在運行的話,使用rm -rf方式刪除日志后,通過df -h會發現磁盤空間並沒有釋放。
原因是通過rm -rf刪除,將會從文件系統的目錄結構上解除鏈接(unlink)。
如果文件是被打開的(有一個進程正在使用),那么進程將仍然可以讀取該文件,磁盤空間也是一直被占用。
正確操作覆蓋操作 *cat /dev/null > -json.log。
或者可以通過rm -rf刪除后重啟docker容器。
