活动作业的轨道设置(等待:2.分钟)方法不起作用



在 Redis 服务器上使用 resque_scheduler gem 创建后台作业。

 class Estamps::OrderAssignment < ActiveRecord::Base
  after_save :enqueue_check_status
   def enqueue_check_status 
       AutoRejectionJob.set(wait: 2.minutes).perform_later(self.id)
   end
 end
 class AutoRejectionJob < ActiveJob::Base
   queue_as :default
   def perform(*args) 
    order_assignment_id = args[0]
    order_assignment = Estamps::OrderAssignment.find(order_assignment_id)
    if order_assignment.status_id == 1 || order_assignment.status_id == nil
      order_assignment.status_id = 3
      order_assignment.save!
    end
  end
 end         

创建订单分配记录时或在 2 分钟后更新时,它应运行自动拒绝作业。这里的问题是集合(等待:2.分钟(似乎没有运行,即

   AutoRejectionJob.perform_later(self.id)

工作得很好,但是

  AutoRejectionJob.set(wait: 2.minutes).perform_later(self.id)

什么都不做。无法纠正该问题。新手到Rails,所以请帮忙。

我认为你的代码没有问题。我检查了:.set(wait: 2.minutes)在 ruby 5.0.2 之上的 rails 2.4.0 中按预期工作

你的工作呼唤也是如此。在我看来,您正在尝试设置在其他地方使用的状态。错误可能是由于OrderAssignment在外部处理中纵(破坏?

既然你说你是 rails 的新手(我想这就是"新手"的意思(,我将提出一些建议。如果你已经过去了,请忽略它们...

还有一些很棒的调试工具可以帮助您找到正在发生的事情:byebug,better_errors,pry,当然还有rails console 。帮自己一个忙:尝试一下。

当我找不到解决一些超出我掌握范围的行为时,我会使用一些"看跌"和一些"尝试/捕捉错误"结构(在红宝石中开始救援确保(......

def perform(*args) 
  puts "@@@@@@@ JOB TRIGGERED @@@@@@"
  begin
    order_assignment_id = args[0]
    order_assignment = Estamps::OrderAssignment.find(order_assignment_id)
    puts "#{order_assignment.inspect}"
    if order_assignment.status_id == 1 || order_assignment.status_id == nil
      order_assignment.status_id = 3
      order_assignment.save!
    end
    puts "@@@@@@@ JOB DONE @@@@@@"
  rescue StandardError => e
    # ... display e.message ...
  ensure
    #... 
  end
end
  1. 检查您的导轨版本。
  2. 检查您的 Rails 日志(日志文件夹,所有作业在执行时都会将消息写入日志文件(

相关内容

最新更新