1

在 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         

在创建 OrderAssignment 记录或在 2 分钟后更新时,它应该运行 AutoRejection Job。这里的问题是 set(wait: 2.minutes) 似乎没有运行,即

   AutoRejectionJob.perform_later(self.id)

工作得很好,但是

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

什么也没做。一直无法纠正问题。Rails 的新手,请帮忙。

4

2 回答 2

0

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

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

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

还有一些很棒的调试工具可以帮助您找到发生了什么:byebug、better_errors、pry,当然还有rails console. 帮自己一个忙:试试看。

当我无法解决某些超出我掌握的行为时,我会使用一些“放置”和一些“尝试/捕获错误”结构(在 ruby​​ 中开始救援确保)...:

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
于 2017-03-30T05:43:29.413 回答
0
  1. 检查您的导轨版本。
  2. 检查您的 Rails 日志(日志文件夹,所有作业在执行时都会将消息写入日志文件)
于 2022-02-23T01:12:28.243 回答