我有Resque工作人员通常不应该花费大约1-5分钟的时间来运行,但是这些工人经常会“陷入困境”并且闲置,堵塞工人并无所事事。
所以我想定期检查运行时间超过X时间的工人并清除它们。但我需要自动执行此操作,因此我不必每隔几个小时亲自进入并手动清除它们(Resque.workers.each {|w| w.unregister_worker}
)。
这需要在Heroku上工作。
答案 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 }