web-dev-qa-db-ja.com

sqlite3 gemエラーが原因で、Herokuのデプロイに失敗しました

Michael HartlによるRuby.railstutorial.orgの本を始めたばかりで、最初の章に取り組んでいます。 Mac Book OS X、Terminal、SublimeTextを使用しています。 Herokuへのデプロイをテストするときまで、すべてが計画どおりに進んでいます。 Herokuに接続して、$ git Push herokuマスターコマンドを実行できます。しかし、展開は失敗します。

Installing sqlite3 (1.3.5) with native extensions
       Gem::Installer::ExtensionBuildError: ERROR: Failed to build gem native extension.
       /usr/local/bin/Ruby extconf.rb
       checking for sqlite3.h... no
       sqlite3.h is missing. Try 'port install sqlite3 +universal'
       or 'yum install sqlite-devel' and check your shared library search path (the
       location where your sqlite3 shared library is located).
       *** extconf.rb failed ***
       Could not create Makefile due to some reason, probably lack of
       necessary libraries and/or headers.  Check the mkmf.log file for more
       details.  You may need configuration options.
       Provided configuration options:


An error occurred while installing sqlite3 (1.3.5), and Bundler cannot continue.
       Make sure that `gem install sqlite3 -v '1.3.5'` succeeds before bundling.
 !
 !     Failed to install gems via Bundler.
 !     
 !     Detected sqlite3 gem which is not supported on Heroku.
 !     http://devcenter.heroku.com/articles/how-do-i-use-sqlite3-for-development
 !
 !     Heroku Push rejected, failed to compile Ruby/Rails app

これが私のGemfileです

source 'https://rubygems.org'

       gem 'Rails', '3.2.8'

       # Bundle Edge Rails instead:
       # gem 'Rails', :git => 'git://github.com/Rails/rails.git'

       group :development, :test do
   gem 'sqlite3', '1.3.5'
       end


       # Gems used only for assets and not required
       # in production environments by default.
       group :assets do
       gem 'sass-Rails',   '~> 3.2.5'
       gem 'coffee-Rails', '~> 3.2.2'

       # See https://github.com/sstephenson/execjs#readme for more supported runtimes
       # gem 'therubyracer', :platforms => :Ruby

       gem 'uglifier', '>= 1.2.3'
       end

       gem 'jquery-Rails', '2.0.2'

       group :production do
   gem 'pg', '0.12.2'
       end

       # To use ActiveModel has_secure_password
       # gem 'bcrypt-Ruby', '~> 3.0.0'

       # To use Jbuilder templates for JSON
       # gem 'jbuilder'

       # Use Unicorn as the app server
       # gem 'Unicorn'

       # Deploy with Capistrano
       # gem 'capistrano'

       # To use debugger
       # gem 'debugger'

私はsqlite3を本番ではなく開発用に指定しているので、Herokuはそれをすべて無視するだけだと思いましたが、そうではないようです。

また、バンドルを作成するときは、$ bundleinstallを使用しています-本番環境なし

PGをインストールして使用することを提案する人もいることは知っていますが、別のアプローチを試す前に、できるだけチュートリアルに固執したいと思います。

私は今少し迷っています、そしてここからどのように進むべきかわかりません。あなたが提供できるどんな助けでも最もありがたいです。

ありがとう

17
xuamox

Herokuは、何らかの理由でsqlite3gemをインストールできません。しかし、bundlerに、開発中以外は試みるべきではないことを伝えることができます。

Gemfileで、gem 'sqlite3'を次のように置き換えます。

group :development, :test do
  gem 'sqlite3'
end
group :production do
  gem 'pg'
end

次に、productionとして実行されているherokuのbundlerはインストールを試みません。

23
Chowlett

ようやくHerokuに正常にデプロイできました。 Herokuサイトの記事を紹介してくれたevanc3に感謝します。 Herokuにデプロイする前に、Gemgileの更新をコミットするのを単に忘れたようです。したがって、始めたばかりのすべての人にとって、Herokuにデプロイする前に変更をコミットすることを確認する必要があります。

14
xuamox

Herokuはsqlite3をサポートしていません...

Gemfileからsqlite3を削除し、代わりにpggemを使用します。 gemファイルで次の変更を行います

Gemfileでフォローを変更します

gem 'sqlite3'

gem 'pg' #you will have to install postgresql

重要:実行

git add .
git commit 
git Push heroku master

注:herokuのデプロイを計画している場合は、開発フェーズでもpostgresを使用することをお勧めします(コンピューターにpostgresqlをインストールします)。herokuはpsqlを優先します。

開発にsqlliteを使用し、Herokuにpostgresqlを使用する場合は、次の構成を使用します。

group :development do 
   gem 'sqlite3'    #gem to use in development environment
end

group :production do 
  gem 'pg'         #gem to use in production environment
end

Herokuはアプリケーションを本番環境で実行するため、Herokuはpggemを使用します

9
Bibin Venugopal

Herokuでは、アプリはファイルシステムにアクセスできません。これにはいくつかの理由があります-これは基本的に、新しいインスタンスを追加することで(つまり、一度に複数のサーバーを実行することで)アプリのパフォーマンスを拡張できるという事実によるものであり、これらのインスタンスが同じ物理マシン上にあることが保証されているわけではありません-コピー全体のファイルは非常に遅くなります。

SQLiteはデータベースをdb /フォルダー内のファイルに保存するだけなので、Herokuと互換性がありません。

ヘルプリンクで提案されているように、SQLiteとPostgreSQL(Herokuが選択したデータベース)の間に微妙な非互換性があり、これを見つけたい場合があるため、SQLiteから離れることが最善のオプションですbefore you本番環境にデプロイしてください!

PostgreSQLをインストールした後(正確にこれを行う方法はOSによって異なります)、Gemfileにgem 'pg'を追加します。

1
Andrew Haines

Gemfileに直接sqlite3がなくても、このエラーが発生する場合の解決策があります。

ほとんどの場合、依存関係としてsqlite3を使用するgemがあり、知らないうちにgemが含まれています。

1)Gemfile.lockに移動し、sqliteを検索します。

2)sqliteを使用しているgemを見つけて、gemを開発グループまたはテストグループに移動します。

3)バンドル

0
Daniel Sun Yang