Hello! 欢迎来到小浪云!


Node.js日志轮转策略如何设置


高效管理node.js应用日志:winston和winston-daily-rotate-file的日志轮转策略

Node.js日志轮转策略如何设置

本文介绍如何使用流行的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参数。

相关阅读