1

使用公牛队列。我有一个限速队列。考虑到速率限制和退避策略,我希望在队列中尽快重试失败的作业。情况似乎并非如此。似乎失败的作业被推送,并将在队列中其他现有作业的后面处理。一个人为的例子:

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({});
}

这总是会在第一次处理后产生作业,然后重试失败的作业。根据公牛的说法,这不应该发生。我的实施错了吗?

4

0 回答 0