WEBサービス創造記

WEBサービスを作ったり保守したりしてる人のメモブログです。

Mac OS X Lion 10.7.5 で MySQLをアップデートした後に`gem install mysql2`が失敗してしまう場合の対処法

      2015/05/20

経緯

もともとMacPortsを使っていたが、HomeBrewに乗り換え、MySQLのバージョンを5.1から5.6にアップデートした。
乗り換え自体は下記のページを参考にしてMacPortsで使用していたパッケージをすべて削除してからHomebrewをインストールするという段取りにした。

パッケージ環境の移行-MacPorts のアンインストールと Homebrew のインストール – TMD45INC!!!

MySQLをアップデートすると、native extensionの依存ライブラリが変わるためmysql2というGemを再インストールしなければならないとのことなので、以下を実行した。

$ gem uninstall mysql2
$ gem install mysql2                                                                                                                                                     (git)-[master]
Building native extensions.  This could take a while...
ERROR:  Error installing mysql2:
        ERROR: Failed to build gem native extension.

    /Users/okishima/.rvm/rubies/ruby-2.0.0-p195/bin/ruby extconf.rb
checking for rb_thread_blocking_region()... yes
checking for rb_wait_for_single_fd()... yes
checking for mysql.h... no
checking for mysql/mysql.h... no
-----
mysql.h is missing.  please check your installation of mysql and try again.
-----
*** 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
        --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=/Users/okishima/.rvm/rubies/ruby-2.0.0-p195/bin/ruby
        --with-mysql-config
        --without-mysql-config


Gem files will remain installed in /Users/okishima/.rvm/gems/ruby-2.0.0-p195@wiking/gems/mysql2-0.3.11 for inspection.
Results logged to /Users/okishima/.rvm/gems/ruby-2.0.0-p195@wiking/gems/mysql2-0.3.11/ext/mysql2/gem_make.out

しかし、上記のようにインストールに失敗する。

対処法

“mysql.h is missing. please check your installation of mysql and try again.”とあるので、このエラーメッセージで検索するとMac OS Xでbrewなら`brew install mysql`、Deb系のLinuxディストーションなら`sudo apt-get install mysql-devel`を実行した後`gem install mysql2`を実行するとなおるという記事が多かったが、解決できなかった。

以下のページに、RailsのインストールにHomeBrewとRVMを利用しているならmysql_configを編集して解決できるかもという情報を発見した。
mysql.h is missing …. (Ruby on Rails, OSX) – Stack Overflow

これを実践した後、`gem install mysql2`を実行したらインストールが成功した。

$ sudo vim /usr/local/Cellar/mysql/5.6.12/bin/mysql_config
#cflags="-I$pkgincludedir  -Wall -Wno-null-conversion -Wno-unused-private-field -Os -g -fno-strict-aliasing -DDBUG_OFF " #note: end space! 
#cxxflags="-I$pkgincludedir  -Wall -Wno-null-conversion -Wno-unused-private-field -Os -g -fno-strict-aliasing -DDBUG_OFF " #note: end space! 
cflags = "-I$pkgincludedir  -Wall -Os -g -fno-strict-aliasing -DDBUG_OFF "
cxxflags = "-I$pkgincludedir  -Wall -Os -g -fno-strict-aliasing -DDBUG_OFF "

 - Ruby , ,