Debian 环境下 JavaScript 日志级别设置指南
一 前置说明
二 快速上手 Node.js 内置日志
// 级别映射:数值越大越详细
const levels = { error: 0, warn: 1, info: 2, debug: 3 };
const current = levels[process.env.LOG_LEVEL || 'info'];
function log(level, msg) {
if (levels[level] >= current) console[level](msg);
}
log('info', '服务已启动');
log('debug', '调试信息'); // 仅在 LOG_LEVEL=debug 时输出
LOG_LEVEL=debug node app.js
三 使用日志库 Winston 与 Pino
// npm i winston
const winston = require('winston');
const logger = winston.createLogger({
level: process.env.LOG_LEVEL || 'info',
format: winston.format.json(),
transports: [
new winston.transports.Console(),
new winston.transports.File({ filename: 'error.log', level: 'error' }),
new winston.transports.File({ filename: 'combined.log' })
]
});
logger.info('应用启动', { pid: process.pid });
logger.error('发生错误', { err: new Error('boom') });
// npm i pino
const pino = require('pino');
const logger = pino({ level: process.env.LOG_LEVEL || 'info' });
logger.info('应用启动');
logger.error({ err: new Error('boom') }, '发生错误');
四 框架与中间件日志
// npm i express morgan
const express = require('express');
const morgan = require('morgan');
const app = express();
// 开发:简洁;生产:combined(更详细)
app.use(morgan(process.env.NODE_ENV === 'development' ? 'dev' : 'combined'));
app.get('/', (req, res) => res.send('Hello World'));
app.listen(3000, () => console.log('Server on :3000'));
五 运行环境与进程管理
# 临时
LOG_LEVEL=debug node app.js
# 持久(当前会话)
export LOG_LEVEL=debug
node app.js
// ecosystem.config.js
module.exports = {
apps: [{
name: 'my-app',
script: 'app.js',
env: {
NODE_ENV: 'development',
LOG_LEVEL: 'debug'
},
env_production: {
NODE_ENV: 'production',
LOG_LEVEL: 'info'
}
}]
};
启动:
pm2 start ecosystem.config.js --env production
http {
log_level info; # 可选:debug | info | notice | warn | error
server { ... }
}
# 修改后执行:sudo systemctl restart nginx
{
"logging": { "level": "debug" }
}
读取:
const config = require('config');
const level = config.get('logging.level') || 'info';