Отложенное задание: отложенное задание зависает

Я использую отложенную работу для выполнения фоновых заданий. я выполняю отложенные задания с командой RAILS_ENV=production bin/delayed_job -n 5 start

когда я запускаю отложенное задание и проверяю отложенные задания, это показывает, что задания запущены. когда я проверил отложенное задание снова через 1 час, состояние отложенных заданий все еще работало. Все задания должны были быть выполнены за 15 минут, но даже через 1 час он показывает состояние как выполненное. пожалуйста помоги.

Ниже приведен мой файл журнала отложенного задания.

I, [2015-12-22T13:10:56.463154 #15255]  INFO -- : 2015-12-22T13:10:56+0000: [Worker(delayed_job.0 host:ip-172-31-6-58 pid:15255)] Job QrCodeGenerator (id=16) RUNNING
I, [2015-12-22T13:10:56.467157 #15261]  INFO -- : 2015-12-22T13:10:56+0000: [Worker(delayed_job.1 host:ip-172-31-6-58 pid:15261)] Job QrCodeGenerator (id=17) RUNNING
I, [2015-12-22T13:10:56.544987 #15267]  INFO -- : 2015-12-22T13:10:56+0000: [Worker(delayed_job.2 host:ip-172-31-6-58 pid:15267)] Job QrCodeGenerator (id=15) RUNNING

статус работ, которые выполняются, как показано ниже.

 => #<Delayed::Backend::ActiveRecord::Job id: 15, priority: 0, attempts: 0, handler: "--- !ruby/struct:QrCodeGenerator\nclient: !ruby/obj...", last_error: nil, run_at: "2015-12-22 11:57:28", locked_at: "2015-12-22 13:10:56", failed_at: nil, locked_by: "delayed_job.2 host:ip-172-31-6-58 pid:15267", queue: nil, created_at: "2015-12-22 09:07:39", updated_at: "2015-12-22 11:57:51">
2.0.0-p598 :004 >

 => #<Delayed::Backend::ActiveRecord::Job id: 16, priority: 0, attempts: 0, handler: "--- !ruby/struct:QrCodeGenerator\nclient: !ruby/obj...", last_error: nil, run_at: "2015-12-22 09:08:06", locked_at: "2015-12-22 13:10:56", failed_at: nil, locked_by: "delayed_job.0 host:ip-172-31-6-58 pid:15255", queue: nil, created_at: "2015-12-22 09:08:06", updated_at: "2015-12-22 09:08:06">

 => #<Delayed::Backend::ActiveRecord::Job id: 17, priority: 0, attempts: 0, handler: "--- !ruby/struct:QrCodeGenerator\nclient: !ruby/obj...", last_error: nil, run_at: "2015-12-22 09:08:44", locked_at: "2015-12-22 13:10:56", failed_at: nil, locked_by: "delayed_job.1 host:ip-172-31-6-58 pid:15261", queue: nil, created_at: "2015-12-22 09:08:44", updated_at: "2015-12-22 09:08:44">

мой код для вставки работы в отложенную работу, как показано ниже.

QrCodeGenerator = Struct.new(:client,:request,:quantity) do
  def perform
      AuthenticationCode.save_qr_codes(client,request,quantity)
  end

  def error(job, exception)
    if request.status != "completed"
      request.update_attributes(:status => "failed")
    end
  end

  def destroy_failed_jobs?
    true
  end

  def max_attempts
    1
  end

end

1 ответ

Решение

Я полагаю, вы поставили в очередь (и начали) работу где-то еще. Таким образом, проблема заключается только в том, почему работа продолжается.

Я думаю, что вы должны сначала убедиться, что процессы действительно инициированы / запущены.

Затем драгоценный камень delayed_job_web полезный интерфейс для мониторинга состояния процессов.

С другой стороны, вы можете попробовать установить max_run_time чтобы увидеть, delayed_job функционирует, как и ожидалось.

# config/initializers/delayed_job_config.rb
Delayed::Worker.max_run_time = 5.minutes
Другие вопросы по тегам