我试图让Winston漂亮地打印到控制台上,所以我将其放在一个文件中,并使用node运行它:
var winston = require('winston');
winston.cli();
winston.data({
a: "test",
of: "many",
properties: {
like: "this"
}
});
winston.data('data', {
a: "test",
of: "many",
properties: {
like: "this"
}
});终端返回以下(不完全正确)消息:
data: a=test, of=many, like=this
data: data a=test, of=many, like=this我正在遵循Winston Readme上的说明(“在CLI工具中使用winston”)。我是不是读错了什么?在什么地方丢失了设置?
发布于 2013-08-01 15:02:18
我找到了答案(文档是不正确的)。如果使用构造函数并手动添加传输,则可以为winston和单个传输设置选项。某些选项需要直接添加到winston中,而其他选项则需要添加到传输中。
例如:
var winston = require('winston');
var logger = new (winston.Logger)({
levels: {
trace: 0,
input: 1,
verbose: 2,
prompt: 3,
debug: 4,
info: 5,
data: 6,
help: 7,
warn: 8,
error: 9
},
colors: {
trace: 'magenta',
input: 'grey',
verbose: 'cyan',
prompt: 'grey',
debug: 'blue',
info: 'green',
data: 'grey',
help: 'cyan',
warn: 'yellow',
error: 'red'
}
});
logger.add(winston.transports.Console, {
level: 'trace',
prettyPrint: true,
colorize: true,
silent: false,
timestamp: false
});
logger.add(winston.transports.File, {
prettyPrint: false,
level: 'info',
silent: false,
colorize: true,
timestamp: true,
filename: './nKindler.log',
maxsize: 40000,
maxFiles: 10,
json: false
});发布于 2018-03-02 04:00:44
如果你使用的是winston@3.0.0-rc0,那么接受的答案将不起作用。尝试以下操作:
const winston = require("winston");
let date = new Date().toISOString();
const logFormat = winston.format.printf(function(info) {
return `${date}-${info.level}: ${JSON.stringify(info.message, null, 4)}\n`;
});
const logger = winston.createLogger({
transports: [
new winston.transports.Console({
level: level,
format: winston.format.combine(winston.format.colorize(), logFormat)
})
]
});日志的格式如下:
是彩色的BTW
2018-03-01T19:49:54.042Z-info: "----- Customer Details ------"
2018-03-01T19:49:54.042Z-info: [
{
"A": 1,
"B": 2
}
]发布于 2019-02-14 05:10:34
这是Winston v3+的一个解决方案
let winstonFormat = winston.format.json();
if (NODE_ENV == "development") {
winstonFormat = winston.format.combine(winston.format.json(), winston.format.prettyPrint());
}
const log = winston.createLogger({
level: "info",
format: winstonFormat,
defaultMeta: {app: "myapp"},
transports: [
new winston.transports.File({filename: "/dev/stderr", level: "warn"}),
new winston.transports.File({filename: "/dev/stdout"}),
],
});https://stackoverflow.com/questions/17963406
复制相似问题