要清理Node.js舊日志文件,你可以使用以下方法:
在你的Node.js應用程序中,可以使用內置的文件系統模塊來讀取、刪除和操作文件。以下是一個簡單的示例,用于刪除特定目錄中的舊日志文件:
const fs = require('fs');
const path = require('path');
const logsDirectory = '/path/to/your/logs/directory';
fs.readdir(logsDirectory, (err, files) => {
if (err) {
console.error('Error reading logs directory:', err);
return;
}
files.forEach(file => {
const filePath = path.join(logsDirectory, file);
fs.stat(filePath, (err, stats) => {
if (err) {
console.error('Error getting file stats:', err);
return;
}
// 刪除超過30天的日志文件
if (stats.isFile() && Date.now() - stats.mtimeMs > 30 * 24 * 60 * 60 * 1000) {
fs.unlink(filePath, err => {
if (err) {
console.error('Error deleting log file:', err);
} else {
console.log(`Deleted old log file: ${filePath}`);
}
});
}
});
});
});
有許多第三方庫可以幫助你更方便地管理日志文件,例如 logrotate。這個庫可以自動地清理、壓縮和歸檔日志文件。要使用這個庫,首先需要安裝它:
npm install logrotate
然后,可以在你的Node.js應用程序中使用它:
const logrotate = require('logrotate');
const options = {
rotate: 30, // 保留最近30天的日志文件
compress: true, // 壓縮舊日志文件
path: '/path/to/your/logs/directory/*.log', // 日志文件的路徑和匹配模式
};
logrotate(options, (err) => {
if (err) {
console.error('Error configuring logrotate:', err);
} else {
console.log('Logrotate configured successfully');
}
});
你還可以使用操作系統的定時任務(如Linux的cron或Windows的任務計劃程序)來定期運行上面提到的Node.js腳本,以便自動清理舊日志文件。
例如,在Linux上,你可以創建一個cron任務,每天凌晨1點運行清理腳本:
0 1 * * * /usr/bin/node /path/to/your/cleanup-script.js
在Windows上,你可以使用任務計劃程序創建一個類似的計劃任務。