【Rails】bundle installのmysql2で上手くいかない

bundle installのmysql2インストールで上手くいかなかった時の対象方法についてです。
業務でrailsが必要になったので、簡単なrailsアプリ(DBはmysql)で作ってみることにしたのですが、なかなか解消せずに苦労しました…。

出てきたエラーメッセージは以下の通り。

current directory: /Users/username/Implementation/railsApp/TestApp/vendor/bundle/ruby/2.3.0/gems/mysql2-0.5.2/ext/mysql2
/System/Library/Frameworks/Ruby.framework/Versions/2.3/usr/bin/ruby -r ./siteconf20190707-80484-8i4xav.rb extconf.rb
checking for rb_absint_size()... yes
checking for rb_absint_singlebit_p()... yes
checking for rb_wait_for_single_fd()... yes
-----
Using mysql_config at /usr/local/bin/mysql_config
-----
checking for mysql.h... yes
checking for errmsg.h... yes
checking for SSL_MODE_DISABLED in mysql.h... yes
checking for SSL_MODE_PREFERRED in mysql.h... yes
checking for SSL_MODE_REQUIRED in mysql.h... yes
checking for SSL_MODE_VERIFY_CA in mysql.h... yes
checking for SSL_MODE_VERIFY_IDENTITY in mysql.h... yes
checking for MYSQL.net.vio in mysql.h... yes
checking for MYSQL.net.pvio in mysql.h... no
checking for MYSQL_ENABLE_CLEARTEXT_PLUGIN in mysql.h... yes
checking for SERVER_QUERY_NO_GOOD_INDEX_USED in mysql.h... yes
checking for SERVER_QUERY_NO_INDEX_USED in mysql.h... yes
checking for SERVER_QUERY_WAS_SLOW in mysql.h... yes
checking for MYSQL_OPTION_MULTI_STATEMENTS_ON in mysql.h... yes
checking for MYSQL_OPTION_MULTI_STATEMENTS_OFF in mysql.h... yes
checking for my_bool in mysql.h... no
-----
Don't know how to set rpath on your system, if MySQL libraries are not in path mysql2 may not load
-----
-----
Setting libpath to /usr/local/Cellar/mysql/8.0.16/lib
-----
creating Makefile

To see why this extension failed to compile, please check the mkmf.log which can be found here:

  /Users/username/Implementation/railsApp/TestApp/vendor/bundle/ruby/2.3.0/extensions/universal-darwin-18/2.3.0/mysql2-0.5.2/mkmf.log

current directory: /Users/username/Implementation/railsApp/TestApp/vendor/bundle/ruby/2.3.0/gems/mysql2-0.5.2/ext/mysql2
make "DESTDIR=" clean

current directory: /Users/username/Implementation/railsApp/TestApp/vendor/bundle/ruby/2.3.0/gems/mysql2-0.5.2/ext/mysql2
make "DESTDIR="
compiling client.c
compiling infile.c
compiling mysql2_ext.c
compiling result.c
compiling statement.c
linking shared-object mysql2/mysql2.bundle
ld: library not found for -lssl
clang: error: linker command failed with exit code 1 (use -v to see invocation)
make: *** [mysql2.bundle] Error 1

make failed, exit code 2

Gem files will remain installed in /Users/username/Implementation/railsApp/TestApp/vendor/bundle/ruby/2.3.0/gems/mysql2-0.5.2 for inspection.
Results logged to /Users/username/Implementation/railsApp/TestApp/vendor/bundle/ruby/2.3.0/extensions/universal-darwin-18/2.3.0/mysql2-0.5.2/gem_make.out

An error occurred while installing mysql2 (0.5.2), and Bundler cannot continue.
Make sure that `gem install mysql2 -v '0.5.2' --source 'https://rubygems.org/'` succeeds before bundling.

エラーメッセージ最後の方に出ているコマンドを実行しても失敗。

gem install mysql2 -v '0.5.2' --source 'https://rubygems.org/'

結果、下記のQiitaの記事と同様の現象だったようで、下記のコマンドを実行してからbundle installをしたら通りました。
※解消方法のみ記載しますので、詳細を知りたい方は下記をご参照ください。
https://qiita.com/fukudakumi/items/463a39406ce713396403

bundle config --local build.mysql2 "--with cppflags=-L/usr/local/opt/openssl/lib"
bundle config --local build.mysql2 "--with-ldflags=-I/usr/local/opt/openssl/include"
bundle install

もし上記で上手くいかない場合は、「brew info openssl」とコマンドを実行し、
「export LDFLAGS」に記載されたパスを「–with-cppflags」に、
「export CPPFLAGS」に記載されたパスを「–with-ldflags」に、
それぞれ設定して実施してみてください。

ここまで読んでいただきありがとうございました。
コメントはご自由にどうぞ!

あわせて読みたい

コメントを残す

メールアドレスが公開されることはありません。