1

このディスカッションで推奨されているように、すべてのファイルがリポジトリのルートにあることを確認しました。しかし、私は本のこのセクションの指示に従っているので、問題なくセクションを通過することはできません。エラーの原因となっている私のシステムで何が起こっていると思いますか?ログで以下を読んだにもかかわらず、問題が何を意味するのか、現時点ではわかりません。よろしくお願いします!

stanley@ubuntu:~/rails_sample/first_app$ git push heroku master
Warning: Permanently added the RSA host key for IP address '50.19.85.156' to the list of known hosts.
Counting objects: 96, done.
Compressing objects: 100% (79/79), done.
Writing objects: 100% (96/96), 28.81 KiB, done.
Total 96 (delta 22), reused 0 (delta 0)

-----> Heroku receiving push
-----> Ruby/Rails app detected
-----> Installing dependencies using Bundler version 1.2.0.pre
       Running: bundle install --without development:test --path vendor/bundle --binstubs bin/ --deployment
       Fetching gem metadata from https://rubygems.org/.......
       Installing rake (0.9.2.2)
       Installing i18n (0.6.0)
       Installing multi_json (1.3.5)
       Installing activesupport (3.2.3)
       Installing builder (3.0.0)
       Installing activemodel (3.2.3)
       Installing erubis (2.7.0)
       Installing journey (1.0.3)
       Installing rack (1.4.1)
       Installing rack-cache (1.2)
       Installing rack-test (0.6.1)
       Installing hike (1.2.1)
       Installing tilt (1.3.3)
       Installing sprockets (2.1.3)
       Installing actionpack (3.2.3)
       Installing mime-types (1.18)
       Installing polyglot (0.3.3)
       Installing treetop (1.4.10)
       Installing mail (2.4.4)
       Installing actionmailer (3.2.3)
       Installing arel (3.0.2)
       Installing tzinfo (0.3.33)
       Installing activerecord (3.2.3)
       Installing activeresource (3.2.3)
       Installing coffee-script-source (1.3.3)
       Installing execjs (1.3.2)
       Installing coffee-script (2.2.0)
       Installing rack-ssl (1.3.2)
       Installing json (1.7.3) with native extensions
       Installing rdoc (3.12)
       Installing thor (0.14.6)
       Installing railties (3.2.3)
       Installing coffee-rails (3.2.2)
       Installing jquery-rails (2.0.2)
       Using bundler (1.2.0.pre)
       Installing rails (3.2.3)
       Installing sass (3.1.18)
       Installing sass-rails (3.2.5)
       Installing sqlite3 (1.3.6) 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:
       --with-opt-dir
       --without-opt-dir
       --with-opt-include
       --without-opt-include=${opt-dir}/include
       --with-opt-lib
       --without-opt-lib=${opt-dir}/lib
       --with-make-prog
       --without-make-prog
       --srcdir=.
       --curdir
       --ruby=/usr/local/bin/ruby
       --with-sqlite3-dir
       --without-sqlite3-dir
       --with-sqlite3-include
       --without-sqlite3-include=${sqlite3-dir}/include
       --with-sqlite3-lib
       --without-sqlite3-lib=${sqlite3-dir}/lib
       --enable-local
       --disable-local
       Gem files will remain installed in /tmp/build_3tplrxvj7qa81/vendor/bundle/ruby/1.9.1/gems/sqlite3-1.3.6 for inspection.
       Results logged to /tmp/build_3tplrxvj7qa81/vendor/bundle/ruby/1.9.1/gems/sqlite3-1.3.6/ext/sqlite3/gem_make.out
       An error occurred while installing sqlite3 (1.3.6), and Bundler cannot continue.
       Make sure that `gem install sqlite3 -v '1.3.6'` succeeds before bundling.
 !
 !     Failed to install gems via Bundler.
 !
 !     Heroku push rejected, failed to compile Ruby/rails app

To git@heroku.com:growing-mountain-2788.git
 ! [remote rejected] master -> master (pre-receive hook declined)
error: failed to push some refs to 'git@heroku.com:growing-mountain-2788.git'

------Gemfile ------------------------

要求に応じて、自動生成されたgemfileは次のとおりです。

source 'https://rubygems.org'

gem 'rails', '3.2.3'

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

gem 'sqlite3'

gem 'json'

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

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

  gem 'uglifier', '>= 1.0.3'
end

gem 'jquery-rails'

# 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 'ruby-debug'
4

5 に答える 5

2

問題は、サーバー上のsqlite3へのヘッダーファイルが欠落していることであり、gemは拡張機能をビルドできません。sqliteが必要ですか?Gemfileから削除してみてください。可能であれば、サーバーにsqlite3-devパッケージをインストールしてください。

于 2012-05-19T23:03:51.083 に答える
2

Herokuはpostgresを自動的に使用しようとします。(sqliteはプロオークションには適していないので良いことです)sqliteスクリプトはpostgresと互換性があるため、変更は必要ありません。

あなたのGemfileでこれをしてください:

gem "sqlite3", :groups => [:development, :test]
gem "pg", groups => [:production]

sqliteとpostgresの間に動作の違いがあるかもしれないことに注意してください。開発環境でpostgresを使用することを強くお勧めします

https://devcenter.heroku.com/articles/how-do-i-use-sqlite3-for-developmentを参照してください

于 2012-05-19T23:14:30.540 に答える
1

これと同じ問題が発生しました。GitHubへのプッシュを完了すると、問題は解決しました。

このステップを完了する必要がありました:

$ git remote add origin ...
$ git push -u origin master

その後、問題なくherokuにプッシュしました。

于 2012-06-29T03:12:12.133 に答える
0

SQLitegemをpostgresのpggemに置き換えます。HerokuはPostgresを使用しており、とにかく本番モードでSQLiteを使用する必要はありません。

Gemfileのsqliteを「gempg」に置き換えます

于 2012-05-19T23:12:40.790 に答える
0

HerokuはSQLiteではなくPostgreSQLを使用します。この手順に従って、問題を解決してくださいhttps://devcenter.heroku.com/articles/rails3

于 2012-05-19T23:16:45.057 に答える