Node.js Kue如何重启失败的作业

时间:2013-01-11 15:11:17

标签: javascript node.js redis delayed-job kue

我在我的node.js应用程序中使用kue来延迟作业。

我有一些问题要弄清楚如何使用kue API重新启动作业,而不必使用redis命令将失败作业列表中的作业ID手动移动到非活动作业列表。

这可以使用kue吗?

我不想设置固定数量的重试次数 - 我只是想重试特定的工作。

对于维持良好维护的替代方案的建议也是受欢迎的。

3 个答案:

答案 0 :(得分:12)

我不知道这是否有效,但您可以尝试将作业状态重置为活动状态,然后再次保存作业:

job.on('failed', function() {
  job.state('inactive').save();

编辑:将状态设置为无效将正确重新排队任务。

答案 1 :(得分:3)

这也可以使用队列级事件来完成。

queue.on('job failed', function(id, result) {
    kue.Job.get(id, function(err, job) {
        if (!err && shouldRetry(job))
            job.state('inactive').save();
    });
});

因此,您不需要为每个要重试的作业执行此操作。相反,您可以在队列级事件中过滤它。

答案 2 :(得分:2)

请参阅官方文档中的失败尝试

  

默认情况下,作业只有一次尝试,即失败时   被标记为失败,并保持这种状态,直到你介入。   但是,Kue允许您指定这一点,这对于工作很重要   例如转移电子邮件,一旦失败,通常可以重试   没有问题。为此,请使用数字调用.attempts()方法。

 queue.create('email', {
     title: 'welcome email for tj'
   , to: 'tj@learnboost.com'
   , template: 'welcome-email'
 }).priority('high').attempts(5).save();

参考:failure attempts