gpt4 book ai didi

node.js - 如何为winston@3记录器制作自定义json格式化程序?

转载 作者:行者123 更新时间:2023-12-02 16:49:25 24 4
gpt4 key购买 nike

我正在尝试为 Winston v3 制作自定义 json 格式化程序。

这是一个带有演示的单个文件:

const { createLogger, format, transports } = require("winston")
const { combine, timestamp, prettyPrint } = format

const logger = createLogger({
format: combine(timestamp(), prettyPrint())
})

logger.add(new transports.Console())

logger.info("test message", { data: { a: 1, b: [1, 2, 3, 4], d: new Date() } })

try {
throw new Error("I'm an error!")
} catch (err) {
logger.error(err)
}

它打印:

{ data: { a: 1, b: [ 1, 2, 3, 4 ], d: 2018-07-21T08:59:27.958Z },
level: 'info',
message: 'test message',
timestamp: '2018-07-21T08:59:27.959Z',
[Symbol(level)]: 'info',
[Symbol(splat)]:
[ { data: { a: 1, b: [ 1, 2, 3, 4 ], d: 2018-07-21T08:59:27.958Z } } ] }
{ Error: I'm an error!
at Object.<anonymous> (/Users/max7z/projects/test/t32__test__winston__pretty-print_symbol/index.js:13:9)
at Module._compile (internal/modules/cjs/loader.js:689:30)
at Object.Module._extensions..js (internal/modules/cjs/loader.js:700:10)
at Module.load (internal/modules/cjs/loader.js:599:32)
at tryModuleLoad (internal/modules/cjs/loader.js:538:12)
at Function.Module._load (internal/modules/cjs/loader.js:530:3)
at Function.Module.runMain (internal/modules/cjs/loader.js:742:12)
at startup (internal/bootstrap/node.js:266:19)
at bootstrapNodeJSCore (internal/bootstrap/node.js:596:3)
level: 'error',
timestamp: '2018-07-21T08:59:27.962Z',
[Symbol(level)]: 'error' }

我想要几乎相同的输出,但没有一些字段:[Symbol(level)]、[Symbol(splat)]。

是否可以从 prettyPrint 格式化程序中删除 [Symbol] 字段?

或者我如何制作自己的自定义 json 格式化程序,并像 PrettyPrint 那样带有错误堆栈跟踪?

最佳答案

我使用 winston v3.3.3 测试了示例,并添加了一个自定义格式化程序来字符串化 data对象:

const winston = require('winston');

const myFormatter = winston.format((info) => {
const {message} = info;

if (info.data) {
info.message = `${message} ${JSON.stringify(info.data)}`;
delete info.data; // We added `data` to the message so we can delete it
}

return info;
})();

const logger = winston.createLogger({
format: winston.format.combine(
winston.format.timestamp({
format: 'YYYY-MM-DD HH:mm:ss',
}),
myFormatter,
winston.format.simple(),
),
transports: [
new winston.transports.Console(),
],
});

我运行了问题中的命令并得到了所需的输出。

执行:

logger.info('test message', {data: {a: 1, b: [1, 2, 3, 4], d: new Date()}});

try {
throw new Error(`I'm an error!`);
} catch (err) {
logger.error(err);
}

输出:

info: test message {"a":1,"b":[1,2,3,4],"d":"2020-09-09T09:41:22.525Z"} {"timestamp":"2020-09-09 11:41:22"}

error: I'm an error! {"timestamp":"2020-09-09 11:41:22"}

使用 winston.format.prettyPrint() 时,还可以使用制表符和换行符打印 JSON 对象而不是winston.format.simple() .

关于node.js - 如何为winston@3记录器制作自定义json格式化程序?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/51454523/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com