##環境
Windows7 64bit
##エラー内容
rails newコマンドを実行すると
次のrails serverコマンドでエラーが出る
rails server
Could not find gem 'sqlite3 x86-mingw32' in any of the gem sources listed in you
r Gemfile or available on this machine.
(Gemfileにリストされている、またはこのマシンで利用可能なgemソースのいずれかにgem 'sqlite3 x86-mingw32'が見つかりませんでした。)
Run `bundle install` to install missing gems.
(足りないgemをインストールするために `bundle install`を実行してください。)
bundle installを試してもエラーが出る
bundle install
Fetching gem metadata from https://rubygems.org/..............
Fetching version metadata from https://rubygems.org/...
Fetching dependency metadata from https://rubygems.org/..
Resolving dependencies...
Using rake 12.3.2
Using concurrent-ruby 1.1.5
Using minitest 5.11.3
Using thread_safe 0.3.6
Using builder 3.2.3
Using erubis 2.7.0
Using mini_portile2 2.4.0
Using crass 1.0.4
Using rack 2.0.7
Using nio4r 2.3.1
Using websocket-extensions 0.1.3
Using mini_mime 1.0.1
Using arel 7.1.4
Using bindex 0.7.0
Using bundler 1.13.6
Using coffee-script-source 1.12.2
Using execjs 2.7.0
Using method_source 0.9.2
Using thor 0.20.3
Using ffi 1.10.0
Using multi_json 1.13.1
Using puma 3.12.1
Using rb-fsevent 0.10.3
Using tilt 2.0.9
Installing sqlite3 1.4.0 with native extensions
Using turbolinks-source 5.2.0
Installing i18n 1.6.0
Using tzinfo 1.2.5
Installing nokogiri 1.10.2
Using rack-test 0.6.3
Using sprockets 3.7.2
Using websocket-driver 0.6.5
Using mail 2.7.1
Using coffee-script 2.4.1
Using uglifier 4.1.20
Using rb-inotify 0.10.0
Gem::Ext::BuildError: ERROR: Failed to build gem native extension.
C:/RailsInstaller/Ruby2.2.0/bin/ruby.exe -r
./siteconf20190413-8660-1gagbbb.rb extconf.rb
checking for sqlite3.h... no
sqlite3.h is missing. Install SQLite3 from http://www.sqlite.org/ first.
*** 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.
(何らかの理由でMakefileを作成できませんでした。おそらく必要なライブラリやヘッダーが不足しています。 詳細については、mkmf.logファイルを確 認してください。 設定オプションが必要になるかもしれません。)
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=C:/RailsInstaller/Ruby2.2.0/bin/$(RUBY_BASE_NAME)
--with-sqlcipher
--without-sqlcipher
--with-sqlite3-config
--without-sqlite3-config
--with-pkg-config
--without-pkg-config
--with-sqlcipher
--without-sqlcipher
--with-sqlite3-dir
--without-sqlite3-dir
--with-sqlite3-include
--without-sqlite3-include=${sqlite3-dir}/include
--with-sqlite3-lib
--without-sqlite3-lib=${sqlite3-dir}/lib
extconf failed, exit code 1
Gem files will remain installed in
C:/RailsInstaller/Ruby2.2.0/lib/ruby/gems/2.2.0/gems/sqlite3-1.4.0 for
inspection.
Results logged to
C:/RailsInstaller/Ruby2.2.0/lib/ruby/gems/2.2.0/extensions/x86-mingw32/2.2.0/sql
ite3-1.4.0/gem_make.out
An error occurred while installing sqlite3 (1.4.0), and Bundler cannot continue.
(sqlite3(1.4.0)のインストール中にエラーが発生し、Bundlerは続行できません。)
Make sure that `gem install sqlite3 -v '1.4.0'` succeeds before bundling.
(バンドルする前に `gem install sqlite3 -v '1.4.0'が成功することを確認してください。)
sqlite3 -v '1.4.0'を試してもエラーが出る
sqlite3 -v '1.4.0'
Temporarily enhancing PATH to include DevKit...
Building native extensions. This could take a while...
ERROR: Error installing sqlite3:
ERROR: Failed to build gem native extension.
Gemネイティブエクステンションの構築に失敗しました。
C:/RailsInstaller/Ruby2.2.0/bin/ruby.exe -r ./siteconf20190413-8772-tajpma.r
b extconf.rb
checking for sqlite3.h... no
sqlite3.h is missing. Install SQLite3 from http://www.sqlite.org/ first.
sqlite3.hが見つかりません。
*** 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=C:/RailsInstaller/Ruby2.2.0/bin/$(RUBY_BASE_NAME)
--with-sqlcipher
--without-sqlcipher
--with-sqlite3-config
--without-sqlite3-config
--with-pkg-config
--without-pkg-config
--with-sqlcipher
--without-sqlcipher
--with-sqlite3-dir
--without-sqlite3-dir
--with-sqlite3-include
--without-sqlite3-include=${sqlite3-dir}/include
--with-sqlite3-lib
--without-sqlite3-lib=${sqlite3-dir}/lib
extconf failed, exit code 1
Gem files will remain installed in C:/RailsInstaller/Ruby2.2.0/lib/ruby/gems/2.2
.0/gems/sqlite3-1.4.0 for inspection.
Results logged to C:/RailsInstaller/Ruby2.2.0/lib/ruby/gems/2.2.0/extensions/x86
-mingw32/2.2.0/sqlite3-1.4.0/gem_make.out
sqlite3.hをパスの通った所においてもエラーが出る
gem install sqlite3 --platform=ruby -- --with-sqlite3-include=C:/sqlite3/ --with-sqlite3-lib=C:/sqlite3/dll
Temporarily enhancing PATH to include DevKit...
Building native extensions with: '--with-sqlite3-include=C:/sqlite3/ --with-sqli
te3-lib=C:/sqlite3/dll'
This could take a while...
ERROR: Error installing sqlite3:
ERROR: Failed to build gem native extension.
C:/RailsInstaller/Ruby2.2.0/bin/ruby.exe -r ./siteconf20190413-9596-gytlp9.r
b extconf.rb --with-sqlite3-include=C:/sqlite3/ --with-sqlite3-lib=C:/sqlite3/dl
l
checking for sqlite3.h... yes
checking for pthread_create() in -lpthread... no
checking for main() in -ldl... no
checking for dlopen()... no
missing function dlopen
*** 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=C:/RailsInstaller/Ruby2.2.0/bin/$(RUBY_BASE_NAME)
--with-sqlcipher
--without-sqlcipher
--with-sqlite3-config
--without-sqlite3-config
--with-pkg-config
--without-pkg-config
--with-sqlcipher
--without-sqlcipher
--with-sqlite3-dir
--without-sqlite3-dir
--with-sqlite3-include=${sqlite3-dir}/include
--with-sqlite3-lib=${sqlite3-dir}/lib
--with-pthreadlib
--without-pthreadlib
--with-dllib
--without-dllib
extconf failed, exit code 1
Gem files will remain installed in C:/RailsInstaller/Ruby2.2.0/lib/ruby/gems/2.2
.0/gems/sqlite3-1.4.0 for inspection.
Results logged to C:/RailsInstaller/Ruby2.2.0/lib/ruby/gems/2.2.0/extensions/x86
-mingw32/2.2.0/sqlite3-1.4.0/gem_make.out
##解決策
正解はこの記事が知っていた
「Windows10でRuby on Railsの環境構築」
https://qiita.com/shita_fontaine/items/aa3f762d7afa20c5d42a
どうやら2019年2月から4月15日現在ではrails newではエラーが起きるらしい。
原因はrails newコマンド。このコマンドはアプリケーションを作るコマンドであるが、実行されるbundle installコマンドにて、sqlite3を使用するgemのinstallが行われる。
そのgemのversionが1.4.0であり、1.4.0は2019年2月4日に追加されたばかりであったためか、gem installコマンドを利用すると下記のようなエラーを吐く。
解決策は、rails newコマンドに--skip-bundleオプションをつけて実行し、Gemfileのsqliteのバージョンを編集し、bundle installを実行することらしい。
全てをインストールし直し試してみると成功。
メモ代わりに残す。