Restful API中的Bunyan logger.info错误

时间:2015-04-08 22:20:06

标签: node.js logging bunyan

我正在使用Restful API,我正在使用bunyan记录所有重要步骤,包括请求。我在登录方面遇到两个问题: 我的第一个问题是,当我记录它们时,我的所有对象,而不是像独立对象一样出现在msg字段中,就像字符串一样。

以下是我记录请求的代码:

var logger = bunyan.createLogger({
    name: 'main', 
    streams: [{ 
        level: 'info', 
        path: './logs/requests.log'
    }]
});

logRequest = function(request){
    logger.info("Request started.", {id: request.id}, {method: request.method});
};

当我看到request.log文件时,它看起来像这样(我刚刚添加了一些标签,以便让它更容易看到):

{
    "name": "logger",
    "hostname": "LLAS",
    "pid": 7700,
    "level": 30,
    "msg":"Request started. { id: '1428527975041:LLAS:7700:i898o4l5:10000'{ method:'post' } ",
    "time":"2015-04-08T21:19:35.055Z",
    "v":0
}

所以我的问题是“msg”字段,我希望看到“id”和“method”像其他字段而不是字符串。 I.E。

 {
        "name": "logger",
        "hostname": "LLAS",
        "pid": 7700,
        "level": 30,
        "msg":"Request started.",
        "id": '1428527975041:LLAS:7700:i898o4l5:10000',
        "method":  'post',
        "time":"2015-04-08T21:19:35.055Z",
        "v":0
 }

如何解决我的问题?

我的第二个问题是:当我在同一个文件中执行多个日志时,它会将JSON写入同一行,而不是新行,如下所示:

{"name":"logger",...,"v":0}{"name":"logger",...,"v":0}

而不是:

{"name":"logger",...,"v":0}
{"name":"logger",...,"v":0}

我以后不能在同一行中使用这些对象,也很难以这种方式阅读和保存。

任何人都知道为什么会这样?

1 个答案:

答案 0 :(得分:1)

  

我的第一个问题是,当我记录它们时,我所有的对象,而不是   看起来像独立的对象,出现在" msg"田野,喜欢   字符串。

那是因为你传递了多个对象。您只能传递一个对象作为记录的第一个参数,所有其他参数将被视为msg。来自bunyan source code

/**
 * The functions below log a record at a specific level.
 *
 * Usages:
 *    log.<level>()  -> boolean is-trace-enabled
 *    log.<level>(<Error> err, [<string> msg, ...])
 *    log.<level>(<string> msg, ...)
 *    log.<level>(<object> fields, <string> msg, ...)
 *
 * where <level> is the lowercase version of the log level. E.g.:
 *
 *    log.info()
 * ....
 */

因此,如果您将所有参数传递到一个对象中,它将正常工作:

var request = { id: "abc", method: "GET" }; // dummy request object
logger.info({id: request.id, method: request.method}, "Request started.");

结果是(漂亮印刷):

{
  "name": "main",
  "hostname": "Victors-MacBook-Pro.local",
  "pid": 2848,
  "level": 30,
  "id": "abc",
  "method": "GET",
  "msg": "Request started.",
  "time": "2015-04-08T23:25:37.967Z",
  "v": 0
}
  

我的第二个问题是:当我同时执行多个登录时   文件,它将JSON写入同一行,而不是新行。

你在Windows上吗?如果你是,可能问题是bunyan可能正在使用UNIX样式回车(\n)而不是Windows样式(\r\n)。尝试使用支持UNIX样式回车的文本编辑器(例如notepad ++或sublime text)。