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.
相关推荐
bjzhang758 小时前
Depcheck——专门用于检测 JavaScript 和 Node.js 项目中未使用依赖项的工具
javascript·node.js·depcheck
你不讲 wood12 小时前
使用 Axios 上传大文件分片上传
开发语言·前端·javascript·node.js·html·html5
tryCbest13 小时前
Nodejs安装配置及创建vue项目
vue.js·node.js
Luckyfif15 小时前
Webpack 是什么? 解决了什么问题? 核心流程是什么?
前端·webpack·node.js
熊的猫17 小时前
如何封装一个可取消的 HTTP 请求?
前端·javascript·vue.js·网络协议·http·webpack·node.js
黑金IT20 小时前
为什么使用Node.js爬虫更优
javascript·爬虫·node.js
API开发1 天前
APISQL企业版离线部署教程
sql·node.js·api·restful·graphql·apisql
前端小垃圾(找工作真难呐)2 天前
将项目从 Webpack 到 Vite 迁移的步骤
前端·webpack·node.js
黑金IT2 天前
Node.js与Python的交互:使用node-pyrunner模块
开发语言·python·node.js·交互
Fan_web2 天前
Node.js——初识Node.js
开发语言·前端·node.js