在Linux系统中,Node.js应用程序的日志轮转可以通过多种方式实现。以下是几种常见的方法:
使用logrotate工具
logrotate是Linux系统自带的日志管理工具,可用于日志文件的轮转、压缩和删除。以下是使用logrotate处理Node.js应用程序日志文件的步骤:
-
安装logrotate(如果未安装):
-
Debian/Ubuntu:
sudo apt-get install logrotate
-
CentOS/RHEL:
sudo yum install logrotate
-
-
创建logrotate配置文件:通常,logrotate的配置文件位于
/etc/logrotate.d/
目录下。你可以为你的Node.js应用程序创建一个新的配置文件,例如/etc/logrotate.d/node-app
。sudo nano /etc/logrotate.d/node-app
添加以下内容:
/var/log/node-app.log { daily rotate 7 compress missingok notifempty copytruncate dateext }
-
测试logrotate:
sudo logrotate -f /etc/logrotate.d/node-app
如果配置正确,
node-app.log
会被重命名为node-app.log-YYYYMMDD.gz
,并创建一个新的空日志文件。
使用PM2的日志管理功能
如果你的Node.js服务器使用PM2进行进程管理,可以让PM2处理日志轮转。以下是配置PM2轮转策略的步骤:
-
启用PM2日志轮转:
pm2 install pm2-logrotate
-
配置PM2轮转策略:
pm2 set pm2-logrotate:max_size 10M pm2 set pm2-logrotate:retain 7 pm2 set pm2-logrotate:compress true pm2 set pm2-logrotate:rotateInterval "0 0 * * *"
-
重启PM2:
pm2 restart all
PM2会自动在
/.pm2/logs/
目录下轮转日志。
使用Node.js日志库
你还可以在Node.js应用程序内部处理日志轮转,使用一些流行的日志库,如Winston或Pino,它们都支持日志轮转功能。以下是使用Winston库实现日志轮转策略的示例:
-
安装Winston和winston-daily-rotate-file:
npm install winston winston-daily-rotate-file
-
配置Winston日志轮转:
const winston = require('winston'); const { createLogger, format, transports } = winston; const DailyRotateFile = require('winston-daily-rotate-file'); const transport = new DailyRotateFile({ filename: 'application-%DATE%.log', datePattern: 'YYYY-MM-DD-HH', zippedArchive: true, maxSize: '20m', maxFiles: '14d' }); const logger = winston.createLogger({ level: 'info', format: winston.format.combine( winston.format.timestamp({ format: 'YYYY-MM-DD HH:mm:ss' }), winston.format.printf(({ timestamp, level, message }) => { return `${timestamp} ${level}: ${message}`; }) ), transports: [transport] }); module.exports = logger;
-
在应用中使用日志记录器:
const logger = require('./logger'); logger.info('This is an info message'); logger.error('This is an error message');
通过以上几种方法,你可以有效地管理和轮转Node.js应用程序的日志文件。选择哪种方法取决于你的具体需求和环境。