无法推送到heroku - sqlite3.h丢失了

时间:2012-06-12 00:32:55

标签: ruby-on-rails heroku sqlite

首先发布在这里=)在此先感谢您的帮助,此时任何帮助都很酷!

1-我在搜索stackoverflow之前已经搜索了很多并尝试了很多东西..

2-运行时

   git push heroku master

我明白了:

   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).

3-我检查了Gemfile:生产和开发/测试分别配置为pg和sqlite3

4- Sqlite3.h在这里:

   pcbo$ ls -l /usr/include/sqlite3.h
   -rw-r--r--  1 root  wheel  322724  7 Dec  2011 /usr/include/sqlite3.h

5-忘了提到我正在使用mac os x ..

6-输出:         pcbo $ git push heroku master

    Counting objects: 71, done.
    Delta compression using up to 4 threads.
    Compressing objects: 100% (58/58), done.
    Writing objects: 100% (71/71), 26.46 KiB, done.
    Total 71 (delta 8), 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.6)
   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.4.0)
   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)
   Installing pg (0.12.2) with native extensions
   Using bundler (1.2.0.pre)
   Installing rails (3.2.3)
   Installing sass (3.1.19)
   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_zmjrcoagwpai/vendor/bundle/ruby/1.9.1/gems/sqlite3-1.3.6 for inspection.
   Results logged to /tmp/build_zmjrcoagwpai/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

7-非常感谢任何帮助!

2 个答案:

答案 0 :(得分:11)

<强> [UPDATE1]

从你的git推送日志中,这是你的罪魁祸首: -

 Installing sqlite3 (1.3.6) with native extensions

所以,正如我最初所怀疑的那样,错误是试图加载sqlite3宝石,这将在heroku上失败。如前所述,这可能因为两个原因而发生

  1. 错误地将Gemfile配置为在生产中需要sqlite3 gem
  2. 其他一些宝石依赖sqlite3宝石。使用gem dependency命令显示gem&amp;的依赖关系删除依赖sqlite3
  3. 的宝石

    之后,重新运行bundle install&amp;它会起作用。

    --- [End Update1] ---

    您可以获得此错误的唯一原因是,尝试在heroku上使用不受支持的sqlite3数据库。仔细检查您的Gemfile并确保其设置与此类似

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

    然后执行bundle install重新生成Gemfile.lock。现在,尝试推动heroku。如果您仍然收到此错误,那么您使用的某个gem可能会在其sqlite3文件中将gemspec列为硬编码依赖项。所以实际上,即使它不存在于gemfile中,也会加载sqlite3。所以验证这一点,在localhost上运行以下命令:

    $ bundle install | grep sqlite
    

    最后,尝试了这个。它不起作用。回发git push heroku master&amp;的完整日志。输出heroku logs

答案 1 :(得分:0)

似乎缺少sqlite库。 尝试使用

找到它
whereis sqlite3.h

如果它在您的系统中,请尝试:

sudo gem install sqlite3-ruby -- --with-sqlite3-include=<"url where it is(for eg: /usr/include)">

此致