node.js - 在node.js winston中添加行号配置进行日志记录时时间戳消失

标签 node.js logging winston

我正在使用 winston 制作一个自记录器,它允许我在日志记录中添加时间戳和行号。代码可以各自完成功能,但是组合起来后,它们就无法按预期工作。

// **help to add timestamp**
var logger = new (winston.Logger)({
  transports : [new (winston.transports.Console)({
    json : false,
    timestamp : true,
    colorize: true
  }), new winston.transports.File({
    filename : __dirname + '/debug.log',
    json : true
  })]
  ,exitOnError : false
});

// **help me to add line number**
var logger_info_old = winston.info;
logger.info = function(msg) {
    var fileAndLine = traceCaller(1);
    return logger_info_old.call(this, fileAndLine + ":" + msg);
}

但是,当添加行号配置后,日志记录的时间戳将会消失。

例如,在添加行号配置之前。

logger.info("abc");
2013-11-24T09:49:15.914Z - info:339:abc

添加行号配置时

logger.info("abc");
info: (H:\Dropbox\node\fablab\utils\logging.js:85:abc

我想要的最佳结果是这样的

logger.info("abc");
2013-11-24T09:49:15.914Z - info: (H:\Dropbox\node\fablab\app.js:339:abc

我可以解决这个问题吗?

最佳答案

我让它工作了,这就是我所做的。

var transports = [
  new(winston.transports.Console)({
    colorize: true,
    prettyPrint: true,
    timestamp : true,
    level: 'debug',
  })
];

var log = new(winston.Logger)({
  "transports": transports
});

for (var func in winston.levels) {
  var oldFunc = log[func];

  log[func] = function() {
    var args = Array.prototype.slice.call(arguments);
    args.unshift(traceCaller(1));
    oldFunc.apply(log, args);
  }
}

这样我就得到了时间戳和文件。 (注意traceCaller(1)来自这个stackoverflow问题: I want to display the file Name in the log statement )。我对winston.levels 进行了for 循环,这样我就可以获取所有函数而不仅仅是信息。

你的不起作用的原因是你的logger_info_old来自winston而不是来自logger。所以

var logger_info_old = winston.info;

应该是

var logger_info_old = logger.info;

关于node.js - 在node.js winston中添加行号配置进行日志记录时时间戳消失,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/20173242/

相关文章:

javascript - 解析大字符串以调用 Node 中的 JS 函数

javascript - 为什么这个简单的函数不能在这个 javascript 状态机中的这个对象上运行?

python 日志管理器

function - 有关如何连接持久函数依赖注入(inject)的示例

node.js - 如何获取安装了我的 slack 应用程序的所有工作区的信息

node.js - 使用 ES6 类的快速路由

python - 当级别设置为logging.DEBUG时,为什么log.debug()不记录日志?

javascript - 有没有办法在 typescript 程序中获取类的详细信息,以便我可以将这些详细信息传递给记录器(winston)?

node.js - Winston/Morgan 日志记录避免重复条目

javascript - Winston 输出 json 而不是格式化字符串