Resque预定作业停留在待处理队列中

时间:2014-06-04 13:23:16

标签: ruby-on-rails resque resque-scheduler

我正在为我的应用创建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 static jobs

当我打开resque管理界面时,我能够在列表中看到我的静态作业。我点击Queue Now按钮进行测试。它将任务正确排入队列,但不执行。它将这些任务永远保留在挂起队列中。

Jobs stuck in queue

这是我的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'

我不确定这里的问题是什么。请帮我解决这个问题。

0 个答案:

没有答案