Docker 容器日志查看和清理的實(shí)現(xiàn)步驟
Docker 容器日志查看
查看所有容器數(shù)據(jù)大小并按倒序排列:
du -d1 -h /var/lib/docker/containers | sort -rh
- du: 用于估算文件或目錄空間使用量。
- -d1: 僅顯示深度為1的目錄,即只顯示直接子目錄的信息。
- -h: 以人類可讀的格式顯示文件大小。
- /var/lib/docker/containers: 要查看的目錄路徑,這是 Docker 存儲(chǔ)容器數(shù)據(jù)的默認(rèn)路徑。
- sort -rh: 對(duì) du 的輸出進(jìn)行排序。-r 表示逆序(降序),-h 表示以人類可讀的格式排序(KB、MB、GB)。
上圖可以看到容器ID為 5c51773bc35d19d69c8f07895232295e4abeb0c9f25e25ca3884fec6ebd6f3fa
的數(shù)據(jù)較大。
cd /var/lib/docker/containers/5c51773bc35d19d69c8f07895232295e4abeb0c9f25e25ca3884fec6ebd6f3fa # 查看容器數(shù)據(jù)目錄下的文件大小 du -sh * | sort -rh
Docker 容器日志清理
單容器日志清理
直接使用 rm -rf <container-id>-json.log
刪除日志文件可能導(dǎo)致文件被占用,因?yàn)槿萜魅栽谶\(yùn)行,并且可能仍在使用該文件的文件描述符。這樣的操作可能會(huì)導(dǎo)致文件系統(tǒng)空間不會(huì)立即釋放。
為確保不中斷容器日志記錄,并釋放文件描述符,可以使用以下命令:
truncate -s 0 <container-id>-json.log
這個(gè)命令會(huì)將指定文件的大小截?cái)酁榱阕止?jié),但不會(huì)刪除文件。這樣,容器的日志文件會(huì)被清空,但文件描述符仍然保持打開,不會(huì)影響正在運(yùn)行的容器。
所有容器日志清理
創(chuàng)建了一個(gè)名為 clean_docker_logs.sh
的清理腳本
touch clean_docker_logs.sh vi clean_docker_logs.sh
復(fù)制下面內(nèi)容至 clean_docker_logs.sh
#!/bin/bash # Docker容器日志清理腳本 # 設(shè)置Docker日志文件存儲(chǔ)路徑 log_path="/var/lib/docker/containers" # 獲取所有容器ID container_ids=$(ls -1 $log_path) # 循環(huán)處理每個(gè)容器 for container_id in $container_ids; do # 構(gòu)造日志文件路徑 log_file="${log_path}/${container_id}/${container_id}-json.log" # 檢查日志文件是否存在 if [ -f "$log_file" ]; then echo "清理容器 ${container_id} 的日志文件: ${log_file}" # 清空日志文件 truncate -s 0 "$log_file" else echo "未找到容器 ${container_id} 的日志文件: ${log_file}" fi done echo "日志清理完成。"
將 clean_docker_logs.sh
腳本復(fù)制到 /usr/local/bin 目錄(這個(gè)目錄通常包含用戶自己安裝的可執(zhí)行文件),并給予執(zhí)行權(quán)限:
cp clean_docker_logs.sh /usr/local/bin/ chmod +x /usr/local/bin/clean_docker_logs.sh
然后執(zhí)行清理腳本:
sh /usr/local/bin/clean_docker_logs.sh
執(zhí)行完清理腳本查看所有容器的日志已清理完畢
定時(shí)清理
如果想將清理容器日志的操作做成一個(gè)定時(shí)任務(wù),可以使用 cron 作業(yè)。
編輯 cron 表
crontab -e
在文件末尾添加類似如下行,以每天凌晨凌晨執(zhí)行清理任務(wù)為例:
0 0 * * * /usr/local/bin/clean_docker_logs.sh
第一個(gè)字段(0):分鐘(0-59)
第二個(gè)字段(0):小時(shí)(0-23)
第三個(gè)字段():天(1-31)
第四個(gè)字段():月份(1-12)
第五個(gè)字段(*):星期幾(0-6,0 表示星期日)
Docker 容器的日志大小可以通過 Docker Daemon 的配置進(jìn)行全局設(shè)置,也可以通過在運(yùn)行容器時(shí)指定參數(shù)進(jìn)行單獨(dú)設(shè)置。
設(shè)置 Docker 容器日志大小限制
全局設(shè)置
要在 Docker Daemon 上全局設(shè)置日志大小,你需要修改 Docker Daemon 的配置文件(通常是 /etc/docker/daemon.json
)。
打開 Docker Daemon 配置文件:
nano /etc/docker/daemon.json
如果文件不存在,你可能需要?jiǎng)?chuàng)建它。在文件中添加以下配置:
{ "log-driver": "json-file", "log-opts": { "max-size": "10m", # 設(shè)置日志文件最大大小 "max-file": "3" # 設(shè)置最大日志文件數(shù)量 } }
這里的 "max-size": "10m"
表示每個(gè)日志文件的最大大小為 10MB,而 "max-file": "3"
表示保留最多 3 個(gè)舊的日志文件。
重新啟動(dòng) Docker 服務(wù),以應(yīng)用新的配置:
systemctl restart docker
單容器設(shè)置
如果你想為單個(gè)容器設(shè)置不同的日志大小,可以在運(yùn)行容器時(shí)使用 --log-opt
參數(shù)。
docker run -d --log-opt max-size=10m --log-opt max-file=3 your_image
這樣會(huì)覆蓋 Docker Daemon 全局設(shè)置,為該容器設(shè)置特定的日志大小。
常用命令
列出當(dāng)前目錄和文件的大小
du -h -x --max-depth=1 | sort -rh
- du:用于估算文件空間使用情況。
- -h:以人類可讀的格式顯示文件大?。ɡ纾?K、234M、2G)。
- -x:跳過不同文件系統(tǒng)的目錄。
- –max-depth=1:只顯示指定目錄的總計(jì),不進(jìn)入子目錄。
- sort -rh:以逆數(shù)值順序(-r)排序,并使用人類可讀的數(shù)值(-h)
到此這篇關(guān)于Docker 容器日志查看和清理的實(shí)現(xiàn)步驟的文章就介紹到這了,更多相關(guān)Docker 日志查看和清理內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Docker學(xué)習(xí)之基于Dockerfile搭建JAVA Tomcat運(yùn)行環(huán)境的方法
本篇文章主要介紹了Docker學(xué)習(xí)之基于Dockerfile搭建JAVA Tomcat運(yùn)行環(huán)境的方法,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下。2017-02-02使用Dockerfile部署nodejs服務(wù)的方法步驟
這篇文章主要介紹了使用Dockerfile部署nodejs服務(wù)的方法步驟,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2019-01-01docker-maven-plugin 插件無法拉取對(duì)應(yīng)jar包問題
這篇文章主要介紹了docker-maven-plugin 插件無法拉取問題,總是報(bào)錯(cuò),如何解決這個(gè)問題呢,下面小編給大家?guī)砹私鉀Q方法,一起看看吧2021-09-09Docker搭建Calibre-Web在線書庫的實(shí)現(xiàn)示例
本文主要介紹了Docker搭建Calibre-Web在線書庫的實(shí)現(xiàn)示例,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2023-01-01解決docker容器重啟之后/etc下某些配置文件被重置的問題
這篇文章主要介紹了解決docker容器重啟之后/etc下某些配置文件被重置的問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧2021-03-03docker從安裝入門到應(yīng)用部署及私有倉庫搭建基礎(chǔ)命令
這篇文章主要為大家介紹了docker從安裝入門到應(yīng)用部署及私有倉庫搭建基礎(chǔ)命令,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步早日升職加薪2022-04-04docker環(huán)境變量配置不生效/ect/profile的解決方法
docker在使用過程中,有時(shí)候自定義容器實(shí)例中的某些配置文件,本文主要介紹了docker環(huán)境變量配置不生效/ect/profile的解決方法,感興趣的可以了解一下2023-08-08docker?運(yùn)行花生殼實(shí)現(xiàn)內(nèi)外網(wǎng)穿透的詳細(xì)過程
這篇文章主要介紹了docker?運(yùn)行花生殼實(shí)現(xiàn)內(nèi)外網(wǎng)穿透,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2023-03-03