我正在为我的应用创建DripEmail广告系列,并使用resque scheduler来安排任务。
我已经调整了一个静态工作,该工作每天在特定时间运行,并根据滴水设置收集用户的列表,然后向他们发送电子邮件。
这是我的resque作业user_follow_up.rb
class UserFollowUp
@queue = :user_follow_up
def self.perform
User.each do |u|
# Send the emailers to only those who are not converted
if !user.is_converted and Date.today <= user.next_email
stage(u)
end
end
end
end
这是我的scheduler.yml
UserFollowUp:
cron: "0 16 * * *"
我有2个resque worker,一个有我的默认任务集,另一个有调度程序。
rake environment resque:work QUEUE=publish_story,accept_story,image_queue,Mango_mailer
和
rake environment resque:scheduler QUEUE=user_follow_up
当我打开resque管理界面时,我能够在列表中看到我的静态作业。我点击Queue Now
按钮进行测试。它将任务正确排入队列,但不执行。它将这些任务永远保留在挂起队列中。
这是我的resque.rake
,是必需的
require 'resque/tasks'
require 'resque/scheduler/tasks'
require 'resque/scheduler/server'
require 'active_record'
require 'mongoid'
require 'action_controller/railtie'
require 'active_support/buffered_logger'
# load the Rails app all the time
namespace :resque do
puts 'Loading Rails environment for Resque'
task :setup => :environment do
# 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("#{Rails.root}/config/scheduler.yml")
Resque::Scheduler.dynamic = true
Resque.logger.info 'Resque Scheduler Initialized!'
Resque.before_first_fork do
# Open the new separate log file
logfile = File.open(File.join(Rails.root, 'log', 'resque.log'), 'a')
# Activate file synchronization
logfile.sync = true
# Create a new buffered logger
Resque.logger = ActiveSupport::BufferedLogger.new(logfile)
Resque.logger.level = Logger::INFO
Resque.logger.info 'Resque Logger Initialized!'
puts 'Resque Logger Initialized!'
end
end
task 'resque:pool:setup' do
Resque::Pool.after_prefork do |job|
Resque.redis.client.reconnect
end
end
end
这是我的Gemfile
gem 'resque', github: 'resque/resque' , branch: '1-x-stable'
gem 'resque_mailer', github: 'zapnap/resque_mailer'
gem 'resque-scheduler'
我不确定这里的问题是什么。请帮我解决这个问题。