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

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

ただいまの
回答率

89.12%

Ruby on Rails 学習者のものです。

解決済

回答 2

投稿

  • 評価
  • クリップ 0
  • VIEW 1,219

y_aka

score 11

Mysqlがうまくインストールされません。

現在Ruby on Railsを勉強してるものです。
データベースを作成しようとすると下記エラーが出ています。

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

rails db:create

Could not find gem 'mysql2 (~> 0.5.2)' in any of the gem sources listed in your Gemfile.
Run `bundle install` to install missing gems

 試したこと

$ bundle install

エラー内容

Make sure that `gem install mysql2 -v '0.5.2' --source 'https://rubygems.org/'` succeeds before bundling.


https://rubygems.org/より mysql2 -v '0.5.2' をinstall

gem 'mysql2', '~> 0.5.2' をgemfileへ記述

ターミナルにて実行
gem install mysql2 -v 0.5.2

ERROR:  Error installing mysql2:
        ERROR: Failed to build gem native extension.

    current directory: /usr/local/rvm/gems/ruby-2.5.1/gems/mysql2-0.5.2/ext/mysql2
/usr/local/rvm/rubies/ruby-2.5.1/bin/ruby -r ./siteconf20180812-6596-f6wjc9.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/bin/mysql_config
-----
checking for mysql.h... no
checking for mysql/mysql.h... no
-----
mysql.h is missing. You may need to 'apt-get install libmysqlclient-dev' or 'yum install mysql-devel', 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
        --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=/usr/local/rvm/rubies/ruby-2.5.1/bin/$(RUBY_BASE_NAME)
        --with-mysql-dir
        --without-mysql-dir
        --with-mysql-include
        --without-mysql-include=${mysql-dir}/include
        --with-mysql-lib
        --without-mysql-lib=${mysql-dir}/lib
        --with-mysql-config
        --without-mysql-config

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

  /usr/local/rvm/gems/ruby-2.5.1/extensions/x86_64-linux/2.5.0/mysql2-0.5.2/mkmf.log

extconf failed, exit code 1

Gem files will remain installed in /usr/local/rvm/gems/ruby-2.5.1/gems/mysql2-0.5.2 for inspection.
Results logged to /usr/local/rvm/gems/ruby-2.5.1/extensions/x86_64-linux/2.5.0/mysql2-0.5.2/gem_make.out


yum install mysql-devel を実行

You need to be root to perform this command.

とでます。
今ままでの実行内容が良かったのかわからず
ここからどのようにしたらよいかわからなくなり躓いています。
ご教示いただきたくお願いいたします。

 補足情報(FW/ツールのバージョンなど)

windows 10 pro
IDE: cloud 9
ruby: 2.5.1p57
rails:  5.2.0
gem: 2.7.7

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

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

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

    クリップを取り消します

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

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

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

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

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

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

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

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

    質問の評価を下げる

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

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

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

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

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

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

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

    詳細な説明はこちら

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

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

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

質問への追記・修正、ベストアンサー選択の依頼

  • jun68ykt

    2018/08/12 11:29

    なるほどです。お手数ですが、こんどは「sudo yum install -y mysql-devel」 と、"install" と "mysql-devel" の間に "-y" を入れて、もう一度、mysql-devel のインストールを行い、その後、「bundle install」を実行してみてください。また次の投稿を参考にしてみてください。https://qiita.com/emahiro/items/1a63d676be9fc4975759 Railsでmysql2をインストールするときにハマったところ(emahiroさん@Qiita)

    キャンセル

  • y_aka

    2018/08/12 14:59 編集

    コメント遅くなりました。上記実行したらbundle installできましたがDBを作成すると違うエラーが出ました。
    rails aborted! NoMethodError: undefined method `halt_callback_chains_on_return_false=' for ActiveSupport:Module /home/ec2-user/environment/monolist/config/initializers/new_framework_defaults.rb:23:in `<top (required)>' /usr/local/rvm/gems/ruby-2.5.1/gems/activesupport-5.2.1/lib/active_support/dependencies.rb:281:in `load' /usr/local/rvm/gems/ruby-2.5.1/gems/activesupport-5.2.1/lib/active_support/dependencies.rb:281:in `block in load' /usr/local/rvm/gems/ruby-2.5.1/gems/activesupport-5.2.1/lib/active_support/dependencies.rb:253:in `load_dependency' /usr/local/rvm/gems/ruby-2.5.1/gems/activesupport-5.2.1/lib/active_support/dependencies.rb:281:in `load' /usr/local/rvm/gems/ruby-2.5.1/gems/railties-5.2.1/lib/rails/engine.rb:657:in `block in load_config_initializer' /usr/local/rvm/gems/ruby-2.5.1/gems/activesupport-5.2.1/lib/active_support/notifications.rb:170:in `instrument' /usr/local/rvm/gems/ruby-2.5.1/gems/railties-5.2.1/lib/rails/engine.rb:656:in `load_config_initializer' /usr/local/rvm/gems/ruby-2.5.1/gems/railties-5.2.1/lib/rails/engine.rb:614:in `block (2 levels) in <class:Engine>' /usr/local/rvm/gems/ruby-2.5.1/gems/railties-5.2.1/lib/rails/engine.rb:613:in `each' /usr/local/rvm/gems/ruby-2.5.1/gems/railties-5.2.1/lib/rails/engine.rb:613:in `block in <class:Engine>' /usr/local/rvm/gems/ruby-2.5.1/gems/railties-5.2.1/lib/rails/initializable.rb:32:in `instance_exec' /usr/local/rvm/gems/ruby-2.5.1/gems/railties-5.2.1/lib/rails/initializable.rb:32:in `run' /usr/local/rvm/gems/ruby-2.5.1/gems/railties-5.2.1/lib/rails/initializable.rb:61:in `block in run_initializers' /usr/local/rvm/gems/ruby-2.5.1/gems/railties-5.2.1/lib/rails/initializable.rb:50:in `each' /usr/local/rvm/gems/ruby-2.5.1/gems/railties-5.2.1/lib/rails/initializable.rb:50:in `tsort_each_child' /usr/local/rvm/gems/ruby-2.5.1/gems/railties-5.2.1/lib/rails/initializable.rb:60:in `run_initializers' /usr/local/rvm/gems/ruby-2.5.1/gems/railties-5.2.1/lib/rails/application.rb:361:in `initialize!' /home/ec2-user/environment/monolist/config/environment.rb:5:in `<top (required)>' /usr/local/rvm/gems/ruby-2.5.1/gems/railties-5.2.1/lib/rails/application.rb:337:in `require' /usr/local/rvm/gems/ruby-2.5.1/gems/railties-5.2.1/lib/rails/application.rb:337:in `require_environment!' /usr/local/rvm/gems/ruby-2.5.1/gems/railties-5.2.1/lib/rails/application.rb:520:in `block in run_tasks_blocks' /usr/local/rvm/gems/ruby-2.5.1/gems/railties-5.2.1/lib/rails/commands/rake/rake_command.rb:23:in `block in perform' /usr/local/rvm/gems/ruby-2.5.1/gems/railties-5.2.1/lib/rails/commands/rake/rake_command.rb:20:in `perform' /usr/local/rvm/gems/ruby-2.5.1/gems/railties-5.2.1/lib/rails/command.rb:48:in `invoke' /usr/local/rvm/gems/ruby-2.5.1/gems/railties-5.2.1/lib/rails/commands.rb:18:in `<top (required)>' bin/rails:4:in `require' bin/rails:4:in `<main>' Tasks: TOP => db:create => db:load_config => environment (See full trace by running task with --trace)

    キャンセル

  • jun68ykt

    2018/08/12 15:28

    前に進みましたね!新たなエラーの対策を回答のほうに書きました。

    キャンセル

回答 2

checkベストアンサー

+1

こんにちは。
質問への追記・修正欄からの続きになります。

rails aborted! NoMethodError: undefined method
'halt_callback_chains_on_return_false=' for ActiveSupport:Module

のエラー対策ですが、自分も同じようなエラーが出たことがあったので、記憶と検索からの情報をたよりに、「こうすれば解決するかもしれません」という情報をお伝えします。

以下のファイル

config/initializers/new_framework_defaults.rb

を開いて、

ActiveSupport.halt_callback_chains_on_return_false

で始まる行を探し、その行全体をコメントアウトして保存してから、エラーが起きてしまったコマンドを再度実行してみてください。
(コメントアウトするには行の先頭に # を追加します。)

また、このようなエラーが起こった場合、エラーメッセージの

undefined method 'halt_callback_chains_on_return_false=' for ActiveSupport:Module

を丸っとコピペしてGoogle検索してみてください。
同じようなエラーで困った人がどうやって解決したかの情報が出てきます。

teratail でも同じ問題にぶつかって質問された方がいらっしゃいました。

undefined method `halt_callback_chains_on_return_false=' for ActiveSupport:Module (NoMethodError)の解決  (jiyo-taさん@teratail)

以上参考になれば幸いです。

投稿

編集

  • 回答の評価を上げる

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

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

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

  • 回答の評価を下げる

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

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

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

  • 2018/08/12 18:32

    上記で解決することができました
    簡単なエラーに対応していただきありがとうございます。
    自分の力で解決できるよう努力していきますありがとうございました。

    キャンセル

  • 2018/08/12 19:40

    解決されたとのことで、よかったです!

    キャンセル

+1

まず、ログを良く読みましょう。

mysql.h is missing. You may need to 'apt-get install libmysqlclient-dev' or 'yum install mysql-devel', and try again.


mysqlがインストールされていないと言っています。

RailsのgemはDBサーバーへの接続するgemをインストールしています。

よって、DBそのものがインストールされていない場合、当然接続できません。

AWSでしたら、CentOS系ですので

yum install mysql-devel


を実行してまず、mysqlのインストールからですね。
あとはユーザー作って、権限与えて、DBを作っていくという手順になります。
Railsの方では
config>database.yml
ファイルに設定を記載していきます。
mysqlのインストールを調査したらよいかと思います。

投稿

  • 回答の評価を上げる

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

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

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

  • 回答の評価を下げる

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

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

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

  • 2018/08/12 23:05

    上記エラー解決いたしました。
    ログを今一度よく読んでみる癖をつけていきたいと思います。

    キャンセル

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

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

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