使用公牛队列。我有一个限速队列。考虑到速率限制和退避策略,我希望在队列中尽快重试失败的作业。情况似乎并非如此。似乎失败的作业被推送,并将在队列中其他现有作业的后面处理。一个人为的例子:
const Bull = require('bull');
const queue = new Bull('test-queue', {
limiter: {
max: 1,
duration: 1000
}
});
queue.process(async ({ data, id }) => {
let {fail = false} = data;
console.log(`processing job ${id}`);
if (fail) {
throw new Error('Queue test error');
}
return `${id} completed`;
});
queue.add({fail: true});
for(let i = 0; i < 10; i++) {
queue.add({});
}
这总是会在第一次处理后产生作业,然后重试失败的作业。根据公牛的说法,这不应该发生。我的实施错了吗?