nohup 命令本身不直接支持日志輪轉。nohup 的主要作用是讓進程在用戶退出登錄后繼續運行,并將輸出重定向到指定的文件(通常是 nohup.out)。然而,你可以結合其他工具來實現日志輪轉。
以下是一些常見的方法:
logrotatelogrotate 是一個用于管理日志文件的系統工具,可以自動輪轉、壓縮和刪除舊日志文件。你可以配置 logrotate 來處理 nohup 生成的日志文件。
創建一個配置文件:
在 /etc/logrotate.d/ 目錄下創建一個新的配置文件,例如 myapp:
sudo nano /etc/logrotate.d/myapp
添加配置內容:
/path/to/nohup.out {
daily
rotate 7
compress
delaycompress
missingok
notifempty
create 640 root adm
}
解釋:
daily: 每天輪轉一次。rotate 7: 保留7個輪轉日志文件。compress: 壓縮舊日志文件。delaycompress: 延遲壓縮,直到下一次輪轉。missingok: 如果日志文件丟失,不要報錯。notifempty: 如果日志文件為空,不進行輪轉。create 640 root adm: 創建新日志文件時設置權限和所有者。測試配置:
sudo logrotate -f /etc/logrotate.d/myapp
syslog 或 rsyslog如果你希望將日志發送到系統的日志服務,可以使用 syslog 或 rsyslog。
修改啟動腳本:
在啟動腳本中,將 nohup 的輸出重定向到 syslog 或 rsyslog:
nohup your_command >> /dev/log 2>&1 &
或者使用 logger 命令:
nohup your_command | logger -t myapp
配置 rsyslog:
編輯 /etc/rsyslog.conf 或 /etc/rsyslog.d/50-default.conf,添加以下內容:
if $programname == 'myapp' then /var/log/myapp.log
& stop
這會將 myapp 的日志發送到 /var/log/myapp.log,并且不會繼續傳遞給其他規則。
重啟 rsyslog:
sudo systemctl restart rsyslog
通過這些方法,你可以有效地管理 nohup 命令生成的日志文件,實現日志輪轉和清理。