在Ubuntu系統(tǒng)中,配置node.js應(yīng)用程序日志的自動清理策略有多種途徑。以下是幾種常用的方法:
方法一:采用 logrotate 工具
logrotate 是一個專門用于日志管理的系統(tǒng)工具,能夠自動對日志文件進(jìn)行壓縮、刪除以及輪轉(zhuǎn)操作。
-
安裝 logrotate(如尚未安裝):
sudo apt-get update sudo apt-get install logrotate
-
構(gòu)建或修改 logrotate 配置文件: 你需要針對你的Node.JS應(yīng)用創(chuàng)建一個 logrotate 的配置文件,通常放置于 /etc/logrotate.d/ 目錄下。
sudo nano /etc/logrotate.d/nodejs-app
-
輸入配置信息: 在文件內(nèi)加入如下內(nèi)容,并依據(jù)實際狀況調(diào)整路徑與參數(shù):
/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 定時任務(wù)
若你使用 systemd 來管理Node.js應(yīng)用,可設(shè)定一個定時任務(wù)以完成日志清理工作。
-
編寫清理腳本: 建立一個腳本文件,比如 /usr/local/bin/clean-nodejs-logs.sh:
sudo nano /usr/local/bin/clean-nodejs-logs.sh
內(nèi)容如下:
#!/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天的日志文件。
-
賦予腳本執(zhí)行權(quán)限:
sudo chmod x /usr/local/bin/clean-nodejs-logs.sh
-
設(shè)立 systemd 定時任務(wù): 編輯一個 systemd 定時任務(wù)文件,例如 /etc/systemd/system/clean-nodejs-logs.timer:
sudo nano /etc/systemd/system/clean-nodejs-logs.timer
內(nèi)容如下:
[Unit] Description=Clean Node.js logs older than 7 days [Timer] OnCalendar=daily Persistent=true [Install] WantedBy=timers.target
-
建立 systemd 服務(wù)文件: 制作一個 systemd 服務(wù)文件,例如 /etc/systemd/system/clean-nodejs-logs.service:
sudo nano /etc/systemd/system/clean-nodejs-logs.service
內(nèi)容如下:
[Unit] Description=Clean Node.js logs older than 7 days [Service] ExecStart=/usr/local/bin/clean-nodejs-logs.sh
-
激活并啟動定時任務(wù):
sudo systemctl daemon-reload sudo systemctl enable clean-nodejs-logs.timer sudo systemctl start clean-nodejs-logs.timer
通過上述方法,你可以高效地管控Node.js應(yīng)用的日志文件,防止其占用過多的存儲空間。