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

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

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

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

MySQL

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

Ruby on Rails

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

AWS(Amazon Web Services)

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

Q&A

解決済

1回答

2201閲覧

AWSで「rails db:create RAILS_ENV=production」できない

amby

総合スコア40

Ruby

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

MySQL

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

Ruby on Rails

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

AWS(Amazon Web Services)

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

0グッド

0クリップ

投稿2020/09/20 13:28

編集2020/09/21 10:42

起きていること、実現したいこと

下記の記事を参考にAWSへデプロイをしています。
https://qiita.com/shunsuke284052/items/26e10494ef05e56d3d01

下記の部分で「rails db:create RAILS_ENV=production」を実行したところで詰まっています。
対処方法を教えていただきたいです。
イメージ説明

エラー内容

[ec2-user@ip-172-31-35-175 portfolio]$ rails db:create RAILS_ENV=production Mysql2::Error::ConnectionError: Access denied for user ''@'localhost' to database 'portfolio_production': CREATE DATABASE `portfolio_production` DEFAULT CHARACTER SET `utf8` Couldn't create 'portfolio_production' database. Please check your configuration. rails aborted! ActiveRecord::StatementInvalid: Mysql2::Error::ConnectionError: Access denied for user ''@'localhost' to database 'portfolio_production': CREATE DATABASE `portfolio_production` DEFAULT CHARACTER SET `utf8` bin/rails:4:in `<main>' Caused by: Mysql2::Error::ConnectionError: Access denied for user ''@'localhost' to database 'portfolio_production' bin/rails:4:in `<main>' Tasks: TOP => db:create (See full trace by running task with --trace)

新たなエラー

「rails db:migrate RAILS_ENV=production」を実行すると下記のようなエラーがでます。

[ec2-user@ip-172-31-35-175 portfolio]$ rails db:migrate RAILS_ENV=production == 20200802224225 DropTableMicroposts: migrating ============================== -- drop_table(:microposts) rails aborted! StandardError: An error has occurred, all later migrations canceled: Mysql2::Error: Unknown table 'portfolio_production.microposts': DROP TABLE `microposts` /var/www/portfolio/db/migrate/20200802224225_drop_table_microposts.rb:3:in `change' bin/rails:4:in `<main>' Caused by: ActiveRecord::StatementInvalid: Mysql2::Error: Unknown table 'portfolio_production.microposts': DROP TABLE `microposts` /var/www/portfolio/db/migrate/20200802224225_drop_table_microposts.rb:3:in `change' bin/rails:4:in `<main>' Caused by: Mysql2::Error: Unknown table 'portfolio_production.microposts' /var/www/portfolio/db/migrate/20200802224225_drop_table_microposts.rb:3:in `change' bin/rails:4:in `<main>' Tasks: TOP => db:migrate (See full trace by running task with --trace) [ec2-user@ip-172-31-35-175 portfolio]$ ails db:migrate RAILS_ENV=production -bash: ails: コマンドが見つかりません [ec2-user@ip-172-31-35-175 portfolio]$ rails db:migrate RAILS_ENV=production == 20200802224225 DropTableMicroposts: migrating ============================== -- drop_table(:microposts) rails aborted! StandardError: An error has occurred, all later migrations canceled: Mysql2::Error: Unknown table 'portfolio_production.microposts': DROP TABLE `microposts` /var/www/portfolio/db/migrate/20200802224225_drop_table_microposts.rb:3:in `change' bin/rails:4:in `<main>' Caused by: ActiveRecord::StatementInvalid: Mysql2::Error: Unknown table 'portfolio_production.microposts': DROP TABLE `microposts` /var/www/portfolio/db/migrate/20200802224225_drop_table_microposts.rb:3:in `change' bin/rails:4:in `<main>' Caused by: Mysql2::Error: Unknown table 'portfolio_production.microposts' /var/www/portfolio/db/migrate/20200802224225_drop_table_microposts.rb:3:in `change' bin/rails:4:in `<main>' Tasks: TOP => db:migrate (See full trace by running task with --trace)

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

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

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

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

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

guest

回答1

0

ベストアンサー

Access denied for user ''@'localhost' to database

となっていて、データベースの接続ユーザが空になっています。
なので、恐らくデータベースの接続設定に問題があります。
多分database.ymlで設定していると思うのでそちらを確認してみてください。
※参考サイトでは平然とrootユーザを使わせていますが、本来は事前に専用のユーザを作るべきです。

投稿2020/09/20 17:51

yu_1985

総合スコア7588

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

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

amby

2020/09/21 10:40

ありがとうございます。 ポートフォリオのdatabase.ymlファイルを下記のように書き直したら「rails db:create RAILS_ENV=production」はひとまずできました。ありがとうございます。 roduction: <<: *default database: portfolio_production username: root password: taishiman1026 # <%= ENV['DATABASE_PASSWORD'] %> socket: /var/lib/mysql/mysql.sock
amby

2020/09/21 10:42

ただ、次のステップの「rails db:migrate RAILS_ENV=production」で新たなエラーが出ており、前のステップのdatabase.ymlの記述が間違っているのでしょうか?
yu_1985

2020/09/21 15:31

エラーの内容になぜエラーになっているのか出てるのでまずはそれをきちんと読んでください。 > Mysql2::Error: Unknown table 'portfolio_production.microposts': DROP TABLE `microposts` micropostsというテーブルが(恐らく)ないようです。 恐らくマイグレーションの設定に問題があります。 この辺の話が関係ありそうですが、マイグレーションの設定が現状どうなのかわからないので想像です。 https://www.uosansatox.biz/entry/2017/09/08/171851 ちなみにですが、これは「Mysql2::Error: Unknown table 」で検索したら一発目に出てきました。 エラーメッセージはトラブルシュートのヒントなので、それを使って調べる癖をつけてください。 (特に)RailsやLaravelに関しては不正確な情報も多々出てくるので取捨選択が面倒な部分はありますが…。
amby

2020/09/22 10:07

丁寧にご教示いただき誠にありがとうございました。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.35%

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

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

質問する

関連した質問