sqlite3 1.3.6推送来自heroku的拒绝

时间:2013-03-07 00:11:45

标签: ruby-on-rails heroku sqlite

-----> Ruby/Rails app detected
-----> Installing dependencies using Bundler version 1.3.0.pre.5
       Running: bundle install --without development:test --path vendor/bundle --binstubs vendor/bundle/bin --deployment
       You are trying to install in deployment mode after changing
       your Gemfile. Run `bundle install` elsewhere and add the
       updated Gemfile.lock to version control.
       You have added to the Gemfile:
       * pg
       * sqlite3
       You have deleted from the Gemfile:
       * sqlite3 (= 1.3.6)
 !
 !     Failed to install gems via Bundler.
 !
 !     Heroku push rejected, failed to compile Ruby/rails app

即使在使用此答案中建议的更新修复我的Gemfile后,这也是我遇到的问题

HEROKU - cannot run git push heroku master

即使添加了上面提到的Gemfile.lock!我收到了这组错误。尝试编译sqlite3时失败了。

Installing sqlite3 (1.3.7)
       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_1u9pbycs3fav1/vendor/bundle/ruby/1.9.1/gems/sqlite3-1.3.7 for inspection.
       Results logged to /tmp/build_1u9pbycs3fav1/vendor/bundle/ruby/1.9.1/gems/sqlite3-1.3.7/ext/sqlite3/gem_make.out
       An error occurred while installing sqlite3 (1.3.7), and Bundler cannot continue.
       Make sure that `gem install sqlite3 -v '1.3.7'` succeeds before bundling.
 !
 !     Failed to install gems via Bundler.
 !
 !     Heroku push rejected, failed to compile Ruby/rails app

我猜我可能要更改一些依赖项?或者我应该怎么做,我以前从未这样做过。 !

1 个答案:

答案 0 :(得分:2)

就像我写的here

Heroku不支持sqlite数据库。您需要在生产中使用postgres。在rails中,切换数据库很简单:

group :production do
  gem "pg"
end

group :development, :test do
  gem "sqlite3"
end

更改上面的gem文件,然后运行bundle,并将更改提交到GemfileGemfile.lock。然后,再次运行git push heroku master

这将允许您在开发和测试环境中本地使用sqlite,并在heroku上根据需要使用postgres。

顺便说一下,rails的一个主要优点是它可以让你轻松切换数据库。在其他框架中,这样做可能会耗费数小时。