Log4js需要数小时才能写入日志文件

时间:2014-08-24 20:08:11

标签: node.js performance logging log4js-node

我在我的代码中使用log4js来记录结果和错误。程序在最终控制台输出之前运行大约2.5小时,之后需要几个小时才能完成日志文件的编写。日志正在写入6个小时(因为算法本身已完成),文件大小为100mb。 日志将大约150万行(完成后)。

日志写得这么慢是否正常?是否有"标准"使用我可以检查的log4js时会出错?

如果您想知道:该程序在带有8GB RAM和SSD驱动器的Intel i5上运行,那么硬件不应该是我猜的问题。

我不确定我能给你什么其他信息,如果你需要了解的话,请提前询问。

1 个答案:

答案 0 :(得分:0)

Dropbox听起来像个好人选。任何反病毒软件也可能会干扰。

首先,我将通过为您的PC上可用的各种配置创建迷你log4js benchmark来确认您的系统能力,然后将其与您的应用程序性能进行比较。

var Benchmark = require('benchmark');
var log4js    = require('log4js');

log4js.clearAppenders();
log4js.loadAppender('file');

log4js.addAppender(log4js.appenders.file('NUL'), 'nulnulnul');
var lognul    = log4js.getLogger('nulnulnul');

log4js.addAppender(log4js.appenders.file('c:/your_dropbox/test.log'), 'normallog');
var lognorm   = log4js.getLogger('normallog');

log4js.addAppender(log4js.appenders.file('c:/tmp/test.log'), 'nodropbox');
var lognodr   = log4js.getLogger('nodropbox');

log4js.addAppender(log4js.appenders.file('c:/virus-exception/test.log'), 'nodropvir');
var lognodv   = log4js.getLogger('nodropvir');


var suite     = new Benchmark.Suite;

// add tests
suite.add('Log#Nul', function() {
  lognul.info("Some lengthy nulnulnul info messages");
})
.add('Log#normal', function() {
  lognorm.info("Some lengthy normallog info messages");
})
.add('Log#NoDropbox', function() {
  lognodr.info("Some lengthy nodropbox info messages");
})
.add('Log#NoVirusOrDropbox', function() {
  lognodv.info("Some lengthy nodropvir info messages");
})
// add listeners
.on('cycle', function(event) {
  console.log(String(event.target));
})
.on('complete', function() {
  console.log('Fastest is ' + this.filter('fastest').pluck('name'));
})
// run async
.run({ 'async': false });

如果Dropbox或Virus软件没有成为问题,那么有两个Windows Sysinternal工具可以帮助您查看进程运行时系统上发生的情况。

Process Explorer - 整体任务管理员/效果查看器

为您提供系统的整体视图,以便您可以查看哪些进程正在执行哪些操作。您还可以深入了解特定流程(右键单击/属性)

Process Monitor - 流程的事件探查器。

Process Monitor就像是任何进程所做的所有系统调用的日志文件。 您可以过滤到特定的进程或调用,因此在您的情况下,您将能够监视Dropbox和Node.js进程,并查看他们对相关文件的访问是否是交错的,而Dropbox可以正常工作。