温馨提示×

如何清理Node.js过期日志

小樊
129
2025-02-17 08:19:01
栏目: 编程语言

要清理Node.js过期日志,你可以使用一些第三方库,例如logrotate,或者编写自定义脚本来实现。下面是两种方法的详细说明:

方法一:使用logrotate

  1. 安装logrotate:

对于Debian/Ubuntu系统,可以使用以下命令安装:

sudo apt-get install logrotate 

对于RHEL/CentOS系统,可以使用以下命令安装:

sudo yum install logrotate 
  1. 创建一个logrotate配置文件,例如/etc/logrotate.d/nodejs,并添加以下内容:
/path/to/your/nodejs/logs/*.log { daily rotate 7 compress missingok notifempty create 0640 root adm } 

这里的配置表示每天轮转日志文件,保留最近7天的日志,压缩旧日志,如果日志文件丢失则不报错,如果日志文件为空则不轮转,创建新的日志文件时设置权限为0640,属主为root,属组为adm。

  1. 重新加载logrotate配置:
sudo logrotate -f /etc/logrotate.d/nodejs 

方法二:编写自定义脚本

你可以编写一个简单的Node.js脚本来清理过期日志。以下是一个示例脚本:

const fs = require('fs'); const path = require('path'); const logsDir = '/path/to/your/nodejs/logs'; const maxDays = 7; fs.readdir(logsDir, (err, files) => { if (err) { console.error('Error reading logs directory:', err); return; } const now = new Date(); files.forEach(file => { const filePath = path.join(logsDir, file); fs.stat(filePath, (err, stats) => { if (err) { console.error('Error reading log file stats:', err); return; } const ageInDays = Math.floor((now - stats.mtime) / (1000 * 3600 * 24)); if (ageInDays > maxDays) { fs.unlink(filePath, err => { if (err) { console.error('Error deleting log file:', err); } else { console.log(`Deleted expired log file: ${filePath}`); } }); } }); }); }); 

将此脚本保存为clean-old-logs.js,然后在命令行中运行node clean-old-logs.js。你可以将此脚本添加到cron作业中,以便定期清理过期日志。

注意:在运行这些脚本之前,请确保将/path/to/your/nodejs/logs替换为你的实际日志文件路径。

0