gpt4 book ai didi

node.js - Log4js 需要几个小时才能写入日志文件

转载 作者:太空宇宙 更新时间:2023-11-04 02:32:24 25 4
gpt4 key购买 nike

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

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

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

我不确定我还能向您提供哪些其他信息,如果您需要了解什么,请提前询问。

最佳答案

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

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

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 - 整体任务管理器/性能查看器

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

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

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

关于node.js - Log4js 需要几个小时才能写入日志文件,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/25475852/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com