🎄teratailクリスマスプレゼントキャンペーン2024🎄』開催中!

\teratail特別グッズやAmazonギフトカード最大2,000円分が当たる!/

詳細はこちら
Ruby on Rails 6

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

Heroku

HerokuはHeroku社が開発と運営を行っているPaaSの名称です。RubyやNode.js、Python、そしてJVMベース(Java、Scala、Clojureなど)の複数のプログラミング言語をサポートしている。

MySQL

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

Docker

Dockerは、Docker社が開発したオープンソースのコンテナー管理ソフトウェアの1つです

Q&A

1回答

2157閲覧

【Docker】heroku run rails db:migrateができない

yozakura_dayo

総合スコア4

Ruby on Rails 6

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

Heroku

HerokuはHeroku社が開発と運営を行っているPaaSの名称です。RubyやNode.js、Python、そしてJVMベース(Java、Scala、Clojureなど)の複数のプログラミング言語をサポートしている。

MySQL

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

Docker

Dockerは、Docker社が開発したオープンソースのコンテナー管理ソフトウェアの1つです

0グッド

0クリップ

投稿2021/01/23 04:50

編集2021/01/24 11:02

前提・実現したいこと

Docker環境で、Railsアプリを作成中です。
Herokuへデプロイはできるのですが、

heroku run rails db:migrate

を行うとエラーになってしまい、
ログインや新規登録ができない状態です。

DockerやHerokuにお詳しい方ご教授お願いできませんでしょうか。

追記
https://qiita.com/hayano-t/items/a074f1f2f889d7e92fcc
を参考に、heoku stackを18、

database.ymlに下記を追記しました。

production:
url: <%= ENV['DATABASE_URL'] %>

しかし、下記のエラーが出ている状態です。

ActiveRecord::ConnectionNotEstablished: Access denied for user 'bead377f5a56c8'@'ip-10-0-118-207.ec2.internal' (using password: YES) (中略) Mysql2::Error::ConnectionError: Access denied for user 'bead377f5a56c8'@'ip-10-0-118-207.ec2.internal' (using password: YES)

該当のソースコード

database.yml default: &default adapter: mysql2 encoding: utf8mb4 pool: <%= ENV.fetch("RAILS_MAX_THREADS") { 5 } %> username: <%= ENV.fetch("MYSQL_USERNAME", "root") %> password: <%= ENV.fetch("MYSQL_PASSWORD", "password") %> host: <%= ENV.fetch("MYSQL_HOST", "db") %> development: <<: *default database: myapp_development test: <<: *default database: myapp_test production: <<: *default database: myapp_production username: myapp password: <%= ENV['MYAPP_DATABASE_PASSWORD'] %>  url: <%= ENV['DATABASE_URL'] %>
docker-compose.yml version: '3' services: db: image: mysql:8.0 environment: MYSQL_ROOT_PASSWORD: password MYSQL_DATABASE: root cap_add: # 追加 - SYS_NICE ports: - '4306:3306' command: --default-authentication-plugin=mysql_native_password volumes: - mysql-data:/var/lib/mysql web: build: . environment: # JST変更 TZ: "Asia/Tokyo" # JST変更 command: bash -c "rm -f tmp/pids/server.pid && bundle exec rails s -p 3000 -b '0.0.0.0'" volumes: - .:/myapp ports: - "3000:3000" depends_on: - db stdin_open: true tty: true volumes: mysql-data: driver: local

いろいろググって調べてはみたのですが、
なかなか上記のエラーメッセージの解決方法が載っているページがなく探し出すことができません。

補足情報

Docker version 20.10.0
mysql Ver 8.0.22
rails 6
ruby 2.6.6p146
heroku/7.47.1

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

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

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

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

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

guest

回答1

0

まず、Heroku 上で MySQL を使うために
ClearDB AddOn の登録を行っている必要があります:
ClearDB MySQL - Add-ons - Heroku Elements
(ただし、確か無料利用でもクレジットカード登録が必要でした)

ClearDB を使った Heroku 環境での MySQL 設定は次のドキュメントが最も正確です:
ClearDB MySQL | Heroku Dev Center

上記のドキュメントによると、ClearDB を有効化したとき与えられる環境変数名は
DATABASE_URL ではなく CLEARDB_DATABASE_URL となるようです:
ClearDB MySQL | Heroku Dev Center

また、上記のドキュメントによると、その環境変数で設定されている mysql:// の部分を
mysql2:// に修正する必要があります

環境変数の修正は、Heroku CLI か Heroku Dashboard で行います:
Configuration and Config Vars | Heroku Dev Center

また、公式ドキュメントによると、MySQL のサポートバージョンとしての記述は 5.7 までで、
8 の記載はありませんので、この点にも注意しましょう
ClearDB MySQL | Heroku Dev Center

投稿2021/04/11 02:13

y_shinoda

総合スコア3272

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

まだベストアンサーが選ばれていません

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

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

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

ただいまの回答率
85.36%

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

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

質問する

関連した質問