docker之如何設置日志文件大小及個數(shù)
docker設置日志文件大小及個數(shù)
docker容器在運行一定時間后會產(chǎn)生大量的日志,導致磁盤空間問題出現(xiàn)。
現(xiàn)在有2個方案可以限制docker容器日志文件大小及個數(shù)
容器范圍內(nèi)
docker run或dokcer create時添加參數(shù)
如創(chuàng)建并運行
docker run --log-opt max-size=10m --log-opt max-file=3
全局范圍內(nèi)
修改docker daemon.json文件,配置日志文件參數(shù)
默認 /etc/docker/daemon.json
{ ?? ?"log-driver": "json-file", ?? ?"log-opts": { ?? ??? ?"max-size": "50m", ?? ??? ?"max-file": "1" ?? ?} }
修改后,docker需要重新加載配置文件和重啟。
CentOS7的操作
systemctl daemon-reload systemctl restart docker
注意:新創(chuàng)建的容器會生效,原有容器不生效。
參數(shù)說明
參數(shù) | 說明 |
---|---|
log-opts max-size | 容器日志文件上限大小 |
log-opts max-file | 窗口日志文件上限個數(shù) |
查出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會發(fā)現(xiàn)磁盤空間并沒有釋放。
原因是通過rm -rf刪除,將會從文件系統(tǒng)的目錄結構上解除鏈接(unlink)。
如果文件是被打開的(有一個進程正在使用),那么進程將仍然可以讀取該文件,磁盤空間也是一直被占用。
正確操作覆蓋操作 *cat /dev/null > -json.log。
或者可以通過rm -rf刪除后重啟docker容器。
docker設置日志文件限制最多3個,最大5M
Docker每個容器最多可以保留3個日志文件,每個文件限制為5M
在/etc/docker/daemon.json文件中的以下內(nèi)容自動輪換日志:
{ ? "log-driver": "json-file", ? "log-opts": {"max-size": "5m", "max-file": "3"} }
配置完后重啟docker
systemctl reload docker
總結
以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。
相關文章
docker安裝rocketMQ和安裝過程中出現(xiàn)問題的解決
本文主要介紹了docker安裝rocketMQ和安裝過程中出現(xiàn)問題的解決,文中通過示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下2021-12-12在CentOS 7上安裝Docker環(huán)境的方法與注意事項
這篇文章主要介紹了在CentOS 7上安裝Docker環(huán)境的方法與注意事項,需要的朋友可以參考下2016-10-10在Ubuntu上使用Grafana監(jiān)控Docker的方法
如今越來越多的公司開始使用Docker,一談起Docker總是會跟著讓人聯(lián)想到輕量這個詞,甚至會有一種通過Docker啟動一個服務會節(jié)省很多資源的錯覺。然而Docker的「輕」也只是相對于傳統(tǒng)虛擬機而已。Docker如何監(jiān)控呢?本文就給大家介紹在Ubuntu上如何使用Grafana監(jiān)控Docker。2016-12-12