質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.48%
Ruby

Rubyはプログラミング言語のひとつで、オープンソース、オブジェクト指向のプログラミング開発に対応しています。

MySQL

MySQL(マイエスキューエル)は、TCX DataKonsultAB社などが開発するRDBMS(リレーショナルデータベースの管理システム)です。世界で最も人気の高いシステムで、オープンソースで開発されています。MySQLデータベースサーバは、高速性と信頼性があり、Linux、UNIX、Windowsなどの複数のプラットフォームで動作することができます。

Ruby on Rails

Ruby on Railsは、オープンソースのWebアプリケーションフレームワークです。「同じことを繰り返さない」というRailsの基本理念のもと、他のフレームワークより少ないコードで簡単に開発できるよう設計されています。

Q&A

解決済

1回答

3734閲覧

bundleインストールでmysqlが通らない現象

退会済みユーザー

退会済みユーザー

総合スコア0

Ruby

Rubyはプログラミング言語のひとつで、オープンソース、オブジェクト指向のプログラミング開発に対応しています。

MySQL

MySQL(マイエスキューエル)は、TCX DataKonsultAB社などが開発するRDBMS(リレーショナルデータベースの管理システム)です。世界で最も人気の高いシステムで、オープンソースで開発されています。MySQLデータベースサーバは、高速性と信頼性があり、Linux、UNIX、Windowsなどの複数のプラットフォームで動作することができます。

Ruby on Rails

Ruby on Railsは、オープンソースのWebアプリケーションフレームワークです。「同じことを繰り返さない」というRailsの基本理念のもと、他のフレームワークより少ないコードで簡単に開発できるよう設計されています。

0グッド

0クリップ

投稿2018/11/27 02:53

編集2018/11/27 03:24

以下の環境で開発をしておりました。

rails5 ruby5 mysql

rbenvのgemsetを新しく作り直したらbundleが通らなくなってしまいました。
原因としてはmysql2が通らないとのこと。

発生してるエラー

$ bundle etching mysql2 0.4.10 Installing mysql2 0.4.10 with native extensions Errno::EACCES: Permission denied @ rb_sysopen - /Users/user_name/app_name/vendor/bundle/ruby/2.5.0/gems/mysql2-0.4.10/CHANGELOG.md An error occurred while installing mysql2 (0.4.10), and Bundler cannot continue. Make sure that `gem install mysql2 -v '0.4.10' --source 'https://rubygems.org/'` succeeds before bundling. In Gemfile: mysql2

gem install mysql2 -v '0.4.10' --source 'https://rubygems.org/' Building native extensions. This could take a while... ERROR: Error installing mysql2: ERROR: Failed to build gem native extension. current directory: /Users/user_name/.rbenv/versions/2.5.0/gemsets/2.5.0/gems/mysql2-0.4.10/ext/mysql2 /Users/user_name/.rbenv/versions/2.5.0/bin/ruby -r ./siteconf20181127-32843-1vyjcho.rb extconf.rb checking for rb_absint_size()... yes checking for rb_absint_singlebit_p()... yes checking for ruby/thread.h... yes checking for rb_thread_call_without_gvl() in ruby/thread.h... yes checking for rb_thread_blocking_region()... no checking for rb_wait_for_single_fd()... yes checking for rb_hash_dup()... yes checking for rb_intern3()... yes checking for rb_big_cmp()... 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 ----- 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.12/lib ----- creating Makefile current directory: /Users/user_name/.rbenv/versions/2.5.0/gemsets/2.5.0/gems/mysql2-0.4.10/ext/mysql2 make "DESTDIR=" clean current directory: /Users/user_name/.rbenv/versions/2.5.0/gemsets/2.5.0/gems/mysql2-0.4.10/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/user_name/.rbenv/versions/2.5.0/gemsets/2.5.0/gems/mysql2-0.4.10 for inspection. Results logged to /Users/user_name/.rbenv/versions/2.5.0/gemsets/2.5.0/extensions/x86_64-darwin-18/2.5.0-static/mysql2-0.4.10/gem_make.out

mysql2のバージョンとかの問題だと思っているのですが、なかなか解決に繋がっておりません。
どなたかアドバイスいただけますと幸いです。

追記

ご指摘をいただきopensslの再インストールを行い改めてbundle install

Gem::Ext::BuildError: ERROR: Failed to build gem native extension. current directory: /Users/user_name/app_anem/vendor/bundle/ruby/2.5.0/gems/mysql2-0.4.10/ext/mysql2 /Users/user_name/.rbenv/versions/2.5.0/bin/ruby -r ./siteconf20181127-41841-k7bxey.rb extconf.rb --with-ldflags=-L/usr/local/opt/openssl/lib --with-cppflags=-I/usr/local/opt/openssl/include checking for rb_absint_size()... yes checking for rb_absint_singlebit_p()... yes checking for ruby/thread.h... yes checking for rb_thread_call_without_gvl() in ruby/thread.h... yes checking for rb_thread_blocking_region()... no checking for rb_wait_for_single_fd()... yes checking for rb_hash_dup()... yes checking for rb_intern3()... yes checking for rb_big_cmp()... 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 ----- Setting rpath to /usr/local/Cellar/mysql/8.0.12/lib ----- creating Makefile current directory: /Users/user_name/app_name/vendor/bundle/ruby/2.5.0/gems/mysql2-0.4.10/ext/mysql2 make "DESTDIR=" clean current directory: /Users/user_name/app_name/vendor/bundle/ruby/2.5.0/gems/mysql2-0.4.10/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 current directory: /Users/user_name/app_name/vendor/bundle/ruby/2.5.0/gems/mysql2-0.4.10/ext/mysql2 make "DESTDIR=" install make: /usr/local/bin/gmkdir: No such file or directory make: *** [.sitearchdir.-.mysql2.time] Error 1 make install failed, exit code 2 Gem files will remain installed in /Users/user_name/app_name/vendor/bundle/ruby/2.5.0/gems/mysql2-0.4.10 for inspection. Results logged to /Users/user_name/app_name/vendor/bundle/ruby/2.5.0/extensions/x86_64-darwin-18/2.5.0-static/mysql2-0.4.10/gem_make.out An error occurred while installing mysql2 (0.4.10), and Bundler cannot continue. Make sure that `gem install mysql2 -v '0.4.10' --source 'https://rubygems.org/'` succeeds before bundling.

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答1

0

ベストアンサー

bundle に失敗する原因

Errno::EACCES: Permission denied @ rb_sysopen - /Users/user_name/app_name/vendor/bundle/ruby/2.5.0/gems/mysql2-0.4.10/CHANGELOG.md

パーミッション違反なので、上記パスに一般ユーザで開けるか所有ユーザを確認してください。

gem installに失敗する原因

ld: library not found for -lssl

opensslの開発パッケージがインストールされていません。
yumなりaptなりでインストール後、再度インストールを試みてください。


gmkdir

make: /usr/local/bin/gmkdir: No such file or directory

gmkdirはcoreutilsに含まれているようです。
brew install coreutilsで先に進むと思います。

投稿2018/11/27 03:03

編集2018/11/27 04:35
kazto

総合スコア7196

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

退会済みユーザー

退会済みユーザー

2018/11/27 03:15

コメントありがとうございます! $ brew install openssl 上記の取得方法で問題ないでしょうか?
退会済みユーザー

退会済みユーザー

2018/11/27 03:18

$ brew install openssl ↓ $ brew reinstall openssl(インストール完了) ↓ $ sudo bundle install またmysql2のエラーになります。。
kazto

2018/11/27 03:22

Macですか。そうですね、大丈夫です。
kazto

2018/11/27 03:23

bundleに失敗するのは、opensslは無関係です。
kazto

2018/11/27 03:25

$ sudo chown -R user_name /Users/user_name/app_name でユーザでのアクセス権を与えてみてはいかがでしょうか。
退会済みユーザー

退会済みユーザー

2018/11/27 04:08

アクセス権の変更まではできたのですが、まだbundleが通らないですね、、、 ご丁寧にありがとございます、、
kazto

2018/11/27 04:36

ちょっと先へ進みましたね。 内容追記しました。
退会済みユーザー

退会済みユーザー

2018/11/27 05:47

ありがとうございます!おかげでbundleが通りました! エラーログをもっと細かく読み進めて行くことを心がけます!
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.48%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問