溫馨提示×

nohup命令日志中如何實現日志輪轉

小樊
76
2025-04-17 02:43:46
欄目: 編程語言

nohup 命令用于在后臺運行程序,即使關閉終端或斷開連接,程序也會繼續運行。默認情況下,nohup 會將輸出重定向到名為 nohup.out 的文件中。為了實現日志輪轉,可以使用 logrotate 工具或者自定義腳本來實現。

使用 logrotate 實現日志輪轉

  1. 確保已經安裝了 logrotate。在大多數 Linux 發行版中,logrotate 已經預裝。如果沒有安裝,可以使用以下命令安裝:

    sudo apt-get install logrotate   # Debian/Ubuntu
    sudo yum install logrotate       # CentOS/RHEL
    
  2. 創建一個 logrotate 配置文件,例如 /etc/logrotate.d/myapp,并添加以下內容:

    /path/to/your/logs/nohup.out {
        daily
        rotate 7
        compress
        missingok
        notifempty
        create 0640 user group
    }
    

    這個配置表示每天輪轉一次日志,保留最近 7 天的日志,壓縮舊日志,如果日志文件不存在則不報錯,如果日志文件為空則不輪轉,創建新的日志文件并設置權限和屬主屬組。

  3. 確保 logrotate 定時任務已啟用。通常,logrotate 會自動運行,但你可以檢查 /etc/cron.daily/logrotate 文件是否存在并確保其可執行。

自定義腳本實現日志輪轉

如果你不想使用 logrotate,可以編寫一個簡單的 shell 腳本來實現日志輪轉。以下是一個示例腳本:

#!/bin/bash

LOG_FILE="/path/to/your/logs/nohup.out"
MAX_LOG_SIZE=104857600  # 100MB
BACKUP_COUNT=7

if [ -f "$LOG_FILE" ]; then
    LOG_SIZE=$(stat -c%s "$LOG_FILE")

    if [ "$LOG_SIZE" -gt "$MAX_LOG_SIZE" ]; then
        mv "$LOG_FILE" "${LOG_FILE}.$(date +%Y%m%d%H%M%S)"
        gzip "${LOG_FILE}.$(date +%Y%m%d%H%M%S)"
        touch "$LOG_FILE"
    fi
fi

# 移動舊日志文件并壓縮
find /path/to/your/logs -name "nohup.out.*" -type f -mtime +$BACKUP_COUNT -exec gzip {} \;

將此腳本保存為 rotate_logs.sh,并使用 chmod +x rotate_logs.sh 命令使其可執行。然后,你可以將此腳本添加到 cron 定時任務中,例如每天運行一次:

0 0 * * * /path/to/rotate_logs.sh

這樣,你的日志文件將在達到指定大小時自動輪轉,并保留指定數量的舊日志。

0
亚洲午夜精品一区二区_中文无码日韩欧免_久久香蕉精品视频_欧美主播一区二区三区美女