鯖(OS:Debian9)を借りてから初期の話。
Rubyの環境構築の際、案の定Nokogiriがインストールできなかったのでメモ。
エラーログ
(ログとってなかったのでよそからのコピペです)(内容はだいたいあってる)
Building native extensions. This could take a while...
ERROR: Error installing nokogiri:
ERROR: Failed to build gem native extension.
current directory: /var/lib/gems/2.3.0/gems/ffi-1.9.18/ext/ffi_c
/usr/bin/ruby2.3 -r ./siteconf20171120-16712-g2o2td.rb extconf.rb
checking for ffi.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=/usr/bin/$(RUBY_BASE_NAME)2.3
--with-ffi_c-dir
--without-ffi_c-dir
--with-ffi_c-include
--without-ffi_c-include=${ffi_c-dir}/include
--with-ffi_c-lib
--without-ffi_c-lib=${ffi_c-dir}/lib
--with-libffi-config
--without-libffi-config
--with-pkg-config
--without-pkg-config
/usr/lib/ruby/2.3.0/mkmf.rb:456:in `try_do': The compiler failed to generate an executable file. (RuntimeError)
You have to install development tools first.
from /usr/lib/ruby/2.3.0/mkmf.rb:587:in `try_cpp'
from /usr/lib/ruby/2.3.0/mkmf.rb:1091:in `block in have_header'
from /usr/lib/ruby/2.3.0/mkmf.rb:942:in `block in checking_for'
from /usr/lib/ruby/2.3.0/mkmf.rb:350:in `block (2 levels) in postpone'
from /usr/lib/ruby/2.3.0/mkmf.rb:320:in `open'
from /usr/lib/ruby/2.3.0/mkmf.rb:350:in `block in postpone'
from /usr/lib/ruby/2.3.0/mkmf.rb:320:in `open'
from /usr/lib/ruby/2.3.0/mkmf.rb:346:in `postpone'
from /usr/lib/ruby/2.3.0/mkmf.rb:941:in `checking_for'
from /usr/lib/ruby/2.3.0/mkmf.rb:1090:in `have_header'
from extconf.rb:16:in `'
extconf failed, exit code 1
ちなみにエラーログ中に登場するmkmf.logの場所は/var/lib/gems/2.3.0/extensions/x86_64-linux/2.3.0/nokogiri-1.8.2/
にありました。
原因を調べるためにいろいろなブログの情報をかき集めると、
「ruby-devがインストールすればいい」
「zlib1g-devがインストールすればいい」
「liblzma-devがインストールすればいい」
などなど断片的な情報が多く、結局なにをインストールすればNokogiriがインストールできるのかわからない状況に陥ってしまいました。
ちなみに上記の3つをインストールしてもNokogiriはインストールできませんでした。
結局なにをインストールすればいいのか
すべてはNokogiriのチュートリアルに載っていました。
これのUbuntu/Debian用である
$ sudo apt-get install build-essential patch ruby-dev zlib1g-dev liblzma-dev
を実行するとNokogiriがインストールできます。
やっぱり公式ドキュメントは大事ですね。