在 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
- 检查您的导轨版本。
- 检查您的 Rails 日志(日志文件夹,所有作业在执行时都会将消息写入日志文件(