我有一份后台工作,最多可能需要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'
答案 0 :(得分:2)
可能有多种原因。您的redis提供程序可能已崩溃并孤立实例。你可能在redis上耗尽内存。我知道你确实已经将你的应用程序设计为一次排队大量的工作。
UI可能会被卡住,因为这些工作ID由于某种原因而在redis中成为孤儿。
尝试运行redis-cli monitor
并检查输出。
如果您只想清除卡住的作业:Resque.workers.each {|w| w.unregister_worker}
重申我之前提到的对sidekiq的偏好。根据您以前的一些问题,这可能不再是一个问题。我知道您可能会进行一些设计更改。冰川