我遇到了一些奇怪的问题,我的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也没有写入任何内容。彻底懵了……