磁碟使用率 監控工具能夠在達到給定閾值時提醒我們。但它們無法自行解決 磁碟使用率 問題。需要手動干預才能解決該問題。
如果你想完全自動化此類操作,你會做什麼。是的,可以使用 bash 指令碼來完成。
該指令碼可防止來自 監控工具 的警報,因為我們會在填滿磁碟空間之前刪除舊的紀錄檔檔案。
我們過去做了很多 shell 指令碼。如果要檢視,請進入下面的連結。
我在本文中新增了兩個 bash 指令碼,它們有助於清除舊紀錄檔。
我們有一個名為 /var/log/app/
的資料夾,其中包含 15 天的紀錄檔,我們將刪除早於 10 天的資料夾。
$ ls -lh /var/log/app/drwxrw-rw- 3 root root 24K Oct 1 23:52 app_log.01drwxrw-rw- 3 root root 24K Oct 2 23:52 app_log.02drwxrw-rw- 3 root root 24K Oct 3 23:52 app_log.03drwxrw-rw- 3 root root 24K Oct 4 23:52 app_log.04drwxrw-rw- 3 root root 24K Oct 5 23:52 app_log.05drwxrw-rw- 3 root root 24K Oct 6 23:54 app_log.06drwxrw-rw- 3 root root 24K Oct 7 23:53 app_log.07drwxrw-rw- 3 root root 24K Oct 8 23:51 app_log.08drwxrw-rw- 3 root root 24K Oct 9 23:52 app_log.09drwxrw-rw- 3 root root 24K Oct 10 23:52 app_log.10drwxrw-rw- 3 root root 24K Oct 11 23:52 app_log.11drwxrw-rw- 3 root root 24K Oct 12 23:52 app_log.12drwxrw-rw- 3 root root 24K Oct 13 23:52 app_log.13drwxrw-rw- 3 root root 24K Oct 14 23:52 app_log.14drwxrw-rw- 3 root root 24K Oct 15 23:52 app_log.15
該指令碼將刪除早於 10 天的資料夾,並通過郵件傳送資料夾列表。
你可以根據需要修改 -mtime X
的值。另外,請替換你的電子郵箱,而不是用我們的。
# /opt/script/delete-old-folders.sh#!/bin/bashprev_count=0fpath=/var/log/app/app_log.*find $fpath -type d -mtime +10 -exec ls -ltrh {} \; > /tmp/folder.outfind $fpath -type d -mtime +10 -exec rm -rf {} \;count=$(cat /tmp/folder.out | wc -l)if [ "$prev_count" -lt "$count" ] ; thenMESSAGE="/tmp/file1.out"TO="[email protected]"echo "Application log folders are deleted older than 15 days" >> $MESSAGEecho "+----------------------------------------------------+" >> $MESSAGEecho "" >> $MESSAGEcat /tmp/folder.out | awk '{print $6,$7,$9}' >> $MESSAGEecho "" >> $MESSAGESUBJECT="WARNING: Apache log files are deleted older than 15 days $(date)"mail -s "$SUBJECT" "$TO" < $MESSAGErm $MESSAGE /tmp/folder.outfi
給 delete-old-folders.sh
設定可執行許可權。
# chmod +x /opt/script/delete-old-folders.sh
最後新增一個 cronjob 自動化此任務。它於每天早上 7 點執行。
# crontab -e0 7 * * * /bin/bash /opt/script/delete-old-folders.sh
你將看到類似下面的輸出。
Application log folders are deleted older than 20 days+--------------------------------------------------------+Oct 11 /var/log/app/app_log.11Oct 12 /var/log/app/app_log.12Oct 13 /var/log/app/app_log.13Oct 14 /var/log/app/app_log.14Oct 15 /var/log/app/app_log.15
我們有一個名為 /var/log/apache/
的資料夾,其中包含15天的紀錄檔,我們將刪除 10 天前的檔案。
以下文章與該主題相關,因此你可能有興趣閱讀。
# ls -lh /var/log/apache/-rw-rw-rw- 3 root root 24K Oct 1 23:52 2daygeek_access.01-rw-rw-rw- 3 root root 24K Oct 2 23:52 2daygeek_access.02-rw-rw-rw- 3 root root 24K Oct 3 23:52 2daygeek_access.03-rw-rw-rw- 3 root root 24K Oct 4 23:52 2daygeek_access.04-rw-rw-rw- 3 root root 24K Oct 5 23:52 2daygeek_access.05-rw-rw-rw- 3 root root 24K Oct 6 23:54 2daygeek_access.06-rw-rw-rw- 3 root root 24K Oct 7 23:53 2daygeek_access.07-rw-rw-rw- 3 root root 24K Oct 8 23:51 2daygeek_access.08-rw-rw-rw- 3 root root 24K Oct 9 23:52 2daygeek_access.09-rw-rw-rw- 3 root root 24K Oct 10 23:52 2daygeek_access.10-rw-rw-rw- 3 root root 24K Oct 11 23:52 2daygeek_access.11-rw-rw-rw- 3 root root 24K Oct 12 23:52 2daygeek_access.12-rw-rw-rw- 3 root root 24K Oct 13 23:52 2daygeek_access.13-rw-rw-rw- 3 root root 24K Oct 14 23:52 2daygeek_access.14-rw-rw-rw- 3 root root 24K Oct 15 23:52 2daygeek_access.15
該指令碼將刪除 10 天前的檔案並通過郵件傳送資料夾列表。
你可以根據需要修改 -mtime X
的值。另外,請替換你的電子郵箱,而不是用我們的。
# /opt/script/delete-old-files.sh#!/bin/bashprev_count=0fpath=/var/log/apache/2daygeek_access.*find $fpath -type f -mtime +15 -exec ls -ltrd {} \; > /tmp/file.outfind $fpath -type f -mtime +15 -exec rm -rf {} \;count=$(cat /tmp/file.out | wc -l)if [ "$prev_count" -lt "$count" ] ; thenMESSAGE="/tmp/file1.out"TO="[email protected]"echo "Apache Access log files are deleted older than 20 days" >> $MESSAGEecho "+--------------------------------------------- +" >> $MESSAGEecho "" >> $MESSAGEcat /tmp/file.out | awk '{print $6,$7,$9}' >> $MESSAGEecho "" >> $MESSAGESUBJECT="WARNING: Apache log folders are deleted older than 15 days $(date)"mail -s "$SUBJECT" "$TO" < $MESSAGErm $MESSAGE /tmp/file.outfi
給 delete-old-files.sh
設定可執行許可權。
# chmod +x /opt/script/delete-old-files.sh
最後新增一個 cronjob 自動化此任務。它於每天早上 7 點執行。
# crontab -e0 7 * * * /bin/bash /opt/script/delete-old-folders.sh
你將看到類似下面的輸出。
Apache Access log files are deleted older than 20 days+--------------------------------------------------------+Oct 11 /var/log/apache/2daygeek_access.11Oct 12 /var/log/apache/2daygeek_access.12Oct 13 /var/log/apache/2daygeek_access.13Oct 14 /var/log/apache/2daygeek_access.14Oct 15 /var/log/apache/2daygeek_access.15