1

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

日志写这么慢正常吗?使用我可以检查的 log4js 时是否存在“标准”错误?

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

我不确定我还能给你什么其他信息,如果你需要知道什么,请提前询问。

4

1 回答 1

0

Dropbox 听起来是个不错的选择。任何防病毒软件也可能会干扰。

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

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 或病毒软件不是问题,则有两个Windows Sysinternal工具可以帮助您查看进程运行时系统上发生的情况。

Process Explorer - 整体任务管理器/性能查看器

为您提供系统的整体视图,以便您了解哪些进程在做什么。您还可以深入了解特定流程(右键单击/属性)

Process Monitor - 进程的事件分析器。

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

于 2014-08-25T08:19:31.303 回答