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 工作时交错。