Ruby on Rails チュートリアル 第4版で第1章をやっているのですが、一番最後にHerokuにデプロイした後、アプリをブラウザで開くとアプリケーションエラーとなります。
原因はsqlite3なのですが、heroku logs
をしてみると以下のようなエラーが出ています。
Error
1 /app/vendor/bundle/ruby/2.4.0/gems/activerecord-5.1.4/lib/active_record/connection_adapters/connection_specification.rb:188:in `rescue in spec': Specified 'sqlite3' for database adapter, but the gem is not loaded. Add `gem 'sqlite3'` to your Gemfile (and ensure its version is at the minimum required by ActiveRecord). (Gem::LoadError)
Add gem 'sqlite3' to your Gemfile
とありますがGemfileはチュートリアル通りdevelopment
とtest
をsqlite3
に、production
をpg
(postgresql)にしてbundle install --without production
を実行しています。
Gemfile
1source 'https://rubygems.org' 2 3gem 'rails', '5.1.4' 4gem 'puma', '3.9.1' 5gem 'sass-rails', '5.0.6' 6gem 'uglifier', '3.2.0' 7gem 'coffee-rails', '4.2.2' 8gem 'jquery-rails', '4.3.1' 9gem 'turbolinks', '5.0.1' 10gem 'jbuilder', '2.6.4' 11 12group :development, :test do 13 gem 'sqlite3', '1.3.13' 14 gem 'byebug', '9.0.6', platform: :mri 15end 16 17group :development do 18 gem 'web-console', '3.5.1' 19 gem 'listen', '3.1.5' 20 gem 'spring', '2.0.2' 21 gem 'spring-watcher-listen', '2.0.1' 22end 23 24group :production do 25 gem 'pg', '0.20.0' 26end 27 28# Windows環境ではtzinfo-dataというgemを含める必要があります 29gem 'tzinfo-data', platforms: [:mingw, :mswin, :x64_mingw, :jruby]
Herokuはdatabase.yml
をHeokuの環境に合わせて勝手に設定するようなのでそもそもdatabase.yml
の編集はいらないのだと思います(現に特に編集していません)
参考:HerokuにRailsアプリをデプロイした時のdatabase.ymlの置き換えについて
このような状況なのですが、どのようにすればHerokuでデプロイしたアプリを実行できるでしょうか?
どうぞよろしくお願いします。
環境:Heroku, Rails v5.1.4
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。