WinstonJS自定义级别

时间:2015-12-02 15:01:57

标签: node.js winston

所以我想在记录器中添加两个级别。但它不是记录,我不知道为什么..这是我的设置。有什么想法吗?

// setup
var logLevels = {
    levels: {
        trace: 0,
        debug: 1,
        info: 2,
        warn: 3,
        error: 4,
        critical: 5
    }
};

var logger = new (winston.Logger)({
    levels: logLevels.levels,
    transports: [
        new winston.transports.Console()
    ]
});

// test
console.info('----------------------');
logger.trace('trace');
logger.debug('debug');
logger.info('info');
logger.warn('warn');
logger.error('error');
logger.critical('critical');
console.info('----------------------');

输出:

----------------------
debug: debug
trace: trace
info: info
----------------------

1 个答案:

答案 0 :(得分:3)

winston Logging levels

这里的第一个问题是,每个级别都有一个特定的整数优先级。默认情况下,它的

{ error: 0, warn: 1, info: 2, verbose: 3, debug: 4, silly: 5 }

所以越少越重要。

其次,您必须为每个传输指定level。在您的情况下,您必须将level设置为critical以显示所有消息。

  

winston允许您在每个传输上定义一个级别属性,该属性指定传输应记录的最大消息级别。

var logger = new (winston.Logger)({
    levels: logLevels.levels,
    transports: [
        new winston.transports.Console({level: 'critical'})
    ]
});