超简单的nodejs使用log4js保存日志到本地(可直接复制使用)

引入依赖

复制代码
npm install log4js

新建配置文件logUtil.js

javascript 复制代码
const log4js = require('log4js');

// 日志配置
log4js.configure({
    appenders: {
        // 控制台输出
        consoleAppender: { 
            type: 'console' 
        },
        // 文件输出
        fileAppender: {
            type: 'dateFile',
            filename: './logs/default',  //日志文件的存储名
            alwaysIncludePattern: true,  //(可选,默认false)将模式包含在当前日志文件的名称以及备份中
            pattern: "yyyy-MM-dd.log",
            encoding: 'utf-8', //(可选,默认为utf-8)文件数据的存储编码
            maxLogSize: 1024 * 1024 * 1 // 文件最大存储空间
        }
    },
    categories: {
        // 设置默认所有日志都记录
        default: { 
            appenders: ['consoleAppender', 'fileAppender'], 
            level: 'all' 
        } 
    }
});

module.exports = log4js

在服务文件index.js中设置全局引用

javascript 复制代码
const log4js = require('../utils/logUtil')

// 引入log4js配置,初始化全局对象
const logger = log4js.getLogger('default'); // 使用默认类别
global.logger = logger // 赋值给全局对象【logger】,也可以直接替换【console】
// global.console = logger

// 捕获未抓捕的异常,例如进程突然挂掉时的报错
process.on('uncaughtException', function (err) {
    logger.error(err.stack) // 保存错误的调用栈
});

然后就可以在所有js文件中通过使用如下方法打印日志了,打印的日志会同时输出在控制台及保存到本地文件夹中

javascript 复制代码
// 不同类型的输出
logger.log('log')
logger.info('info')
logger.error('error')
logger.debug('debug')
logger.warn('warn')
logger.trace('trace')
logger.fatal('fatal')
logger.mark('mark')
javascript 复制代码
// object类型的输出,可以使用【JSON.stringify(obj, null, 2)】的格式来输出
logger.error('------------------login fail-------------------')
logger.error('result : \n' + JSON.stringify(obj, null, 2))
logger.error('message : ' +  message)
logger.error('time : ' + nowTime)
logger.error('-----------------------------------------------')

效果如下:

相关推荐
码农阿豪12 小时前
Node.js 连金仓数据库(下篇):连接池、事务和那些坑
数据库·node.js
晓杰'12 小时前
从0到1实现Balatro游戏后端(7):Boss Blind与特殊规则实现
后端·websocket·typescript·node.js·游戏开发·项目实战·nestjs
右耳朵猫AI13 小时前
Node.js周刊2026W21 | Node.js 26.2.0、Bun v1.3.14、Rolldown 1.0、TypeORM 1.0
node.js
wgc2k14 小时前
Node.js游戏服务器项目移植 5-唯一 ID 生成方案
游戏·node.js
x***r15114 小时前
Node.js v0.12.2 安装教程(Windows x86版 node-v0.12.2-x86.msi 详细步骤)
windows·node.js
海兰15 小时前
【实用程序】 极简OA系统-详细设计及源码(基于Node.js + Express + SQLite + 原生前端)
sqlite·node.js·express
x***r1511 天前
nvm-windows 安装教程:Node.js 多版本管理(避坑版)
windows·node.js
云水一下1 天前
掌握 Express 框架:从零到 MVC 博客系统
node.js·express
米丘1 天前
HTTP 3xx 重定向类状态码
http·node.js
丑过三八线1 天前
npm 私有仓库找不到包的解决方案
前端·npm·node.js