首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >log4js库是异步的吗?

log4js库是异步的吗?
EN

Stack Overflow用户
提问于 2014-08-27 08:37:46
回答 1查看 1.8K关注 0票数 3

我有一个小问题要知道log4js库是否是异步的。我试图找到log4js文档,但没有找到任何结果。我想在我的节点js应用程序中使用它,但在此之前,我想知道它是异步的还是非异步的?

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2014-08-27 09:35:38

记录器本身是异步的,但是它正在使用的appender可能不是。

例如,您正在使用log4js记录器,并将console作为附录。注意,自版本0.6以来,node.js中的控制台是同步的。

现在,运行日志函数将创建一个LogEvent对象并发出log事件:

代码语言:javascript
复制
Logger.prototype.log = function() {
  var args = Array.prototype.slice.call(arguments)
  , logLevel = levels.toLevel(args.shift())
  , loggingEvent;
  if (this.isLevelEnabled(logLevel)) {
    loggingEvent = new LoggingEvent(this.category, logLevel, args, this);
    this.emit("log", loggingEvent);
  }
};

现在由事件侦听器来决定它是否是异步的。这意味着异步与否完全取决于appender实现。您可以看到所有可用的附加程序这里

file.js是异步的,而控制台和fileSync是同步的。

很快,记录器将请求传递给编写器,其中请求是否是同步的取决于编写器的规范。实际上,控制台是同步的,这是有充分理由的。

票数 4
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/25522538

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档