JavaScript后端日志系统:使用Winston构建专业日志

Winston是Node.js生态中最流行的日志库之一,它提供了强大的日志记录功能,支持多种传输方式和格式化选项。

安装Winston

bash 复制代码
pnpm i winston

基础使用示例

javascript 复制代码
const winston = require('winston')
const path = require('path')

// 创建日志格式
const logFormat = winston.format.combine(
  winston.format.timestamp({ format: 'YYYY-MM-DD HH:mm:ss' }),
  winston.format.errors({ stack: true }),
  winston.format.json(),
)

// 创建控制台格式(开发环境使用)
const consoleFormat = winston.format.combine(
  winston.format.colorize(),
  winston.format.timestamp({ format: 'YYYY-MM-DD HH:mm:ss' }),
  winston.format.printf(({ timestamp, level, message, ...meta }) => {
    return `${timestamp} [${level}]: ${message} ${Object.keys(meta).length ? JSON.stringify(meta, null, 2) : ''}`
  }),
)

// 创建logger实例
const logger = winston.createLogger({
  level: process.env.LOG_LEVEL || 'info',
  format: logFormat,
  defaultMeta: { service: 'vue3-big-event-backend' },
  transports: [
    // 错误日志文件
    new winston.transports.File({
      filename: path.join(__dirname, '../../logs/error.log'),
      level: 'error',
      maxsize: 5242880, // 5MB
      maxFiles: 5,
    }),
    // 所有日志文件
    new winston.transports.File({
      filename: path.join(__dirname, '../../logs/combined.log'),
      maxsize: 5242880, // 5MB
      maxFiles: 5,
    }),
  ],
})

// 开发环境添加控制台输出
if (process.env.NODE_ENV !== 'production') {
  logger.add(
    new winston.transports.Console({
      format: consoleFormat,
    }),
  )
}

// 创建日志中间件
const requestLogger = (req, res, next) => {
  const start = Date.now()

  res.on('finish', () => {
    const duration = Date.now() - start
    logger.info('HTTP请求', {
      method: req.method,
      url: req.url,
      statusCode: res.statusCode,
      duration: `${duration}ms`,
      userAgent: req.get('User-Agent'),
      ip: req.ip,
    })
  })

  next()
}

// 错误日志中间件
const errorLogger = (err, req, res, next) => {
  logger.error('服务器错误', {
    message: err.message,
    stack: err.stack,
    url: req.url,
    method: req.method,
    ip: req.ip,
  })
  next(err)
}

module.exports = {
  logger,
  requestLogger,
  errorLogger,
}

如何使用

1. 在Express应用中使用

javascript 复制代码
const { requestLogger, errorLogger } = require('./utils/log/index.js')

app.use(requestLogger) // 请求日志
app.use(errorLogger)   // 错误日志

2. 在代码中记录日志

javascript 复制代码
const { logger } = require('./utils/log')

// 不同级别的日志
logger.info('用户登录成功', { username: 'john', ip: '192.168.1.1' })
logger.warn('API调用频繁', { endpoint: '/api/users' })
logger.error('数据库连接失败', { error: err.message })

3. 环境变量配置

bash 复制代码
# 设置日志级别
LOG_LEVEL=debug

# 生产环境不输出控制台日志
NODE_ENV=production

主要特性

  • 多级别日志:debug、info、warn、error、fatal
  • 多种输出目标:文件、控制台、数据库等
  • 结构化日志:JSON格式便于分析
  • 日志轮转:自动管理日志文件大小和数量
  • 开发环境友好:彩色控制台输出

以上就是本篇全部内容,感兴趣还请三连支持一波!灰常感谢!

相关推荐
qq_297574676 小时前
【实战教程】SpringBoot 集成阿里云短信服务实现验证码发送
spring boot·后端·阿里云
韩立学长7 小时前
【开题答辩实录分享】以《智能大学宿舍管理系统的设计与实现》为例进行选题答辩实录分享
数据库·spring boot·后端
编码者卢布10 小时前
【Azure Storage Account】Azure Table Storage 跨区批量迁移方案
后端·python·flask
她说..12 小时前
策略模式+工厂模式实现审批流(面试问答版)
java·后端·spring·面试·springboot·策略模式·javaee
梦梦代码精13 小时前
开源、免费、可商用:BuildingAI一站式体验报告
开发语言·前端·数据结构·人工智能·后端·开源·知识图谱
李慕婉学姐14 小时前
【开题答辩过程】以《基于Spring Boot的疗养院理疗管理系统的设计与实现》为例,不知道这个选题怎么做的,不知道这个选题怎么开题答辩的可以进来看看
java·spring boot·后端
tb_first14 小时前
SSM速通2
java·javascript·后端
一路向北⁢14 小时前
Spring Boot 3 整合 SSE (Server-Sent Events) 企业级最佳实践(一)
java·spring boot·后端·sse·通信
风象南14 小时前
JFR:Spring Boot 应用的性能诊断利器
java·spring boot·后端
爱吃山竹的大肚肚15 小时前
微服务间通过Feign传输文件,处理MultipartFile类型
java·spring boot·后端·spring cloud·微服务