我有一份可能需要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'

发布于 2016-10-19 20:50:30
可能有很多原因。您的redis提供程序可能已经崩溃并使实例成为孤儿。你的记忆可能会用光了。我知道你的应用程序曾经设计成成堆的工作排队。
用户界面有可能是因为这些工作in由于某种原因在redis中成为孤儿而陷入困境。
尝试运行redis-cli monitor并签出输出。
如果你只想清除被困的工作:Resque.workers.each {|w| w.unregister_worker}
重申我先前提到的偏好。根据您以前的一些Qs,这可能不再是一个问题。我知道你可能在做一些设计上的改变。Gl.
https://stackoverflow.com/questions/39986793
复制相似问题