gpt4 book ai didi

ruby-on-rails - 事件作业的 Rails 设置(等待 : 2. 分钟)方法不起作用

转载 作者:可可西里 更新时间:2023-11-01 11:28:35 25 4
gpt4 key购买 nike

在 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 的新手,所以请帮忙。

最佳答案

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

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

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

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

当我无法找到解决某些超出我掌握范围的行为的方法时,我会使用一些“puts”和一些“try/catch errors”结构(在 ruby​​ 中开始 rescue ensure)...:

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

关于ruby-on-rails - 事件作业的 Rails 设置(等待 : 2. 分钟)方法不起作用,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/42921844/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com