Rails,Heroku和Resque:工人陷入了无限的困境中,工作和#34;状态

时间:2016-10-11 21:10:22

标签: ruby-on-rails heroku resque

我有一份后台工作,最多可能需要5分钟。我刚检查了我的Resque队列,我发现有#75; 75名工作人员正在工作"尽管那些工人几天前就已经开始工作了。

这是什么意思?工作完成了吗?为什么它会像这样陷入困境?我该如何处理这种情况呢?

这是我的工作:

class CalculateRelevantEventRankingsForUser

   @queue = :calculate_relevant_event_rankings_for_user

  def self.perform(user_id, newly_voted_event_id)
    begin
      user = User.find(user_id)
      events_to_rerank = user.events_that_share_keywords(newly_voted_event_id)
      events_to_rerank.each do |e|
        e.rank(user_id)
      end
    rescue Resque::TermException
      Resque.enqueue(self, user_id, newly_voted_event_id)
    end
  end

end

并且procfile:

resque: env TERM_CHILD=1 bundle exec rake resque:workers QUEUE='*' COUNT='1'

enter image description here

1 个答案:

答案 0 :(得分:2)

可能有多种原因。您的redis提供程序可能已崩溃并孤立实例。你可能在redis上耗尽内存。我知道你确实已经将你的应用程序设计为一次排队大量的工作。

UI可能会被卡住,因为这些工作ID由于某种原因而在redis中成为孤儿。

尝试运行redis-cli monitor并检查输出。

如果您只想清除卡住的作业:Resque.workers.each {|w| w.unregister_worker}

重申我之前提到的对sidekiq的偏好。根据您以前的一些问题,这可能不再是一个问题。我知道您可能会进行一些设计更改。冰川