高效管理node.js应用日志:winston和winston-daily-rotate-file的日志轮转策略
本文介绍如何使用流行的Node.JS日志库winston和winston-daily-rotate-file实现日志文件轮转,有效管理不断增长的日志文件。
步骤一:安装必要的库
首先,请确保已安装winston和winston-daily-rotate-file。使用npm安装:
npm install winston winston-daily-rotate-file
步骤二:配置日志轮转策略 (logger.js)
创建一个名为logger.js的文件,包含以下代码来配置日志记录器:
const winston = require('winston'); const { format } = winston; const DailyRotateFile = require('winston-daily-rotate-file'); // 日志格式化 const myFormat = format.combine( format.timestamp({ format: 'yyYY-MM-DD HH:mm:ss' }), format.errors({ stack: true }), format.splat(), format.json() ); // 日志轮转配置 const transport = new DailyRotateFile({ filename: 'logs/application-%DATE%.log', datePattern: 'YYYY-MM-DD', zippedArchive: true, // 压缩存档 maxSize: '20m', // 最大文件大小 maxFiles: '14d' // 保留最大天数 }); // 创建winston日志记录器实例 const logger = winston.createLogger({ level: 'info', format: myFormat, transports: [transport] }); module.exports = logger;
此配置将日志写入logs目录(需手动创建),每天生成一个新的日志文件,文件大小限制为20MB,并保留最多14天的日志。 日志采用JSON格式,包含时间戳和错误堆栈信息。
步骤三:在应用中使用日志记录器
在你的Node.js应用代码中引入并使用logger实例:
const logger = require('./logger'); logger.info('应用程序启动成功!'); logger.error('发生错误:', new Error('这是一个测试错误'));
通过以上步骤,你的Node.js应用将按照配置的策略进行日志轮转,方便日志管理和问题排查。 记得根据实际需求调整maxSize和maxFiles参数。