nodejs写入日志文件

不同日志的结果写入项目目录下的./logs/类型.log

实现结果如下

安装模块

js 复制代码
npm install winston

项目根目录下新建logger.js文件,内容如下:

js 复制代码
const winston = require('winston');
const fs = require('fs');
const path = require('path');

// 创建一个日志目录,如果不存在的话
const logDir = path.join(__dirname, 'logs');
if (!fs.existsSync(logDir)) {
  fs.mkdirSync(logDir);
}

const logger = winston.createLogger({
  // 定义日志级别
  levels: winston.config.npm.levels,
  // 自定义日志格式
  format: winston.format.combine(
    winston.format.timestamp({
      format: 'YYYY-MM-DD HH:mm:ss'
    }),
    winston.format.printf(info => `${info.timestamp} ${info.level}: ${info.message}`)
  ),
  // 定义不同的日志处理器(仅支持info,error,warn,http,verbose,debug,silly)
  transports: [
    // 日志处理器info
    new winston.transports.File({
      // 写入到./logs/info.log
      filename: path.join(logDir, 'info.log'),
      level: 'info'
    }),
    // 日志处理器error
    new winston.transports.File({
      // 写入到./logs/error.log
      filename: path.join(logDir, 'error.log'),
      level: 'error'
    }),
    // 日志处理器warn
    new winston.transports.File({
      // 写入到./logs/warn.log
      filename: path.join(logDir, 'warn.log'),
      level: 'warn'
    }),
    // 日志处理器http
    new winston.transports.File({
      // 写入到./logs/http.log
      filename: path.join(logDir, 'http.log'),
      level: 'http'
    }),
    // 日志处理器verbose
    new winston.transports.File({
      // 写入到./logs/verbose.log
      filename: path.join(logDir, 'verbose.log'),
      level: 'verbose'
    }),
    // 日志处理器debug
    new winston.transports.File({
      // 写入到./logs/debug.log
      filename: path.join(logDir, 'debug.log'),
      level: 'debug'
    }),
    // 日志处理器silly
    new winston.transports.File({
      // 写入到./logs/silly.log
      filename: path.join(logDir, 'silly.log'),
      level: 'silly'
    }),
    // 控制台输出
    new winston.transports.Console({
      // 控制台输出日志级别为 debug 或以上级别,写入到控制台
      level: 'debug',
      format: winston.format.combine(
        winston.format.colorize(),
        winston.format.simple()
      )
    })
  ],
  exitOnError: false // 禁止在日志写入失败时退出程序
});

// 异常处理
process.on('unhandledRejection', (ex) => {
  throw ex;
});

// 捕获未捕获的异常
process.on('uncaughtException', (ex) => {
  logger.error('Uncaught Exception:', ex);
  process.exit(1);
});

module.exports = logger;

在需要使用打印的地方只需要如下导入使用即可

js 复制代码
const logger = require('./logger');

// (仅支持info,error,warn,http,verbose,debug,silly)
logger.info('This is a successful operation.');
logger.error('This is an error operation.');
logger.warn('This is a warning operation.');
logger.http('This is a http operation.')
logger.verbose('This is a verbose operation.')
logger.debug('This is a debug operation.')
logger.silly('This is a silly operation.')

运行项目

不同的级别的日志打印的内容分别如下(一般使用info.log【打印成功和错误和警告级别】和error.log【仅仅打印错误级别】):

控制台级别输出打印如下(在控制台打印的结果):

js 复制代码
info: This is a successful operation. {"timestamp":"2024-10-25 11:29:51"}
error: This is an error operation. {"timestamp":"2024-10-25 11:29:51"}
warn: This is a warning operation. {"timestamp":"2024-10-25 11:29:51"}
http: This is a http operation. {"timestamp":"2024-10-25 11:29:51"}
verbose: This is a verbose operation. {"timestamp":"2024-10-25 11:29:51"}
debug: This is a debug operation. {"timestamp":"2024-10-25 11:29:51"}

logs/info.log内容如下:

js 复制代码
2024-10-25 11:29:51 info: This is a successful operation.
2024-10-25 11:29:51 error: This is an error operation.
2024-10-25 11:29:51 warn: This is a warning operation.

logs/error.log内容如下:

js 复制代码
2024-10-25 11:29:51 error: This is an error operation.

logs/warn.log内容如下:

js 复制代码
2024-10-25 11:29:51 error: This is an error operation.
2024-10-25 11:29:51 warn: This is a warning operation.

logs/http.log内容如下:

js 复制代码
2024-10-25 11:29:51 info: This is a successful operation.
2024-10-25 11:29:51 error: This is an error operation.
2024-10-25 11:29:51 warn: This is a warning operation.
2024-10-25 11:29:51 http: This is a http operation.

logs/verbose.log内容如下:

js 复制代码
2024-10-25 11:29:51 info: This is a successful operation.
2024-10-25 11:29:51 error: This is an error operation.
2024-10-25 11:29:51 warn: This is a warning operation.
2024-10-25 11:29:51 http: This is a http operation.
2024-10-25 11:29:51 verbose: This is a verbose operation.

logs/debug.log内容如下:

js 复制代码
2024-10-25 11:29:51 info: This is a successful operation.
2024-10-25 11:29:51 error: This is an error operation.
2024-10-25 11:29:51 warn: This is a warning operation.
2024-10-25 11:29:51 http: This is a http operation.
2024-10-25 11:29:51 verbose: This is a verbose operation.
2024-10-25 11:29:51 debug: This is a debug operation.

logs/silly.log内容如下:

js 复制代码
2024-10-25 11:29:51 info: This is a successful operation.
2024-10-25 11:29:51 error: This is an error operation.
2024-10-25 11:29:51 warn: This is a warning operation.
2024-10-25 11:29:51 http: This is a http operation.
2024-10-25 11:29:51 verbose: This is a verbose operation.
2024-10-25 11:29:51 debug: This is a debug operation.
2024-10-25 11:29:51 silly: This is a silly operation.
相关推荐
年纪轻轻就扛不住2 小时前
Express 入门指南(超详细教程)
前端·前端框架·node.js·express·js
爱电摇的小码农3 小时前
【深度探究系列(5)】:前端开发打怪升级指南:从踩坑到封神的解决方案手册
前端·javascript·css·vue.js·node.js·html5·xss
lihainuo6 小时前
Next.js + AI-SDK 实战:模型注册表从类型设计到工具调用全解析
后端·node.js
胡gh6 小时前
JavaScript 中的闭包、防抖与节流:让你彻底搞懂它们的作用和应用场景
前端·javascript·node.js
野槐7 小时前
vue3+node.js+mysql写接口(二)
node.js
讨厌吃蛋黄酥7 小时前
🚀 全栈开发48小时逆袭:用Node.js打造超炫实时数据仪表盘! 📊
node.js·全栈
天若有情6737 小时前
Node.js 是什么?npm 是什么? Vue 为什么需要他们?
vue.js·npm·node.js
爱敲代码的小冰9 小时前
npm 切换 node 版本 和npm的源
前端·npm·node.js
甜瓜看代码18 小时前
1.
react.js·node.js·angular.js
伍哥的传说18 小时前
React 实现五子棋人机对战小游戏
前端·javascript·react.js·前端框架·node.js·ecmascript·js