Winston: JSON 的循环结构:Sequelize 日志记录

创建于 2017-11-05  ·  3评论  ·  资料来源: winstonjs/winston

代码:

const winston = require('winston');

const sequelize = new Sequelize(config.db.database, config.db.username, config.db.password, {
    host: config.db.host,
    dialect: config.db.dialect,
    logging: winston.info // Not work it
});

版本:

winston: 3.0.0-rc1
sequelize: 4.22.2
mysql2: 1.4.2

错误堆栈:

Unhandled rejection TypeError: Converting circular structure to JSON
    at Object.stringify (native)
    at Format.transform (/demo/node_modules/logform/json.js:13:24)
    at DerivedLogger._transform (/demo/node_modules/winston/lib/winston/logger.js:218:25)
    at DerivedLogger.Transform._read (_stream_transform.js:167:10)
    at DerivedLogger.Transform._write (_stream_transform.js:155:12)
    at doWrite (_stream_writable.js:331:12)
    at writeOrBuffer (_stream_writable.js:317:5)
    at DerivedLogger.Writable.write (_stream_writable.js:243:11)
    at DerivedLogger.log (/demo/node_modules/winston/lib/winston/logger.js:174:8)
    at DerivedLogger.(anonymous function) [as info] (/demo/node_modules/winston/lib/winston/create-logger.js:54:16)
    at winston.(anonymous function) (/demo/node_modules/winston/lib/winston.js:84:34)
    at Sequelize.log (/demo/node_modules/sequelize/lib/sequelize.js:1062:23)
    at Query.run (/demo/node_modules/sequelize/lib/dialects/mysql/query.js:39:22)
    at retry (/demo/node_modules/sequelize/lib/sequelize.js:543:32)
    at /demo/node_modules/retry-as-promised/index.js:39:21
    at Promise._execute (/demo/node_modules/bluebird/js/release/debuggability.js:300:9)
    at Promise._resolveFromExecutor (/demo/node_modules/bluebird/js/release/promise.js:483:18)
    at new Promise (/demo/node_modules/bluebird/js/release/promise.js:79:10)
    at retryAsPromised (/demo/node_modules/retry-as-promised/index.js:29:10)
    at Promise.try.then.connection (/demo/node_modules/sequelize/lib/sequelize.js:543:14)
    at tryCatcher (/demo/node_modules/bluebird/js/release/util.js:16:23)
    at Promise._settlePromiseFromHandler (/demo/node_modules/bluebird/js/release/promise.js:512:31)

解决方案替代
用过的
循环-json
实例
https://github.com/winstonjs/logform/blob/master/json.js#L13

最有用的评论

我相信这与续集而不是温斯顿有关。
我们在将 sequelize 升级到版本 4 后遇到了这个问题。
我认为,从这个版本开始,使用两个参数 sql 和一些 sequelize 对象(我不记得对象到底是什么)调用了一个日志记录函数。 winston 尝试记录传递的每个参数,因此它也尝试了 sequelize 对象,什么不打算记录。

要解决此问题,请尝试将 winston 日志调用包装到另一个函数中。

const winston = require('winston');

const sequelize = new Sequelize(config.db.database, config.db.username, config.db.password, {
    host: config.db.host,
    dialect: config.db.dialect,
    logging: function(sql, sequelizeObject) {
        winston.info(sql); // Not work it
    }
});

所有3条评论

我相信这与续集而不是温斯顿有关。
我们在将 sequelize 升级到版本 4 后遇到了这个问题。
我认为,从这个版本开始,使用两个参数 sql 和一些 sequelize 对象(我不记得对象到底是什么)调用了一个日志记录函数。 winston 尝试记录传递的每个参数,因此它也尝试了 sequelize 对象,什么不打算记录。

要解决此问题,请尝试将 winston 日志调用包装到另一个函数中。

const winston = require('winston');

const sequelize = new Sequelize(config.db.database, config.db.username, config.db.password, {
    host: config.db.host,
    dialect: config.db.dialect,
    logging: function(sql, sequelizeObject) {
        winston.info(sql); // Not work it
    }
});

谢谢@matuszeman!

感谢一堆@matuszeman ,我为此

此页面是否有帮助?
0 / 5 - 0 等级

相关问题

anks333 picture anks333  ·  3评论

Nepoxx picture Nepoxx  ·  4评论

ghost picture ghost  ·  4评论

xungwoo picture xungwoo  ·  3评论

bertolo1988 picture bertolo1988  ·  3评论