高效管理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参数。
以上就是Node.js日志轮转策略如何设置的详细内容,更多请关注php中文网其它相关文章!
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号