【问题标题】:Delayed_job (2.1.4) error: Job failed to load: instance of IO needed. Handler nilDelayed_job (2.1.4) 错误:作业加载失败:需要 IO 实例。处理程序无
【发布时间】: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


【解决方案1】:

找到解决方案:我的问题是由批量分配保护引起的。我有一个初始化程序来防止大规模赋值:

# SECURITY: protect against mass assignment vulnerabilities
# enforces explicitly setting attributes accessible in models (whitelisting)
ActiveRecord::Base.send(:attr_accessible, nil)

这阻止了delayed_job 访问处理程序字段!不确定这是否可以被视为 DJ 中的错误。这是解决我的问题的初始化代码:

# Imortant: delayed job requires some attributes to be accessible - make sure they are
Delayed::Job.attr_accessible :priority, :payload_object, :handler, :run_at, :failed_at

【讨论】:

  • 直到我这样做才为我工作:Delayed::Backend::ActiveRecord::Job.attr_accessible
  • 感谢您的更新 - 可能是 DelayedJob 中的更改导致了此问题。如果其他人可以确认这一点,我会将您的评论包含在答案中(加上您使用的 DJ 版本会有所帮助)
【解决方案2】:

您的处理程序列可能太小而无法放入其中。您可以像这样在迁移中解决此问题:

change_column :delayed_jobs, :handler, :text, :limit => 64.kilobytes + 1

【讨论】:

  • 感谢您的提示。我试过了,但没有运气。由于我只存储 ID 和类名,我认为 TEXT 字段就足够了(而不是 LONGTEXT)。
猜你喜欢
  • 1970-01-01
  • 1970-01-01
  • 2016-05-31
  • 2019-02-09
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
相关资源
最近更新 更多