3

システムが最小要件を満たしていることを確認した後、バージョンが適切であることの確認を開始します。 rails new app 新しいアプリケーションをゼロにすると、次のメッセージが表示されます。

         run  bundle install
/var/lib/gems/1.9.1/gems/bundler-1.3.5/lib/bundler/ui.rb:36:in `initialize': undefined method `[]' for #<Thor::Shell::Color:0x95890e0> (NoMethodError)
    from /usr/lib/ruby/vendor_ruby/bundler/cli.rb:12:in `new'
    from /usr/lib/ruby/vendor_ruby/bundler/cli.rb:12:in `initialize'
    from /usr/lib/ruby/vendor_ruby/bundler/vendor/thor.rb:263:in `new'
    from /usr/lib/ruby/vendor_ruby/bundler/vendor/thor.rb:263:in `dispatch'
    from /usr/lib/ruby/vendor_ruby/bundler/vendor/thor/base.rb:386:in `start'
    from /var/lib/gems/1.9.1/gems/bundler-1.3.5/bin/bundle:20:in `block in <main>'
    from /var/lib/gems/1.9.1/gems/bundler-1.3.5/lib/bundler/friendly_errors.rb:3:in `with_friendly_errors'
    from /var/lib/gems/1.9.1/gems/bundler-1.3.5/bin/bundle:20:in `<main>'

新しく作成した Rails アプリケーションに入りました。すぐにbundle installインストールを開始すると、次のエラーメッセージが表示されます。

Gem::Installer::ExtensionBuildError: ERROR: Failed to build gem native extension.

        /usr/bin/ruby1.9.1 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/bin/ruby1.9.1
    --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 /home/helio/.bundler/tmp/23089/gems/sqlite3-1.3.8 for inspection.
Results logged to /home/helio/.bundler/tmp/23089/gems/sqlite3-1.3.8/ext/sqlite3/gem_make.out

An error occurred while installing sqlite3 (1.3.8), and Bundler
cannot continue.
Make sure that `gem install sqlite3 -v '1.3.8'` succeeds before
bundling.

試してみましたが、splite3 をインストールしようとするとエラー メッセージが表示されます。

Building native extensions.  This could take a while...
ERROR:  Error installing sqlite3:
    ERROR: Failed to build gem native extension.

        /usr/bin/ruby1.9.1 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/bin/ruby1.9.1
    --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 /var/lib/gems/1.9.1/gems/sqlite3-1.3.8 for inspection.
Results logged to /var/lib/gems/1.9.1/gems/sqlite3-1.3.8/ext/sqlite3/gem_make.out
4

4 に答える 4

1

私にとっては、(MacOS で) GNU MP ライブラリが見つからないというエラーが発生しました。

これは ~/.rvm/gems/ruby-2.1.3/extensions/x86_64-darwin-13/2.1.0-static/sqlite3-1.3.9/mkmf.log ファイルに記載されています

-lgmpがありませんでした

brew はライブラリが存在することを示しましたが、Xcode は知りたがっていたと思います:

私の軌跡…

$ brew install gmp 警告: gmp-6.0.0a は既にインストールされています ✔ ~/.rvm/gems/ruby-2.1.3/extensions/x86_64-darwin-13/2.1.0-static/sqlite3-1.3.9

$ brew install gmp4 警告: gmp4-4.3.2 は既にインストールされています ✔ ~/.rvm/gems/ruby-2.1.3/extensions/x86_64-darwin-13/2.1.0-static/sqlite3-1.3.9

$ ls -altd /usr/local/lib/libgmp* lrwxr-xr-x 1 si staff 40 Jul 31 15:48 /usr/local/lib/libgmp.10.dylib -> ../Cellar/gmp/6.0. 0a/lib/libgmp.10.dylib lrwxr-xr-x 1 si スタッフ 33 Jul 31 15:48 /usr/local/lib/libgmp.a -> ../Cellar/gmp/6.0.0a/lib/libgmp. a lrwxr-xr-x 1 si スタッフ 37 Jul 31 15:48 /usr/local/lib/libgmp.dylib -> ../Cellar/gmp/6.0.0a/lib/libgmp.dylib lrwxr-xr-x 1 siスタッフ 41 7 月 31 日 15:48 /usr/local/lib/libgmpxx.4.dylib -> ../Cellar/gmp/6.0.0a/lib/libgmpxx.4.dylib lrwxr-xr-x 1 si スタッフ 35 7 月 31 日15:48 /usr/local/lib/libgmpxx.a -> ../Cellar/gmp/6.0.0a/lib/libgmpxx.a lrwxr-xr-x 1 si スタッフ 39 Jul 31 15:48 /usr/local/ lib/libgmpxx.dylib -> ../Cellar/gmp/6.0.0a/lib/libgmpxx.dylib ✔ ~/.rvm/gems/ruby-2.1.3/extensions/x86_64-darwin-13/2.1.0-static /sqlite3-1.3.9

$ otool -L /usr/local/lib/libgmpxx.dylib /usr/local/lib/libgmpxx.dylib: /usr/local/lib/libgmpxx.4.dylib (互換バージョン 9.0.0、現行バージョン 9.0.0) /usr/local/Cellar/gmp/6.0.0a/lib/libgmp.10.dylib (互換バージョン 13.0.0、現在のバージョン 13.0.0) /usr/lib/libc++.1.dylib (互換バージョン 1.0.0、現在のバージョン 120.0.0) /usr/lib/libSystem.B.dylib (互換バージョン 1.0.0、現在のバージョン 1197.1.1) ✔ ~/.rvm/gems/ruby-2.1.3/extensions/x86_64-darwin-13 /2.1.0-静的/sqlite3-1.3.9

$ gem install sqlite3 '1.3.9' ネイティブ拡張機能のビルド。これにはしばらく時間がかかる可能性があります... sqlite3-1.3.9 が正常にインストールされました エラー: どのリポジトリにも有効な gem '1.3.9' (>= 0) が見つかりませんでした 1 gem installed

この ERROR メッセージが表示されたにもかかわらず、正常にインストールされたように見えました

于 2014-10-20T16:52:12.733 に答える
0

問題はGemfileにありました。チュートリアルには次のような注意書きがあります: Windows と Mac にはデフォルトで Java ランタイム スクリプトもインストールされています。代わりに、Linux はそれを実行しません。別途インストールする必要があります。しかし、解決するのは非常に簡単です。最初は、Gemfile でランタイムを参照する行をクリアすることです。2つ目はbundle install。このコマンドを実行する Bundler は、必要なソフトウェアと boala をインストールし、解決しました。

于 2013-10-16T19:11:29.383 に答える