在Heroku上定期清除陈旧的Resque工作人员?

时间:2013-06-13 14:06:38

标签: ruby-on-rails heroku background-process resque

我有Resque工作人员通常不应该花费大约1-5分钟的时间来运行,但是这些工人经常会“陷入困境”并且闲置,堵塞工人并无所事事。

所以我想定期检查运行时间超过X时间的工人并清除它们。但我需要自动执行此操作,因此我不必每隔几个小时亲自进入并手动清除它们(Resque.workers.each {|w| w.unregister_worker})。

这需要在Heroku上工作。

3 个答案:

答案 0 :(得分:5)

把它放到rake任务中:

allocated_time = 60 * 60 # 1 hour
Resque::WorkerRegistry.working.each do |worker|
  if (worker.started <=> Time.now - allocated_time) < 1
    worker.unregister
  end
end

使用heroku调度程序,如果是套件,则可以将其设置为最少10分钟。

答案 1 :(得分:0)

对于Resque v1,

# lib/tasks/clear_stale_workers.rake
namespace :clear do
  desc 'Clearing stuck workers ...'
  task :stale_workers => :environment do
    Resque.workers.each do |w|
      w.unregister_worker unless w.started > 1.hour.ago
    end
  end
end

从命令行rake clear:stale_workers

在Heroku上,设置调度程序集以运行此Rake任务。

答案 2 :(得分:0)

这对我有用,可以删除运行陈旧作业的特定工人。您可以将其添加到rake任务中。

Resque::Worker.working.each{|w| w.done_working }