35

我试图让温斯顿漂亮地打印到控制台,所以我把它放在一个文件中并用节点运行它:

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 自述文件(“在 CLI 工具中使用 winston”)中的说明进行操作。我误读了什么吗?在某处缺少设置?

4

5 回答 5

31

我想出了答案(文档不正确)。如果您使用构造函数并手动添加传输,则可以为 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
});
于 2013-08-01T07:02:18.050 回答
28

如果您使用的是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)
    })
  ]
});

日志将具有以下格式:

顺便说一句,它是彩色的

2018-03-01T19:49:54.042Z-info: "----- Customer Details ------"

2018-03-01T19:49:54.042Z-info: [
    {
        "A": 1,
        "B": 2
    }
]
于 2018-03-01T20:00:43.513 回答
9

这是 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"}),
    ],
  });
于 2019-02-13T21:10:34.370 回答
3

我接受了@partycoder 的回答并将其缩减为仅使用winston 附带的默认日志记录级别。它也不会颠倒错误的顺序。0 = 最高优先级。

winston.addColors({
  silly: 'magenta',
  debug: 'blue',
  verbose: 'cyan',
  info: 'green',
  warn: 'yellow',
  error: 'red'
});

winston.remove(winston.transports.Console);
winston.add(winston.transports.Console, {
  level: process.env.LOG_LEVEL,
  prettyPrint: true,
  colorize: true,
  silent: false,
  timestamp: false
});
于 2017-02-09T18:25:48.640 回答
0

我也遇到了同样的问题,但我在 git 上遇到了它,发现了一些有趣的技巧,可能对它有帮助。 问题 #1217

首先,诀窍在于使用

JSON.stringify(jsonData, null, 4) // This helps indent lines and make them readable

您可以在下面的这个 Visual Studio 代码屏幕截图中看到它,以获得 如何使用 JSON.stringify的清晰文档

例如,如果您使用的是控制台传输器,您将像这样创建它

    transports: [
        new winston.transports.Console({
            format: printf((info) => {
                return `${info.timestamp} [${info.label}] [${info.level}] : ${info.message}\n 
            ${JSON.stringify(info.meta, null, 4)}`; // Meta as additional data you provide while logging
                ;
            })
        })
    ]

并像使用它一样

Logger.info("Message text", { meta: metaDataHere } )
于 2020-03-27T01:16:18.407 回答