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

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

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

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

MySQL

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

AWS(Amazon Web Services)

Amazon Web Services (AWS)は、仮想空間を機軸とした、クラスター状のコンピュータ・ネットワーク・データベース・ストーレッジ・サポートツールをAWSというインフラから提供する商用サービスです。

Q&A

0回答

952閲覧

AWS My sql エラーについて

ken1203

総合スコア24

Ruby on Rails 6

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

MySQL

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

AWS(Amazon Web Services)

Amazon Web Services (AWS)は、仮想空間を機軸とした、クラスター状のコンピュータ・ネットワーク・データベース・ストーレッジ・サポートツールをAWSというインフラから提供する商用サービスです。

0グッド

0クリップ

投稿2020/11/30 05:34

編集2020/12/01 11:50

前提・実現したいこと

前提
Ruby on Rails6にてアプリを作成
aws amazon amazon linux2にてデプロイ作業中
実現したいこと
本番環境でrailsを起動させたい

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

ターミナル [ec2-user@ip-172-31-41-71 Dr_nishi]$ less log/unicorn.stderr.log I, [2020-11-28T04:27:13.668451 #27673] INFO -- : Refreshing Gem list I, [2020-11-28T04:27:15.839359 #27673] INFO -- : listening on addr=0.0.0.0:3000 fd=11 E, [2020-11-28T04:27:15.905289 #27673] ERROR -- : Access denied for user 'root'@'localhost' (using password: YES) (Mysql2::Error)

該当するソースコード

database.yml # SQLite. Versions 3.8.0 and up are supported. # gem install sqlite3 # # Ensure the SQLite 3 gem is defined in your Gemfile # gem 'sqlite3' default: &default adapter: mysql2 encoding: utf8 pool: <%= ENV.fetch("RAILS_MAX_THREADS") { 5 } %> username: root password: kenichi1203 socket: /tmp/mysql.sock development: <<: *default database: Dr_nishi_development test: <<: *default database: Dr_nishi_test production: <<: *default database: Dr_nishi_production username: root password: Kenichi@1203 socket: /var/lib/mysql/mysql.sock
ローカル環境 my sql *******@********noMacBook-Pro Dr_nishi % mysql -u root -p Enter password: Welcome to the MySQL monitor. Commands end with ; or \g. Your MySQL connection id is 5 Server version: 5.6.50 Homebrew Copyright (c) 2000, 2020, Oracle and/or its affiliates. All rights reserved. Oracle is a registered trademark of Oracle Corporation and/or its affiliates. Other names may be trademarks of their respective owners. Type 'help;' or '\h' for help. Type '\c' to clear the current input statement. mysql>
本番環境 my sql [ec2-user@*********** Dr_nishi]$ mysql -u root -p Enter password: Welcome to the MySQL monitor. Commands end with ; or \g. Your MySQL connection id is 10 Server version: 5.7.32 MySQL Community Server (GPL) Copyright (c) 2000, 2020, Oracle and/or its affiliates. All rights reserved. Oracle is a registered trademark of Oracle Corporation and/or its affiliates. Other names may be trademarks of their respective owners. Type 'help;' or '\h' for help. Type '\c' to clear the current input statement. mysql>

試したこと(仮説)

ERROR -- : Access denied for user 'root'@'localhost' (using password: YES) (Mysql2::Error)

エラー内容で検索をしました。

.my sql のパスワードを変更
.database.yml の記述を変更

試しましたが変化はありませんでした。

補足

初心者で言葉足らずで申し訳ありませんがご教示頂けたらと思い質問させて頂きました。
宜しくお願い致します。

補足2

database.yml default: #&default adapter: mysql2 encoding: utf8 pool: <%= ENV.fetch("RAILS_MAX_THREADS") { 5 } %> username: root password: kenichi1203 socket: /tmp/mysql.sock development: #<<: *default database: Dr_nishi_development test: #<<: *default database: Dr_nishi_test production: #<<: *default database: Dr_nishi_production username: root password: Kenichi@1203 socket: /var/lib/mysql/mysql.sock

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

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

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

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

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

maisumakun

2020/11/30 05:37

本番環境でのMySQLはどのように実行していますか?
ken1203

2020/11/30 05:51

maisumakun様 ご返信ありがとうございます! >本番環境でのMySQLはどのように実行していますか? 上記のソースコードに書いてある通りに実行したのですが、また別の方法が あるのでしょうか?? 無知で申し訳ありません。
maisumakun

2020/11/30 06:17

パスワードは合っていますか?
ken1203

2020/11/30 06:40

maisumakun様 ご返信ありがとうございます! はい。パスワードは通っています。 database.ymlにも同じパスワードを記載しました。
yu_1985

2020/11/30 06:44

defaultにusername、password、socketが記述してある上で、productionでもusername、password、socketが記載してあるので、デプロイ時にどちらの情報が読み取られているのかが怪しいですね。 一応capistranoでどのようにデプロイ設定しているのかについても記載してください。
ken1203

2020/12/01 09:48

yu_1985様 ご返信ありがとございます! capistranoを導入せずにデプロイを行っていました。 capistranoは導入した方がよろしいでしょうか??
yu_1985

2020/12/01 10:30

いえ、capistranoを使ってるものだと思いこんでました。別に必須ではないので使ってないなら特になにもないです。 username,password,socketをdefaultに書くのをやめて、それぞれの環境ごとに書くようにしたら変わりますか?
ken1203

2020/12/01 11:16

yu_1985様 ご返信ありがとうございます! 一応、capistrano導入を試みたのですがSSHKit::Runner::ExecuteError) というエラーになってしまいました。 >username,password,socketをdefaultに書くのをやめて、それぞれの環境ごとに書くようにしたら変わりますか? 申し訳ありませんが初心者で「それぞぞれの環境ごとに書く」ことが少し理解出来ずです、、、。 database.ymlに記述したら宜しいでしょうか??
yu_1985

2020/12/01 11:22

いえ、だからCapistranoを使っていないのなら特に関係ないと言ったつもりなのですが…。 それは別の問題なので一旦ここでは無視してください。 問題の原因がはっきりしないうちに別のことをやろうとすると往々にして余計に問題が複雑化するので、切り分けができないうちは問題と関係ないところをいじるのはやめましょう。 >username,password,socketをdefaultに書くのをやめて、それぞれの環境ごとに書く 今はdatabase.yml内のdefaultのところにusername,password,socketを記載しているのはわかりますか? development,test,productionはいずれも ``` <<: *default ``` として、defaultに付け加えて各環境ごとの個別の設定を入れるようにしています。 なので、この状態でdefaultのところでそれらを定義してしまうと、各環境ごとで接続先を変えたい時に設定がバッティングして困るのではないか、という話です。 ただ、実際の挙動がわからないのでそのように書き方を変えてみたら変わりますか、というのを確認してほしいということです。 この辺はyamlの記法なので例えばこの辺の記事を参考にしてください。 https://qiita.com/terufumi1122/items/b5678bae891ba9cf1e57
ken1203

2020/12/01 11:47 編集

yu_1985様 ご返信ありがとうございます! はい。一旦、Capistranoは無視します! >今はdatabase.yml内のdefaultのところにusername,password,socketを記載しているのはわかりますか? はい!わかります! <<: *default なるほど!そういう意味だったのですね! 一旦defaultに書くのをやめて実行してみます!! yamlのリンクも貼付して頂きありがとうございます! とても勉強になります!! 詳しくご説明頂きありがとうございます! 補足に追加しましたので確認して頂けますでしょうか??
yu_1985

2020/12/01 12:01 編集

*defaultをコメントアウトするんじゃないです。 defaultの下にusername,password,socketを記載するのをやめて、 各環境ごとにusername,password,socketを記述するようにしてください。 環境ごとに切り替えたいんですよね? そうでないと、なんのためにdefaultの記述が存在するのかわかりません。 defaultに記述するのは各環境で共通の設定でしょう。なので、環境ごとに切り替えたい情報についてはdefaultの下に書いてはいけません。 もしdefaultを記載しないのであれば、各環境に必要な情報をすべて記述する必要がありますが、現状だとproductionに記述しているのはdatabase,username,password,socketのみになってしまいます。(その他2環境についてはdatabaseしか記載がないことになります) 同じ情報を何度も記載するのが冗長なので、defaultのところに共通の値を記載して、それに付け加える形で各環境固有の値を定義する意図で元々そのような書き方になっているはずです。
ken1203

2020/12/01 12:04

yu_1985様 ご返信ありあがとうございます! 各環境ごとにusername,password,socketを記述するようにしてください。 >すいません。勉強不足です、、、 調べます!調べてからもう一度、投稿させて下さいm(_ _)m
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

まだ回答がついていません

会員登録して回答してみよう

アカウントをお持ちの方は

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

ただいまの回答率
85.35%

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

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

質問する

関連した質問