在Ubuntu系統中,配置node.js應用程序日志的自動清理策略有多種途徑。以下是幾種常用的方法:
方法一:采用 logrotate 工具
logrotate 是一個專門用于日志管理的系統工具,能夠自動對日志文件進行壓縮、刪除以及輪轉操作。
-
安裝 logrotate(如尚未安裝):
sudo apt-get update sudo apt-get install logrotate
-
構建或修改 logrotate 配置文件: 你需要針對你的Node.JS應用創建一個 logrotate 的配置文件,通常放置于 /etc/logrotate.d/ 目錄下。
sudo nano /etc/logrotate.d/nodejs-app
-
輸入配置信息: 在文件內加入如下內容,并依據實際狀況調整路徑與參數:
/path/to/your/nodejs/app/logs/*.log { daily missingok rotate 7 compress notifempty create 0640 root adm }
說明:
-
驗證配置: 手動檢測 logrotate 配置是否有效:
sudo logrotate -f /etc/logrotate.d/nodejs-app
方法二:利用 systemd 定時任務
若你使用 systemd 來管理Node.js應用,可設定一個定時任務以完成日志清理工作。
-
編寫清理腳本: 建立一個腳本文件,比如 /usr/local/bin/clean-nodejs-logs.sh:
sudo nano /usr/local/bin/clean-nodejs-logs.sh
內容如下:
#!/bin/bash LOG_DIR="/path/to/your/nodejs/app/logs" find "$LOG_DIR" -type f -name "*.log" -mtime 7 -exec rm -f {} ;
解釋:
- -mtime 7: 刪除超過7天的日志文件。
-
賦予腳本執行權限:
sudo chmod x /usr/local/bin/clean-nodejs-logs.sh
-
設立 systemd 定時任務: 編輯一個 systemd 定時任務文件,例如 /etc/systemd/system/clean-nodejs-logs.timer:
sudo nano /etc/systemd/system/clean-nodejs-logs.timer
內容如下:
[Unit] Description=Clean Node.js logs older than 7 days [Timer] OnCalendar=daily Persistent=true [Install] WantedBy=timers.target
-
建立 systemd 服務文件: 制作一個 systemd 服務文件,例如 /etc/systemd/system/clean-nodejs-logs.service:
sudo nano /etc/systemd/system/clean-nodejs-logs.service
內容如下:
[Unit] Description=Clean Node.js logs older than 7 days [Service] ExecStart=/usr/local/bin/clean-nodejs-logs.sh
-
激活并啟動定時任務:
sudo systemctl daemon-reload sudo systemctl enable clean-nodejs-logs.timer sudo systemctl start clean-nodejs-logs.timer
通過上述方法,你可以高效地管控Node.js應用的日志文件,防止其占用過多的存儲空間。