У меня есть этот рабочий, который бежит вечно.
class Worker
include Sidekiq::Worker
sidekiq_options queue: "infinity", retry: true
def perform(params)
# ...
self.class.perform_in(30.seconds, params)
end
end
Проблема в том, что я загружаю воркеров при запуске, вот так. config/initializers/load_workers.rb
Rails.application.config.after_initialize do
if ENV["SIDEKIQ"] == "1"
Worker.perform_async({})
end
end
Используя это, чтобы запустить sidekiq SIDEKIQ=1 sidekiq --verbose --environment production -C config/sidekiq.yml
.
Это означает, что старые рабочие должны быть остановлены, как текущие, так и перенесенные.
Я пробовал запускать это при запуске (непосредственно перед загрузкой новых работ), но это не сработало.
q = []
q += Sidekiq::RetrySet.new.select { |job| job.klass.match(/Worker/) }
q += Sidekiq::Queue.new("infinity").select { |job| job.klass.match(/Worker/) }
q += Sidekiq::ScheduledSet.new.select { |job| job.klass.match(/Worker/) }
q.each(&:delete)
После пятикратного развертывания в очереди, запланированной на более позднее время, появляется куча повторяющихся рабочих процессов. Итак, есть ли способ очистить все в одной очереди и предотвратить перепланирование уже запущенных заданий?
Я использую sidekiq 3.0.