如何設(shè)置Ubuntu Node.js日志的自動(dòng)清理策略

ubuntu系統(tǒng)中,配置node.JS應(yīng)用程序日志的自動(dòng)清理策略有多種途徑。以下是幾種常用的方法:

方法一:采用 logrotate 工具

logrotate 是一個(gè)專(zhuān)門(mén)用于日志管理的系統(tǒng)工具,能夠自動(dòng)對(duì)日志文件進(jìn)行壓縮、刪除以及輪轉(zhuǎn)操作。

  1. 安裝 logrotate(如尚未安裝)

     sudo apt-get update  sudo apt-get install logrotate
  2. 構(gòu)建或修改 logrotate 配置文件: 你需要針對(duì)你的Node.js應(yīng)用創(chuàng)建一個(gè) logrotate 的配置文件,通常放置于 /etc/logrotate.d/ 目錄下。

     sudo nano /etc/logrotate.d/nodejs-app
  3. 輸入配置信息: 在文件內(nèi)加入如下內(nèi)容,并依據(jù)實(shí)際狀況調(diào)整路徑與參數(shù):

     /path/to/your/nodejs/app/logs/*.log {      daily      missingok      rotate 7      compress      notifempty      create 0640 root adm  }

    說(shuō)明:

    • daily: 每天進(jìn)行日志輪轉(zhuǎn)。
    • missingok: 日志文件若不存在,不會(huì)觸發(fā)錯(cuò)誤提示。
    • rotate 7: 保存最近7次輪轉(zhuǎn)的日志記錄。
    • compress: 將舊日志文件壓縮。
    • notifempty: 若日志文件為空,則不執(zhí)行輪轉(zhuǎn)。
    • create 0640 root adm: 新建日志文件時(shí),權(quán)限設(shè)為0640,屬主為root,屬組為adm。
  4. 驗(yàn)證配置: 手動(dòng)檢測(cè) logrotate 配置是否有效:

     sudo logrotate -f /etc/logrotate.d/nodejs-app

方法二:利用 systemd 定時(shí)任務(wù)

若你使用 systemd 來(lái)管理Node.js應(yīng)用,可設(shè)定一個(gè)定時(shí)任務(wù)以完成日志清理工作。

  1. 編寫(xiě)清理腳本: 建立一個(gè)腳本文件,比如 /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 {} ;

    解釋?zhuān)?/p>

    • -mtime 7: 刪除超過(guò)7天的日志文件。
  2. 賦予腳本執(zhí)行權(quán)限

     sudo chmod  x /usr/local/bin/clean-nodejs-logs.sh
  3. 設(shè)立 systemd 定時(shí)任務(wù): 編輯一個(gè) systemd 定時(shí)任務(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
  4. 建立 systemd 服務(wù)文件: 制作一個(gè) 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
  5. 激活并啟動(dòng)定時(shí)任務(wù)

     sudo systemctl daemon-reload  sudo systemctl enable clean-nodejs-logs.timer  sudo systemctl start clean-nodejs-logs.timer

通過(guò)上述方法,你可以高效地管控Node.js應(yīng)用的日志文件,防止其占用過(guò)多的存儲(chǔ)空間。

? 版權(quán)聲明
THE END
喜歡就支持一下吧
點(diǎn)贊6 分享