2

我遇到了一些奇怪的问题,我的delayed_jobs 在生产中失败了。最后我把它缩小到记录器。如果我注释掉我的日志函数调用,一切正常。但是,如果我尝试登录,我会在 delay_job 处理程序中得到这个:

 --- !ruby/struct:Delayed::PerformableMethod 
object: AR:User:1
method: :load_and_update_without_send_later
args: []

 | closed stream
/opt/ruby/lib/ruby/1.8/logger.rb:504:in `write'
/opt/ruby/lib/ruby/1.8/logger.rb:504:in `write'
/opt/ruby/lib/ruby/1.8/monitor.rb:242:in `synchronize'
/opt/ruby/lib/ruby/1.8/logger.rb:496:in `write'
/opt/ruby/lib/ruby/1.8/logger.rb:326:in `add'
/opt/ruby/lib/ruby/1.8/logger.rb:374:in `info'
/home/rails/myapp.com/releases/20100203203031/app/models/gmail.rb:35:in `log'

我的记录器看起来像这样:

@@error_log_file = File.open("#{RAILS_ROOT}/log/error.log", 'a')
@@error_log_file.sync = true
def log(msg)
  msg.each do |line|
    line = "#{Time.now.strftime('%H:%M:%S')}  #{line}"
    @@error_log_file.info(line) # this is line 35 where it's failing
    puts line
  end
end

如果我注释掉“@@error_log_file.sync = true”行,它也可以工作。

这是一个延迟的工作问题,还是与我的日志目录是一个符号链接有关(由标准 capistrano 部署设置)?

我的error.log文件也没有写入任何内容,delayed_job.log也没有写入任何内容。彻底懵了……

4

3 回答 3

5

伍迪彼得森在这里发现了问题:http ://groups.google.com/group/delayed_job/browse_thread/thread/f7d0534bb6c7c83f/37b4e8ed7bfaba42

问题是:

DJ 在生产中使用 Rails 的缓冲日志,并且由于某种原因没有触发刷新缓冲区(不知道它是按缓冲区大小刷新还是在请求后显式刷新)。

临时修复(归功于 Nathan Phelps)是:

在生产中,缓冲日志设置为 1000 的 auto_flushing 值,这意味着在记录 1000 条消息之前不会调用刷新。假设您正在使用collectiveidea 的delayed_job 分支,您可以通过在第64 行初始化记录器后立即在command.rb 中将auto_flushing 设置为更合理的值来解决此问题。IE

延迟::Worker.logger = Rails.logger

Delayed::Worker.logger.auto_flushing = 1 # 或其他

完美地为我工作!

于 2010-02-11T20:02:37.817 回答
0

看起来您正在尝试登录到已关闭的文件。您是否考虑过尝试 SyslogLogger gem?

是一篇关于如何将它与 rails 一起使用的文章,它应该可以帮助您入门。

于 2010-02-03T21:24:56.797 回答
0

我有一个类似的问题。正在重写collectiveidea 分叉中的日志记录- 请参阅此问题以获取更多信息。也许尝试最新版本,看看是否可以为您解决问题。

于 2010-02-04T19:49:27.643 回答