登录delay_job?

Posted

技术标签:

【中文标题】登录delay_job?【英文标题】:Logging in delayed_job? 【发布时间】:2013-01-15 21:59:09 【问题描述】:

我无法从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 

我只是想看看这个工作,缺乏日志记录意味着我不能。这是怎么回事?

【问题讨论】:

delayed_job not logging 的可能重复项 【参考方案1】:

当我需要延迟作业的日志输出时,我发现this question 非常有用。

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 被写入。这适用于开发、暂存和生产环境。

【讨论】:

注意logger.debug 日志可能默认隐藏,具体取决于您的设置,因此我建议使用logger.info,而不是更高一级。

以上是关于登录delay_job?的主要内容,如果未能解决你的问题,请参考以下文章

如何使用monit监控delay_job

在 Heroku 上运行 delay_job 工作者?

delay_job 在生产一段时间后停止运行

在 Ruby on Rails 应用程序/内存泄漏中分析延迟作业任务

sso单点登录,单点登录原理图,单点登录图解,单点登录

练习题:获取登录按钮及整个登录面板,给登录按钮添加事件,点击时让登录层示,点击登录面板的关闭按钮,关闭整个登录层