rails 3.0.9的上下文,使用resque 1.17.1和resque-scheduler 2.0.0.0d。 試圖跟隨在https://github.com/bvandenbos/resque-scheduler/tree/v2.0.0.d文檔,我創建了一個resque_scheduler.rake文件:rails 3.0.9 resque-scheduler和延遲作業錯誤undefined方法enqueue_at
# Resque tasks
require 'resque/tasks'
require 'resque_scheduler/tasks'
namespace :resque do
task :setup do
require 'resque'
require 'resque_scheduler'
require 'resque/scheduler'
# you probably already have this somewhere
Resque.redis = 'localhost:6379'
# The schedule doesn't need to be stored in a YAML, it just needs to
# be a hash. YAML is usually the easiest.
#Resque.schedule = YAML.load_file('your_resque_schedule.yml')
# If your schedule already has +queue+ set for each job, you don't
# need to require your jobs. This can be an advantage since it's
# less code that resque-scheduler needs to know about. But in a small
# project, it's usually easier to just include you job classes here.
# So, someting like this:
#require 'jobs'
# If you want to be able to dynamically change the schedule,
# uncomment this line. A dynamic schedule can be updated via the
# Resque::Scheduler.set_schedule (and remove_schedule) methods.
# When dynamic is set to true, the scheduler process looks for
# schedule changes and applies them on the fly.
# Note: This feature is only available in >=2.0.0.
Resque::Scheduler.dynamic = true
end
end
暫時我只是在延遲工作有興趣,所以我沒有任何resque_schedule.yml文件。 我用resque測試了我的工人類,它工作正常。當我嘗試添加的延遲和用戶enqueue_at在我的控制器......
def do_delay_job user_id,delay
Resque.enqueue_at(delay.minutes.from_now, JobDelayer, :user_id => user_id)
#Resque.enqueue(JobDelayer, user_id) # using basic resque mechanism.
end
...它只是失敗
undefined method `enqueue_at' for Resque Client connected to redis://127.0.0.1:6379/0:Module
任何線索或暗示弄清楚這個問題,將不勝感激。