欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Docker 容器日志查看和清理的實(shí)現(xiàn)步驟

 更新時(shí)間:2023年11月28日 11:13:57   作者:有來技術(shù)  
在處理Docker容器的過程中,經(jīng)常需要查看容器的日志輸出來排查問題或者進(jìn)行系統(tǒng)監(jiān)控,本文主要介紹了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)文章

最新評(píng)論