目錄
- docker設置日志文件大小及個數
- 容器范圍內
- 全局范圍內
- 參數說明
- 查出Docker容器日志并刪除腳本
- docker設置日志文件限制最多3個,最大5M
- 總結
docker設置日志文件大小及個數
docker容器在運行一定時間后會產生大量的日志,導致磁盤空間問題出現。
現在有2個方案可以限制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" ?? ?} }
修改后,docker需要重新加載配置文件和重啟。
CentOS7的操作
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容器。
docker設置日志文件限制最多3個,最大5M
Docker每個容器最多可以保留3個日志文件,每個文件限制為5M
在/etc/docker/daemon.json文件中的以下內容自動輪換日志:
{ ? "log-driver": "json-file", ? "log-opts": {"max-size": "5m", "max-file": "3"} }
配置完后重啟docker
systemctl reload docker
總結
以上為個人經驗,希望能給大家一個參考,也希望大家多多支持。