docker 設置日志文件大小及個數


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容器。


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM