Docker 容器日志查看和清理的實(shí)現(xiàn)步驟
Docker 容器日志查看
查看所有容器數(shù)據(jù)大小并按倒序排列:
du -d1 -h /var/lib/docker/containers | sort -rh
- du: 用于估算文件或目錄空間使用量。
- -d1: 僅顯示深度為1的目錄,即只顯示直接子目錄的信息。
- -h: 以人類(lèi)可讀的格式顯示文件大小。
- /var/lib/docker/containers: 要查看的目錄路徑,這是 Docker 存儲(chǔ)容器數(shù)據(jù)的默認(rèn)路徑。
- sort -rh: 對(duì) du 的輸出進(jìn)行排序。-r 表示逆序(降序),-h 表示以人類(lèi)可讀的格式排序(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ì)被清空,但文件描述符仍然保持打開(kāi),不會(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è)目錄通常包含用戶(hù)自己安裝的可執(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
在文件末尾添加類(lèi)似如下行,以每天凌晨凌晨執(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 容器的日志大小可以通過(guò) Docker Daemon 的配置進(jìn)行全局設(shè)置,也可以通過(guò)在運(yùn)行容器時(shí)指定參數(shù)進(jìn)行單獨(dú)設(shè)置。
設(shè)置 Docker 容器日志大小限制
全局設(shè)置
要在 Docker Daemon 上全局設(shè)置日志大小,你需要修改 Docker Daemon 的配置文件(通常是 /etc/docker/daemon.json)。
打開(kāi) 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:以人類(lèi)可讀的格式顯示文件大?。ɡ?,1K、234M、2G)。
- -x:跳過(guò)不同文件系統(tǒng)的目錄。
- –max-depth=1:只顯示指定目錄的總計(jì),不進(jìn)入子目錄。
- sort -rh:以逆數(shù)值順序(-r)排序,并使用人類(lèi)可讀的數(shù)值(-h)
到此這篇關(guān)于Docker 容器日志查看和清理的實(shí)現(xiàn)步驟的文章就介紹到這了,更多相關(guān)Docker 日志查看和清理內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
使用Docker registry鏡像創(chuàng)建私有倉(cāng)庫(kù)的方法
本篇文章主要介紹了使用Docker registry鏡像創(chuàng)建私有倉(cāng)庫(kù)的方法,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下。2017-04-04
搭建docker-nginx服務(wù),訪(fǎng)問(wèn)nginx報(bào)錯(cuò)403問(wèn)題及解決
這篇文章主要介紹了搭建docker-nginx服務(wù),訪(fǎng)問(wèn)nginx報(bào)錯(cuò)403問(wèn)題及解決,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2025-03-03
Docker創(chuàng)建openresty容器的實(shí)現(xiàn)步驟
OpenResty可以用來(lái)構(gòu)建高性能的Web應(yīng)用和服務(wù),本文主要介紹了Docker創(chuàng)建openresty容器的實(shí)現(xiàn)步驟,文中通過(guò)示例代碼介紹的非常詳細(xì),需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2024-03-03
Docker容器之間數(shù)據(jù)傳輸?shù)膶?shí)現(xiàn)
本文主要介紹了Docker容器之間數(shù)據(jù)傳輸?shù)膶?shí)現(xiàn),文中根據(jù)實(shí)例編碼詳細(xì)介紹的十分詳盡,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2022-03-03
Docker使用Dockerfile創(chuàng)建支持ssh服務(wù)自啟動(dòng)的容器鏡像
這篇文章主要介紹了Docker使用Dockerfile創(chuàng)建支持ssh服務(wù)自啟動(dòng)的容器鏡像,需要的朋友可以參考下2016-10-10
Docker部署Spring-boot項(xiàng)目的示例代碼
這篇文章主要介紹了Docker部署Spring-boot的示例代碼,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2018-12-12
Docker安裝mysql教程以及解決mysqld: Can‘t read dir&nbs
本文詳細(xì)介紹了如何通過(guò)Docker來(lái)安裝和配置MySQL數(shù)據(jù)庫(kù),包括拉取MySQL鏡像、啟動(dòng)MySQL容器、配置MySQL、解決常見(jiàn)錯(cuò)誤等步驟,提供了詳盡的命令和參數(shù)說(shuō)明,幫助用戶(hù)順利完成MySQL的安裝和配置,文中還提到了如何處理MySQL容器啟動(dòng)時(shí)遇到的“無(wú)法讀取目錄”2024-10-10

