在 CentOS 系統中,nohup 命令用于在后臺運行程序,即使關閉終端也不會中斷程序運行。默認情況下,nohup 會將輸出重定向到 nohup.out 文件中,但沒有內置的日志大小限制功能。如果你需要限制 nohup.out 文件的大小,可以使用以下幾種方法:
logrotatelogrotate 是一個用于管理日志文件的工具,可以自動輪轉、壓縮和刪除舊日志文件。
安裝 logrotate(如果尚未安裝):
sudo yum install logrotate
創建 logrotate 配置文件:
在 /etc/logrotate.d/ 目錄下創建一個新的配置文件,例如 nohup:
sudo nano /etc/logrotate.d/nohup
添加配置內容: 在文件中添加以下內容,根據需要調整日志文件路徑和大小限制:
/path/to/your/nohup.out {
size 100M
rotate 5
compress
missingok
notifempty
create 640 root root
}
解釋:
size 100M:當日志文件達到 100MB 時進行輪轉。rotate 5:保留 5 個輪轉日志文件。compress:壓縮舊日志文件。missingok:如果日志文件不存在,不會報錯。notifempty:如果日志文件為空,不進行輪轉。create 640 root root:創建新日志文件時的權限和所有者。測試配置:
sudo logrotate -f /etc/logrotate.d/nohup
split 命令split 命令可以將大文件分割成多個小文件。
運行程序并使用 split:
nohup your_command > >(split -b 100M - nohup_part_) 2>&1 &
解釋:
split -b 100M - nohup_part_:將輸出分割成每個 100MB 的小文件,文件名前綴為 nohup_part_。2>&1:將標準錯誤輸出重定向到標準輸出,一起分割。合并日志文件:
當需要查看完整日志時,可以使用 cat 命令合并分割的文件:
cat nohup_part_* > nohup.out
編寫一個自定義腳本來監控日志文件大小,并在達到指定大小時進行輪轉。
創建腳本:
sudo nano /usr/local/bin/logrotate_nohup.sh
添加腳本內容:
#!/bin/bash
LOG_FILE="/path/to/your/nohup.out"
MAX_SIZE=100M
BACKUP_COUNT=5
if [ -f "$LOG_FILE" ]; then
FILE_SIZE=$(stat -c%s "$LOG_FILE")
if [ "$FILE_SIZE" -gt $(numfmt --from=iec $MAX_SIZE) ]; then
TIMESTAMP=$(date +%Y%m%d%H%M%S)
mv "$LOG_FILE" "${LOG_FILE}_$TIMESTAMP"
touch "$LOG_FILE"
fi
fi
賦予執行權限:
sudo chmod +x /usr/local/bin/logrotate_nohup.sh
設置定時任務:
使用 cron 設置定時任務,定期運行腳本:
crontab -e
添加以下行,每分鐘運行一次腳本:
* * * * * /usr/local/bin/logrotate_nohup.sh
通過以上方法,你可以有效地管理 nohup 日志文件的大小,避免日志文件過大導致的問題。