【发布时间】:2011-12-19 10:37:18
【问题描述】:
我创建了一个简单的成就系统,并想引入delayed_job (2.1.4) 来处理处理。但是,delayed_jobs 表中的 handler 列始终为 nil,导致 last_error 文本:Job failed to load: instance of IO needed. Handler nil
这是我的设置:
成就观察者
class AchievementObserver < ActiveRecord::Observer
observe User, Comment, ...
def after_create(record)
# initiate delayed job to check conditions
Delayed::Job.enqueue(TrophyJob.new(record.id, record.class.name))
end
...
end
奖杯工作
class TrophyJob < Struct.new(:record_id, :record_type)
def perform
case record_type
when "User"
UserProfileCompleteTrophy.progress(User.find(record_id)) # complete your profile settings
NewsletterReceiverTrophy.progress(User.find(record_id)) # sign up for the newsletter
when "Comment"
CommentsAuthoredTrophy.progress(Comment.find(record_id)) # create x comments
...
end
end
end
delayed_jobs 表中的条目被创建。但是,处理程序始终为 NULL。我已经尝试过各种各样的事情(之前通过完整的对象,现在去 id + classname 如此处所述:Weird exception with delayed_job;在观察者中尝试了 xxxTrophy.delay.progress(...) 等) - 都没有运气.
我也有
require 'yaml'
YAML::ENGINE.yamler= 'syck'
在我的 boot.rb 中。
有一点值得一提:虽然 last_error 文本被delayed_job 填充,但是尝试次数和失败_at 列仍然为NULL。
我错过了什么?
更新
我验证了序列化按预期工作:
ruby-1.9.2-p290 :004 > TrophyJob.new(1, "User").to_yaml
=> "--- !ruby/struct:TrophyJob \nrecord_id: 1\nrecord_type: User\n"
【问题讨论】:
-
您是否尝试过删除 yaml 引擎自定义(或者甚至可能)?
-
这一行是 YAML 工作所必需的(例如,对于我的语言环境)。我提到它只是为了表明我认为问题可能是由 YAML 序列化问题引起的——但我认为这不太可能。不过还是谢谢。
标签: ruby-on-rails ruby-on-rails-3.1 delayed-job mass-assignment