gpt4 book ai didi

ruby-on-rails - Heroku 上的 Rails 应用程序 - 状态 500 错误 => 空白白页

转载 作者:数据小太阳 更新时间:2023-10-29 07:33:56 26 4
gpt4 key购买 nike

我在 Heroku 登台服务器上有一个 Rails 应用程序,除了错误页面无法正常工作外,一切都进行得很顺利。每次我收到“状态:500”错误时,都会生成空白页面,而不是 500.html 静态错误页面。

我在 my_app/public 文件夹中有一个静态 500.html 页面,如果我尝试直接通过 myapp.herokuapp.com/500 访问它,我可以在 heroku 中访问它。它将显示正常。但是,如果我在程序中遇到真正的“status: 500”错误,它不会呈现 500.html 页面……相反,它会呈现空白页面。

为了创建一个错误,我试图转到一个不存在的页面。日志表明发生了“status: 500”错误,但同样是白页。以下是日志的部分输出:

heroku[router]: at=info method=GET path="/fakepage" host=myapp.herokuapp.com request_id=20825-b474-4e-37f-c52486140 fwd="67.xxx.xxx.x" dyno=web.1 connect=1ms service=108ms status=500 bytes=949
Started GET "/fakepage" for xx.xxx.xxx.x at 2014-08-24 03:50:31 +0000
app[web.1]: ** [Raven] User excluded error: #<ActionController::RoutingError: No route matches [GET] "/fakepage">

config/environment/staging.rb 我有以下内容:

config.consider_all_requests_local = false
config.serve_static_assets = true #after the default of false didn't work

这似乎不应该是那些“棘手的问题”之一......并且没有找到任何与我的问题直接相关的先前帖子或文章让我认为这对我来说一定是愚蠢的。我目前正在运行 Ruby 2.0.0p451 和 Rails 4.1.1。我通过 heroku 设置了 Sentry 来监控错误。如果我可以提供任何其他有用的信息,请告诉我。

编辑我应该提到我的 Gemfile 看起来像这样:

  source 'https://rubygems.org'
ruby '2.0.0'
gem 'rails' #, '4.1.1'

gem 'bcrypt'
gem 'bootstrap_form'
gem 'bootstrap-sass'
gem 'carrierwave'
gem 'coffee-rails'
gem 'dropzonejs-rails'
gem 'email_validator'
gem 'fog'
gem 'geocoder'
gem 'haml-rails'
gem 'jquery-rails'
gem 'jquery-turbolinks'
gem 'jquery-ui-rails'
gem 'mini_magick'
gem 'paratrooper'
gem 'sass-rails'
gem 'sidekiq'
gem 'sinatra', require: nil
gem 'turbolinks'
gem 'uglifier'
gem 'unicorn'

group :production, :staging do
gem 'pg'
gem 'rails_12factor'
gem 'sentry-raven'
end

也就是说,如 a similar question 中所述,我确实将 gem 'rails_12factor' 放在了登台和生产环境的正确组中关于使用 Rails4 在 heroku 中提供静态 Assets ...基本上错误页面会做什么。我将应用程序设置为通过 Unicorn 运行多个进程,并临时设置 Unicorn 以在应用程序测试时在内部处理 Sidekiq 进程(以避免第二次测功机)。同时运行 Redis。

config/environments/staging.rb

Rails.application.configure do
config.cache_classes = true
config.eager_load = true
config.consider_all_requests_local = false
config.action_controller.perform_caching = true

config.serve_static_assets = true
config.assets.js_compressor = :uglifier
config.assets.compress = true
config.assets.compile = true #WAS FALSE
config.assets.digest = true
config.assets.version = '1.0'

config.action_mailer.default_url_options = { host: "..." }
config.action_mailer.delivery_method = :smtp
ActionMailer::Base.smtp_settings = {
:port => ENV['MAILGUN_SMTP_PORT' ],
:address => ENV['MAILGUN_SMTP_SERVER' ],
:user_name => ENV['MAILGUN_SMTP_LOGIN' ],
:password => ENV['MAILGUN_SMTP_PASSWORD'],
:domain => '...',
:authentication => :plain }

config.log_level = :info #see everything in the log
config.i18n.fallbacks = true
config.log_formatter = ::Logger::Formatter.new
config.action_dispatch.show_exceptions = false #per sentry-raven docs
config.active_record.dump_schema_after_migration = false
config.active_support.deprecation = :notify #send to registered listeners

最佳答案

我终于找到了问题的根源。结论是,当在没有任何自定义类的普通 Rails 应用程序中发生状态错误(404、500 等)时,Heroku 将提供基本错误页面。在我确定之后,它有助于指导诊断。

查看config/environments/staging.rb代码,看到sentry-raven在他们的文档中规定的LOC应该设置为false:

config.action_dispatch.show_exceptions = false #per sentry-raven docs

将其设置回 true 后,状态错误页面开始运行:

config.action_dispatch.show_exceptions = true #status error pages work again!

所以,我可能一直在误解 sentry-raven 的文档并将其错误地合并到 Rails 应用程序配置中,或者其他什么地方,但这就是问题所在。因此,如果您的 Heroku 托管 Rails 应用程序运行良好,然后在出现任何状态错误时遇到“白屏死机”,这就是您尝试诊断时需要检查的另一件事。

关于ruby-on-rails - Heroku 上的 Rails 应用程序 - 状态 500 错误 => 空白白页,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/25468529/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com