首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >Rails、Heroku和Resque:被困在无限“工作”状态的工人

Rails、Heroku和Resque:被困在无限“工作”状态的工人
EN

Stack Overflow用户
提问于 2016-10-11 21:10:21
回答 1查看 392关注 0票数 2

我有一份可能需要5分钟的背景工作。我刚刚检查了我的Resque队列,发现"75名工人在工作“,尽管这些工人几天前就开始工作了。

这是什么意思?工作完成了吗?为什么会像这样卡住,我该怎么处理呢?

我的工作是:

代码语言:javascript
复制
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:

代码语言:javascript
复制
resque: env TERM_CHILD=1 bundle exec rake resque:workers QUEUE='*' COUNT='1'

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2016-10-19 20:50:30

可能有很多原因。您的redis提供程序可能已经崩溃并使实例成为孤儿。你的记忆可能会用光了。我知道你的应用程序曾经设计成成堆的工作排队。

用户界面有可能是因为这些工作in由于某种原因在redis中成为孤儿而陷入困境。

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

如果你只想清除被困的工作:Resque.workers.each {|w| w.unregister_worker}

重申我先前提到的偏好。根据您以前的一些Qs,这可能不再是一个问题。我知道你可能在做一些设计上的改变。Gl.

票数 4
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/39986793

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档