Sequelize与log4js结合使用

本文介绍如何将Sequelize框架的日志输出整合到log4js中,实现更灵活的日志管理和记录。文章提供了具体的配置代码示例,包括如何重新定义日志输出方法来避免出现特定错误。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

Sequelize与log4js结合使用

1.如何将Sequelize的日志通过log4js进行输出。

log.js

const log4js = require('log4js');
const config = require('config');

log4js.configure({
    appenders: {
        deepLink: {
            type: 'file', filename: config.get("log.filename")
        },
        stdout: {
            type: 'stdout'
        }
     },
    categories: {
        default: {
            appenders: ['deepLink','stdout'],
            level: config.get("log.level")
        }
    }
});

const logger = log4js.getLogger('default');

//重新写了info方法
function info(message){
    logger.info(message)
}

exports.logger = logger
exports.log4js = log4js
exports.info = info

database.js

const Sequelize = require('sequelize')
const config = require('config');
const log = require('../log/log')

module.exports = new Sequelize(config.get("mysql.database"), config.get("mysql.username"), config.get("mysql.password"), {
    host: config.get("mysql.host"),
    dialect: 'mysql',
    pool: {
        max: config.get("mysql.pool.max"),
        min: config.get("mysql.pool.min"),
        acquire: config.get("mysql.pool.acquire"),
        idle: config.get("mysql.pool.idle")
    },
    //如果选择log.logger.info,会有Cannot read property 'isLevelEnabled' of null的异常。
    logging:log.info
})
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值