Heroku Rails部署“ at =错误代码= H10 desc =“应用程序崩溃”

时间:2018-06-29 12:47:16

标签: ruby-on-rails ruby heroku rubygems

我试图在Heroku上部署我的Rails应用,但是我遇到两个h10错误:

heroku[router]: at=error code=H10 desc="App crashed" method=GET path="/" ... dyno= connect= service= status=503 bytes= protocol=https

at=error code=H10 desc="App crashed" method=GET path="/favicon.ico" ...  dyno= connect= service= status=503 bytes= protocol=https

当我在其他帖子中读到的时候,我跑了heroku console

我得到了这个答案:

/app/vendor/bundle/ruby/2.3.0/gems/activerecord-4.2.6/lib/active_record/dynamic_matchers.rb:26:in `method_missing': undefined local variable or method `acts_as_votable' for Comment (call 'Comment.connection' to establish a connection):Class (NameError)

当我做heroku run rake db:migrate时,我得到了:

rake aborted!
NameError: uninitialized constant ForestLiana`

这是我的Gemfile

source 'https://rubygems.org'

ruby '2.3.0'

gem 'rails', '4.2.6'

group :development do
  gem 'sqlite3'
end

group :production do
  gem 'pg'
end

gem 'rails_12factor'
gem 'sass-rails', '~> 5.0'
gem 'uglifier', '>= 1.3.0'
gem 'coffee-rails', '~> 4.1.0'

gem 'jquery-rails'    
gem 'turbolinks'    
gem 'jbuilder', '~> 2.0'    
gem 'sdoc', '~> 0.4.0', group: :doc
gem 'bcrypt', '~> 3.1.7'

group :development, :test do
  gem 'byebug'
end

group :development do
  gem 'web-console', '~> 2.0'
  gem 'spring'
  gem 'forest_liana'
  gem 'acts_as_votable', '~> 0.10.0'
end

是因为gem版本吗?我该如何解决这个问题?

1 个答案:

答案 0 :(得分:1)

将代码部署到Heroku时,它不会安装:development的{​​{1}}组中定义的gem,因为在生产环境中实际运行应用程序时通常不需要这些gem。

在您的情况下,您已经在开发组中添加了Gemfile gem。由于您的模型是依靠它的,因此您应该在acts_as_votable中的任何组之外定义它,以便始终安装它。

在检查堆栈跟踪时,您可以看到在Heroku上Gemfile类上调用的acts_as_votable方法不可用。这可能会提示您添加此方法的gem尚未安装或未以某种方式加载。