Rails、Heroku 和 Resque:Worker 陷入无限 "working" 状态

Rails, Heroku, and Resque: Workers stuck in infinite "working" state

我的后台作业最多可能需要 5 分钟。我刚刚检查了我的 Resque 队列,我看到有“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'

可能有多种原因。您的 Redis 提供商可能已经崩溃并孤立了这些实例。你可能 运行 在 redis 上内存不足。我知道您确实将应用程序设计为在某一时刻对大量作业进行排队。

可能 UI 卡住了,因为这些作业 ID 出于某种原因在 Redis 中被孤立了。

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

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

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