Ste*_*all 40 ruby logging ruby-on-rails delayed-job clockwork
我无法获得任何日志输出delayed_job,我不确定我的工作是否正在开始.
这是我的Procfile:
web: bundle exec rails server
worker: bundle exec rake jobs:work
worker: bundle exec clockwork app/clock.rb
Run Code Online (Sandbox Code Playgroud)
这是工作:
class ScanningJob
def perform
logger.info "logging from delayed_job"
end
def after(job)
Rails.logger.info "logging from after delayed_job"
end
end
Run Code Online (Sandbox Code Playgroud)
我看到发条输出到系统输出,我可以看到工作程序执行器启动,但我从未看到我的日志语句命中.我也试过puts无济于事.
我的时钟文件非常简单:
every(3.seconds, 'refreshlistings') { Delayed::Job.enqueue ScanningJob.new }
Run Code Online (Sandbox Code Playgroud)
我只是想看到这个工作,缺乏记录意味着我不能.这里发生了什么?
Jam*_*ier 92
当我需要延迟工作的日志输出时,我发现这个问题非常有用.
在config/initializers/delayed_job.rb我添加行:
Delayed::Worker.logger = Logger.new(File.join(Rails.root, 'log', 'dj.log'))
Run Code Online (Sandbox Code Playgroud)
然后,在我的工作中,我输出到这个日志:
Delayed::Worker.logger.debug("Log Entry")
Run Code Online (Sandbox Code Playgroud)
这导致文件log/dj.log被写入.这适用于开发,登台和生产环境.
| 归档时间: |
|
| 查看次数: |
26956 次 |
| 最近记录: |