43

からログ出力を取得できませんdelayed_job。また、ジョブが開始されているかどうかもわかりません。

これが私のProcfileです:

web:     bundle exec rails server
worker:  bundle exec rake jobs:work
worker:  bundle exec clockwork app/clock.rb

そして、ここに仕事があります:

class ScanningJob
  def perform
    logger.info "logging from delayed_job"
  end

  def after(job)
    Rails.logger.info "logging from after delayed_job"
  end
end

クロックワークがシステム アウトに出力されていることがわかり、ワーカー エグゼキュータが起動していることがわかりますが、ログ ステートメントがヒットしたことはありません。私も試しputsてみましたが無駄でした。

私のクロックファイルはとてもシンプルです:

every(3.seconds, 'refreshlistings') { Delayed::Job.enqueue ScanningJob.new }

これが機能することを確認したいだけですが、ログがないということはできないことを意味します。何が起きてる?

4

1 に答える 1

103

Delayed Jobs からのログ出力が必要なとき、この質問がかなり役に立ちました。

config/initializers/delayed_job.rbの行を追加します。

Delayed::Worker.logger = Logger.new(File.join(Rails.root, 'log', 'dj.log'))

次に、私の仕事では、このログに次のように出力します。

Delayed::Worker.logger.info("Log Entry")

これにより、ファイルlog/dj.logが書き込まれます。これは、開発、ステージング、および本番環境で機能します。

于 2013-01-31T18:02:36.340 に答える