我正在使用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}
我以后不能在同一行中使用这些对象,也很难以这种方式阅读和保存。
任何人都知道为什么会这样?
答案 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)。