gpt4 book ai didi

间隔执行后的 JavaScript 回调

转载 作者:行者123 更新时间:2023-11-27 23:03:15 24 4
gpt4 key购买 nike

我使用自定义间隔函数来确保函数执行首先完成,直到下次运行。一般来说,我会执行以下操作:检查 redis 数据库并检查作业是否由 sidekiq 执行。如果它被执行,我会向数据库发出请求以获取已写入的信息,如果第 10 次之后没有我解析为未定义的数据,我会运行此函数 10 次。我想知道我现在的解决方案是否可以以某种方式改进。

 const interval = (func, wait, times) => {
const interv = function(w, t){
return () => {
if (typeof t === 'undefined' || t-- > 0) {
setTimeout(interv, w);
try {
func.call(null);
}
catch (e) {
t = 0;
throw e.toString();
}
}
};
}(wait, times);
setTimeout(interv, wait);
};

let intervalCount = 0;
interval(() => {
intervalCount++;
redisClient.lrange('queue:default', 0, -1, (err, results) => {
const job = results.find((element) => { return JSON.parse(element).jid === jobId; });
if (job === undefined) {
checkDatabase(personId).then((result) => {
if (result) {
resolve(checkDatabase(personId));
} else if (intervalCount >= 10) {
resolve(undefined);
}
});
}
});
}, 1500, 10);

最佳答案

好吧,您正在使用现代 NodeJS,并且您提到您正在使用 Promise 和 Bluebird,所以让我们使用使用生成器和 Bluebird 的现代解决方案。

您根本不应该经常使用 Promise 构造函数。您可以 promise redis API,让您的生活更轻松:

Promise.promisifyAll(require("redis")); // now redis is promisified


var pollAndResolve = Promise.coroutine(function* pollAndResolve () {
for(var i = 0; i < 10; i++) {
yield Promise.delay(1500); // wait 1500 ms
yield redisClient.lrangeAsync('queue:default', 0, -1); // since we promisifed
const job = results.find((element) => JSON.parse(element).jid === jobId);
if (result) return yield checkDatabase(personId);
}
});

关于间隔执行后的 JavaScript 回调,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/36860390/

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