mini_racer gem 0.8.0 が Ruby 3.1.x とのバンドル インストールに失敗する
概要
この問題は過去に報告されており、mini_racer のアップデートにより解決されたようです。しかし、ここで乗り越えられないレンガの壁にぶつかったため、同じ問題が再び発生しているようですが、おそらく別の理由によるものと思われます。最初にこの問題に遭遇したのは、Ruby 3.0.2 から Ruby 3.1.0 にアップグレードしようとしたときで、すべてを新規インストールしても同じ問題が発生しました。また、Ruby 3.0.2 に戻してバンドル インストールを実行しようとすると、まったく同じエラーが発生しました。
また、古いバージョンの mini_racer を変更せずに使用してみました。 mini_racer や Bundler をデバッグする知識がありません。 mkmf.log ファイルには有益な情報は何もありませんでしたが、復号化する方法がわかりません。
Bundle install を実行すると、常に次のメッセージが表示されます。トラブルシューティングの手順で示されているファイルは、何が問題になっているのかを掘り下げるには、私の理解を超えた何層にもわたっています。これは、以前の mini_racer / Ruby バージョンで以前に報告されたエラーと同じですが、現在の解決策は見つかりませんでした。
Gem::Ext::BuildError: ERROR: Failed to build gem native extension.
current directory: /home/erik/.rvm/gems/ruby-3.1.0/gems/mini_racer-0.8.0/ext/mini_racer_extension
/home/erik/.rvm/rubies/ruby-3.1.0/bin/ruby -I /home/erik/.rvm/rubies/ruby-3.1.0/lib/ruby/3.1.0 -r ./siteconf20231202-16840-vjvf4h.rb extconf.rb
checking for -lpthread... yes
*** 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=/home/erik/.rvm/rubies/ruby-3.1.0/bin/$(RUBY_BASE_NAME)
--with-pthread-dir
--without-pthread-dir
--with-pthread-include
--without-pthread-include=${pthread-dir}/include
--with-pthread-lib
--without-pthread-lib=${pthread-dir}/lib
--with-pthreadlib
--without-pthreadlib
--enable-debug
--disable-debug
--enable-asan
--disable-asan
/home/erik/.rvm/rubies/ruby-3.1.0/lib/ruby/3.1.0/psych.rb:455:in `parse_stream': undefined method `parse' for #<Psych::Parser:0x00007f85c2b965c8
@handler=#<Psych::Handlers::DocumentStream:0x00007f85c2b96a78 @stack=[], @last=nil, @root=nil, @start_line=nil, @start_column=nil, @end_line=nil, @end_column=nil, @block=#<Proc:0x00007f85c2b96690
/home/erik/.rvm/rubies/ruby-3.1.0/lib/ruby/3.1.0/psych.rb:399>>, @external_encoding=0> (NoMethodError)
parser.parse yaml, filename
^^^^^^
from /home/erik/.rvm/rubies/ruby-3.1.0/lib/ruby/3.1.0/psych.rb:399:in `parse'
from /home/erik/.rvm/rubies/ruby-3.1.0/lib/ruby/3.1.0/psych.rb:272:in `unsafe_load'
from /home/erik/.rvm/gems/ruby-3.1.0/gems/libv8-node-18.16.0.0-x86_64-linux/ext/libv8-node/location.rb:21:in `block in load!'
from /home/erik/.rvm/gems/ruby-3.1.0/gems/libv8-node-18.16.0.0-x86_64-linux/ext/libv8-node/location.rb:20:in `open'
from /home/erik/.rvm/gems/ruby-3.1.0/gems/libv8-node-18.16.0.0-x86_64-linux/ext/libv8-node/location.rb:20:in `load!'
from /home/erik/.rvm/gems/ruby-3.1.0/gems/libv8-node-18.16.0.0-x86_64-linux/lib/libv8/node.rb:8:in `configure_makefile'
from extconf.rb:77:in `<main>'
To see why this extension failed to compile, please check the mkmf.log which can be found here:
/home/erik/.rvm/gems/ruby-3.1.0/extensions/x86_64-linux/3.1.0/mini_racer-0.8.0/mkmf.log
extconf failed, exit code 1
Gem files will remain installed in /home/erik/.rvm/gems/ruby-3.1.0/gems/mini_racer-0.8.0 for inspection.
Results logged to /home/erik/.rvm/gems/ruby-3.1.0/extensions/x86_64-linux/3.1.0/mini_racer-0.8.0/gem_make.out
/home/erik/.rvm/rubies/ruby-3.1.0/lib/ruby/3.1.0/rubygems/ext/builder.rb:95:in `run'
/home/erik/.rvm/rubies/ruby-3.1.0/lib/ruby/3.1.0/rubygems/ext/ext_conf_builder.rb:47:in `block in build'
/home/erik/.rvm/rubies/ruby-3.1.0/lib/ruby/3.1.0/tempfile.rb:317:in `open'
/home/erik/.rvm/rubies/ruby-3.1.0/lib/ruby/3.1.0/rubygems/ext/ext_conf_builder.rb:26:in `build'
/home/erik/.rvm/rubies/ruby-3.1.0/lib/ruby/3.1.0/rubygems/ext/builder.rb:161:in `build_extension'
/home/erik/.rvm/rubies/ruby-3.1.0/lib/ruby/3.1.0/rubygems/ext/builder.rb:195:in `block in build_extensions'
/home/erik/.rvm/rubies/ruby-3.1.0/lib/ruby/3.1.0/rubygems/ext/builder.rb:192:in `each'
/home/erik/.rvm/rubies/ruby-3.1.0/lib/ruby/3.1.0/rubygems/ext/builder.rb:192:in `build_extensions'
/home/erik/.rvm/rubies/ruby-3.1.0/lib/ruby/3.1.0/rubygems/installer.rb:847:in `build_extensions'
/home/erik/.rvm/gems/ruby-3.1.0/gems/bundler-2.4.22/lib/bundler/rubygems_gem_installer.rb:76:in `build_extensions'
/home/erik/.rvm/gems/ruby-3.1.0/gems/bundler-2.4.22/lib/bundler/rubygems_gem_installer.rb:28:in `install'
/home/erik/.rvm/gems/ruby-3.1.0/gems/bundler-2.4.22/lib/bundler/source/rubygems.rb:203:in `install'
/home/erik/.rvm/gems/ruby-3.1.0/gems/bundler-2.4.22/lib/bundler/installer/gem_installer.rb:54:in `install'
/home/erik/.rvm/gems/ruby-3.1.0/gems/bundler-2.4.22/lib/bundler/installer/gem_installer.rb:16:in `install_from_spec'
/home/erik/.rvm/gems/ruby-3.1.0/gems/bundler-2.4.22/lib/bundler/installer/parallel_installer.rb:130:in `do_install'
/home/erik/.rvm/gems/ruby-3.1.0/gems/bundler-2.4.22/lib/bundler/installer/parallel_installer.rb:121:in `block in worker_pool'
/home/erik/.rvm/gems/ruby-3.1.0/gems/bundler-2.4.22/lib/bundler/worker.rb:62:in `apply_func'
/home/erik/.rvm/gems/ruby-3.1.0/gems/bundler-2.4.22/lib/bundler/worker.rb:57:in `block in process_queue'
/home/erik/.rvm/gems/ruby-3.1.0/gems/bundler-2.4.22/lib/bundler/worker.rb:54:in `loop'
/home/erik/.rvm/gems/ruby-3.1.0/gems/bundler-2.4.22/lib/bundler/worker.rb:54:in `process_queue'
/home/erik/.rvm/gems/ruby-3.1.0/gems/bundler-2.4.22/lib/bundler/worker.rb:90:in `block (2 levels) in create_threads'
An error occurred while installing mini_racer (0.8.0), and Bundler cannot continue.
In Gemfile:
mini_racer
mkmf.log ファイルの内容:
have_library: checking for -lpthread... -------------------- yes
LD_LIBRARY_PATH=.:/home/erik/.rvm/rubies/ruby-3.1.0/lib "gcc -o conftest -I/home/erik/.rvm/rubies/ruby-3.1.0/include/ruby-3.1.0/x86_64-linux -I/home/erik/.rvm/rubies/ruby-3.1.0/include/ruby-3.1.0/ruby/backward -I/home/erik/.rvm/rubies/ruby-3.1.0/include/ruby-3.1.0 -I. -O3 -fno-fast-math -ggdb3 -Wall -Wextra -Wdeprecated-declarations -Wduplicated-cond -Wimplicit-function-declaration -Wimplicit-int -Wmisleading-indentation -Wpointer-arith -Wwrite-strings -Wold-style-definition -Wimplicit-fallthrough=0 -Wmissing-noreturn -Wno-cast-function-type -Wno-constant-logical-operand -Wno-long-long -Wno-missing-field-initializers -Wno-overlength-strings -Wno-packed-bitfield-compat -Wno-parentheses-equality -Wno-self-assign -Wno-tautological-compare -Wno-unused-parameter -Wno-unused-value -Wsuggest-attribute=format -Wsuggest-attribute=noreturn -Wunused-variable -Wundef -fPIC conftest.c -L. -L/home/erik/.rvm/rubies/ruby-3.1.0/lib -Wl,-rpath,/home/erik/.rvm/rubies/ruby-3.1.0/lib -L. -fstack-protector-strong -rdynamic -Wl,-export-dynamic -Wl,--no-as-needed -Wl,-rpath,'/../lib' -Wl,-rpath,'/../lib' -lruby -lm -lc"
checked program was:
/* begin */
1: #include "ruby.h"
2:
3: int main(int argc, char **argv)
4: {
5: return !!argv[argc];
6: }
/* end */
LD_LIBRARY_PATH=.:/home/erik/.rvm/rubies/ruby-3.1.0/lib "gcc -o conftest -I/home/erik/.rvm/rubies/ruby-3.1.0/include/ruby-3.1.0/x86_64-linux -I/home/erik/.rvm/rubies/ruby-3.1.0/include/ruby-3.1.0/ruby/backward -I/home/erik/.rvm/rubies/ruby-3.1.0/include/ruby-3.1.0 -I. -O3 -fno-fast-math -ggdb3 -Wall -Wextra -Wdeprecated-declarations -Wduplicated-cond -Wimplicit-function-declaration -Wimplicit-int -Wmisleading-indentation -Wpointer-arith -Wwrite-strings -Wold-style-definition -Wimplicit-fallthrough=0 -Wmissing-noreturn -Wno-cast-function-type -Wno-constant-logical-operand -Wno-long-long -Wno-missing-field-initializers -Wno-overlength-strings -Wno-packed-bitfield-compat -Wno-parentheses-equality -Wno-self-assign -Wno-tautological-compare -Wno-unused-parameter -Wno-unused-value -Wsuggest-attribute=format -Wsuggest-attribute=noreturn -Wunused-variable -Wundef -fPIC conftest.c -L. -L/home/erik/.rvm/rubies/ruby-3.1.0/lib -Wl,-rpath,/home/erik/.rvm/rubies/ruby-3.1.0/lib -L. -fstack-protector-strong -rdynamic -Wl,-export-dynamic -Wl,--no-as-needed -Wl,-rpath,'/../lib' -Wl,-rpath,'/../lib' -lruby -lpthread -lm -lc"
checked program was:
/* begin */
1: #include "ruby.h"
2:
3: /*top*/
4: extern int t(void);
5: int main(int argc, char **argv)
6: {
7: if (argc > 1000000) {
8: int (* volatile tp)(void)=(int (*)(void))&t;
9: printf("%d", (*tp)());
10: }
11:
12: return !!argv[argc];
13: }
14:
15: int t(void) { ; return 0; }
/* end */
--------------------
私はプロジェクトを Ruby 3.0.4 / Rails 6.1.4 から Ruby 3.1.3 / Rails 7.0.8 にアップグレードしようとしています。 以前 Ruby 3.0.4 / Rails 6.1.4 で正常に実行されていた既存のプロジェクトを再構築しました Rails を 7.0.8 にアップグレード - バンドルのインストールが正常に完了しました Ruby 3.1.3 に切り替えました - バンドルのインストールに失敗しました (成功すると予想されました) - 説明したエラーが発生しました Ruby 3.1.0 に切り替えました - バンドルのインストールに失敗しました (成功すると予想されました) - 説明したエラーが発生しました Ruby 3.0.4 に切り替えました - バンドルのインストールに失敗しました (成功すると予想されました) - 説明したエラーが発生しました
Ruby 3.1.0 を使用したクリーン インストール (Ubuntu 22.04.3) からプロジェクトを再構築しました - 説明のとおり、バンドルのインストールに失敗しました (成功すると予想されました) エラーが発生しました
解決策
mini_racer プロジェクトの Github issue 289 から Andy Allan を引用するには: