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

当我需要延迟作业的日志输出时,我发现这个问题很有帮助。

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 回答