我在Node.js中构建了一个非常稳定的机器人应用程序,它基本上将请求连续发送到API.为了确保什么都不会出错,我会处理任何可能的错误,并且我已经设定了可能需要很长时间才能解决的承诺超时…
现在,我想通过删除我的安全网并监视异步操作以找到任何类型的“异步泄漏”来改进应用程序,例如永久未决的承诺或任何我不知道的奇怪结果(这是我的问题的关键点) ).
是否有任何工具可用于监控Node.js异步流?例如,在给定时间内获取流程中的待处理承诺总额?或者,如果任何承诺已超过一定时间,并且跟踪该承诺,则会收到警告?
如果这可以指导答案,这里是我使用的模块:
// Bluebird (promises)
var Promise = require("bluebird");
// Mongoose with promises
var mongoose = require('mongoose');
mongoose.Promise = require('bluebird');
// Rate limiter with promises
var Bottleneck = require("bottleneck");
// Promisified requests
var request = require('request-promise');
很抱歉没有能够准确地提出我的问题:我完全不清楚我的期望/期望…
编辑:到目前为止,我的研究让我:
> Bluebird’s resource management tools,但我无法找到使它们有用的方法
>令人惊叹的npm monitor和装运的显示器 – 仪表板,但由于某种原因我还不能让它满足我的需求……
由于我还在开发应用程序并且除了应用程序之外还有生命,我没有太多时间来研究它,但我肯定会在某些方面认真地解决这个问题!
解决方法:
听起来你可能需要某种工作管理.
我最近一直在尝试kue来管理异步工作,这非常好.
它有一个用于启动和运行作业的API.每个工作都可以报告它的进度.它带有一个内置的作业仪表板,可以显示正在运行的作业及其进度.它有一系列广泛的事件,以便您可以监视每个作业的状态.
您需要安装Redis才能使用它,但这并不困难.
它不支持promises,但你可以在下面的代码示例中看到,很容易启动一个作业,然后将它包装在一个promise中,以便你可以等待作业完成:
const queue = kue.createQueue();
queue.process("my-job", 1, (job, done) => {
const result = ... some result ...
// Run your job here.
if (an error occurs) {
done(err); // Job failure.
return;
}
done(null, result); // Job success
});
function runMyJob () {
return new Promise((resolve, reject) => {
const job = queue.create("my-job").save();
job.on('complete', result => {
resolve(result); // Job has completed successfully, resolve the promise.
});
job.on("failed", err => {
reject(err); // Job has failed, reject the promise.
});
});
};
runMyJob()
.then(() => {
console.log("Job completed.")
})
.catch(err => {
console.error("Job failed.");
});
使用Node.js集群模块在多个CPU上并行工作相当容易.
Read more on the kue web page.