我正在尝试在 rails 3.0.20 和 ruby 1.8.7 的项目中创建自定义错误页面。
无论如何在我的应用程序控制器中:
unless Rails.application.config.consider_all_requests_local
rescue_from Exception, :with => :render_error
rescue_from ActionController::RoutingError, ActionController::UnknownController, ::AbstractController::ActionNotFound, ActiveRecord::RecordNotFound, :with => :render_error_not_found
end
然后是渲染错误方法:
def render_error(exception)
notify_airbrake(exception)
Rails.logger.fatal exception
Rails.logger.fatal exception.backtrace.join("\n")
respond_to do |format|
format.html { render :template => "errors/error_500", :layout => 'layouts/application'}
format.all { render :nothing => true, :status => 500 }
end
end
似乎现在我的日志充满了比通常更长的回溯。为什么会这样?有没有办法只显示回溯的“重要”部分?在这里调用airbrake是否正确?
谢谢