我正在使用DelayedJob,我想更新我的Rails 4.2应用程序以使用ActiveJob。问题是我有一堆看起来像这样的自定义作业:
AssetDeleteJob = Struct.new(:user_id, :params) do
def perform
# code
end
# more methods n' stuff
end
然后在控制器的某个地方,这个作业被这个语法排队:
@asset_delete_job = AssetDeleteJob.new(current_admin_user.id, params)
Delayed::Job.enqueue @asset_delete_job
我想找到ActiveJob的等价物。以上基本上是直接来自DJ文档。使用它来排队单个调用就像调用job的perform方法一样简单,就像使用DJ一样。但我的更复杂,需要DJ的Struct语法和传递给它的参数。
这是我到目前为止所尝试的内容:
class AssetDeleteJob < ActiveJob::Base
queue_as :default
def initialize(user_id, params)
@user_id = user_id
@params = params
end
def perform
#code
end
# more methods n' stuff
end
job = AssetDeleteJob.new(1, {ids: [1,2,3]})
不幸的是,实例化的对象没有像我期望的那样的#perform_later方法。它确实有#enqueue,但我得到一个奇怪的错误:
无法记录“enqueue.active_job”事件。 NoMethodError:未定义的方法`any?'为零:NilClass
...后跟数组中的堆栈跟踪,以
结尾NoMethodError:nil的未定义方法`map':NilClass
奇怪的几个错误,但我可能不应该直接访问#enqueue。对于ActiveJob正在寻找的东西,上面看起来很漂亮。我错过了什么?
答案 0 :(得分:5)
我可以看到两个问题。首先,您已在自定义作业类中定义了initialize
方法,从而覆盖了initialize
类中的ActiveJob
方法。这就是导致异常被抛出的原因。我不确定你是否可以摆弄有效工作的实例化。其次,你试图在该类的实例上调用类方法perform_later
,而ruby不会允许。
修复起来很简单,只需在自定义类中为perform
方法添加参数:
class AssetDeleteJob < ActiveJob::Base
#code
def perform(user_id, params)
#do a thing
end
#more code
end
然后通过调用以下内容对作业进行排队:
AssetDeleteJob.perform_later(1, {ids: [1,2,3]})
答案 1 :(得分:0)
# in jobs/asset_delete_job.rb
class AssetDeleteJob < ActiveJob::Base
queue_as :default
def perform(user_id, params)
AssetService.new(user_id, params).delete # for example
end
end
# somewhere in your controllers/assets_controller.rb
AssetDeleteJob.perform_later(1, {ids: [1,2,3]})