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

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

ただいまの
回答率

88.19%

Ruby onRailsで rails db:create実行時のLoadError

解決済

回答 2

投稿

  • 評価
  • クリップ 0
  • VIEW 282

_dana

score 13

Ruby onRailsで rails db:create実行時のLoadError

Railsでデータベースを用いるwebサービスの開発をしています。
rails db:createを実行するとエラーが起きます。
それまでは問題なく行えていたので、全く原因もわかりません。

発生している問題・エラーメッセージ

LoadError: dlopen(/Users/User名/.rbenv/versions/2.5.1/lib/ruby/gems/2.5.0/gems/mysql2-0.5.3/lib/mysql2/mysql2.bundle, 9): Libr
ary not loaded: /usr/local/opt/mysql@5.6/lib/libmysqlclient.18.dylib
Referenced from: /Users/User名/.rbenv/versions/2.5.1/lib/ruby/gems/2.5.0/gems/mysql2-0.5.3/lib/mysql2/mysql2.bundle
Reason: image not found - /User名/.rbenv/versions/2.5.1/lib/ruby/gems/2.5.0/gems/mysql2-0.5.3/lib/mysql2/mysql2.bundle
/Users/User名/Projects/App名/config/application.rb:7:in <top (required)>'
/Users/User名/Projects/App名/Rakefile:4:in<top (required)>'
/Users/User名/Projects/App名/bin/rails:9:in <top (required)>'
/Users/User名/Projects/App名/bin/spring:15:in<top (required)>'
bin/rails:3:in load'
bin/rails:3:in<main>'

該当のソースコード

rails db:create

試したこと

まず調べたところ、sqlの再インストールが必要なのかと思い、アンイストール後再インストールしましたが変化はありませんでした。
database.ymlファイルにおいてパスワードが設定されていなかったり、権限がなかったりという可能性もあると知り、試してみましたが同じでした。
ネットで調べてみるとreadlineがインストールされていないことが原因jかもしれないと思いましたが、エラー文にその旨の記述はありませんでした。
とりあえず以下の方法でreadlineをインストールしてみました。
gemファイルのgroup :development内にgem 'rb-readline'を追記
そのままrails db:createを実行
rb-readlineが見つからないとのエラーが出たので
bundle installを実行
rails db:createを実行
としましたが、同じエラーが出ました。
エラー文を読んでみて、mysqlが見つからないということなのかなと思いましたが、それ以降目ぼしい解決策が見つかっていません。

補足情報

PcはMacで
rails 5.2.4.2
mysql  Ver 14.14 Distrib 5.7.29, for osx10.15 (x86_64) using  EditLine wrapper
という環境です。
以下にgemfileの一部を記述します

ruby '2.5.1'

# Bundle edge Rails instead: gem 'rails', github: 'rails/rails'
gem 'rails', '~> 5.2.3'
# Use mysql as the database for Active Record
gem 'mysql2', '>= 0.4.4', '< 0.6.0'

group :development do
  # Access an interactive console on exception pages or by calling 'console' anywhere in the code.
  gem 'web-console', '>= 3.3.0'
  gem 'listen', '>= 3.0.5', '< 3.2'
  # Spring speeds up development by keeping your application running in the background. Read more: https://github.com/rails/spring
  gem 'spring'
  gem 'spring-watcher-listen', '~> 2.0.0'
  gem 'rb-readline'
end
  • 気になる質問をクリップする

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

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

    クリップを取り消します

  • 良い質問の評価を上げる

    以下のような質問は評価を上げましょう

    • 質問内容が明確
    • 自分も答えを知りたい
    • 質問者以外のユーザにも役立つ

    評価が高い質問は、TOPページの「注目」タブのフィードに表示されやすくなります。

    質問の評価を上げたことを取り消します

  • 評価を下げられる数の上限に達しました

    評価を下げることができません

    • 1日5回まで評価を下げられます
    • 1日に1ユーザに対して2回まで評価を下げられます

    質問の評価を下げる

    teratailでは下記のような質問を「具体的に困っていることがない質問」、「サイトポリシーに違反する質問」と定義し、推奨していません。

    • プログラミングに関係のない質問
    • やってほしいことだけを記載した丸投げの質問
    • 問題・課題が含まれていない質問
    • 意図的に内容が抹消された質問
    • 過去に投稿した質問と同じ内容の質問
    • 広告と受け取られるような投稿

    評価が下がると、TOPページの「アクティブ」「注目」タブのフィードに表示されにくくなります。

    質問の評価を下げたことを取り消します

    この機能は開放されていません

    評価を下げる条件を満たしてません

    評価を下げる理由を選択してください

    詳細な説明はこちら

    上記に当てはまらず、質問内容が明確になっていない質問には「情報の追加・修正依頼」機能からコメントをしてください。

    質問の評価を下げる機能の利用条件

    この機能を利用するためには、以下の事項を行う必要があります。

回答 2

check解決した方法

0

mysqlのバージョンが5.7になっていたのが原因のようでしたので、5.6にダウングレードしたところ解決しました。

投稿

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

0

/usr/local/opt/mysql@5.6/lib/libmysqlclient.18.dylib
が無いというエラーがでています。
まず、このファイルの存在有無をチェックしてきてください。
次に mysql が動作しているかのチェック, mysll の reinstal, bundle install のし直し、
マシンの rebootl などを試してみてください。
それでもだめなら、再度、エラーメッセージを見て原因を理解し、それを解決するような処理を試してみてください。

投稿

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

  • 2020/04/27 00:03

    ご回答ありがとうございます。
    ご指定のファイルを探しましたが存在しないようです。
    ls -a -lを利用してusr => local => optまで入り、mysql@5.6の存在は確認できましたが、それ以降が見つからなかったです。
    mysqlサーバーは起動しているようです。
    gem updateでアップデートを行い、再度db:createを実行したところ、上記のエラー文の上に、
    末尾が〇〇 was hereとなっている記述が何行か出るようになりました
    PCの再起動もしてみましたが変わりませんでした。

    キャンセル

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

  • ただいまの回答率 88.19%
  • 質問をまとめることで、思考を整理して素早く解決
  • テンプレート機能で、簡単に質問をまとめられる

関連した質問

同じタグがついた質問を見る