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

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

新規登録して質問してみよう
ただいま回答率
85.48%
docker-compose

docker-composeとは、複数のコンテナで構成されるサービスを提供する手順を自動的し管理を簡単にするツール。composeファイルを使用しコマンド1回で設定した全サービスを作成・起動することが可能です。

MySQL

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

Ruby on Rails

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

Q&A

解決済

1回答

1773閲覧

Access denied for user 'root'@'localhost' (using password: YES)

tomsuma

総合スコア38

docker-compose

docker-composeとは、複数のコンテナで構成されるサービスを提供する手順を自動的し管理を簡単にするツール。composeファイルを使用しコマンド1回で設定した全サービスを作成・起動することが可能です。

MySQL

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

Ruby on Rails

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

0グッド

0クリップ

投稿2020/09/12 03:33

編集2020/09/12 22:19

Access denied for user 'root'@'localhost' (using password: NO)

から
Access denied for user 'root'@'localhost' (using password: YES)
になりました
rails s
やdocker-compose up をするとこのエラーが出て困ってます。

Mysqlの環境変数を確認したのですが、ほかはどこが怪しいですか?

イメージ説明

database.yml default: &default adapter: mysql2 encoding: utf8 pool: <%= ENV.fetch("RAILS_MAX_THREADS") { 5 } %> username: root password: example # socket: /tmp/mysql.sock # host: db development: <<: *default database: Books_development test: <<: *default database: Books_test production: <<: *default database: Books_production username: root password: <%= ENV['DATABASE_PASSWORD'] %> # socket: /var/lib/mysql/mysql.sock ``` ``` version: '3' services: db: image: mysql:5.6 environment: MYSQL_ROOT_PASSWORD: example MYSQL_DATABASE: root ports: - "4306:3306" volumes: - mysql-data:/var/lib/mysql web: build: . command: bash -c "rm -f tmp/pids/server.pid && bundle exec rails s -p 3000 -b '0.0.0.0'" volumes: - .:/Books ports: - 3000:3000 depends_on: - db tty: true stdin_open: true volumes: mysql-data: ``` ``` Creating books_web_run ... done Can't connect to local MySQL server through socket '/var/run/mysqld/mysqld.sock' (2) Couldn't create 'Books_development' database. Please check your configuration. ``` 環境変数が抜けてたので sudo vim /etc/environment コマンド後、 DATABASE_PASSWORD='****' と記入したのですがダメでした

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

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

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

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

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

hatsu

2020/09/12 03:51

>Mysqlの環境変数を確認したのですが とありますが、 エラーメッセージでは using password: NO と書かれているのが気になりました。 環境変数の `DATABASE_PASSWORD` の値は入っていますか? また SELECT Host, User, authentication_string FROM mysql.user; でrootユーザーはパスワードを持っているか確認できますでしょうか。
unhappychoice

2020/09/12 03:51

docker-compose.yml の内容を記載してください
tomsuma

2020/09/12 09:26

ご回答ありがとうございます。 環境変数が抜けてたので sudo vim /etc/environment コマンド後、 DATABASE_PASSWORD='****' と記入したのですがダメでした
tomsuma

2020/09/12 09:29

*** には mysql -u root -p コマンド時に必要なパスワードと同じものを入れました
hatsu

2020/09/12 16:32

docker-compose.ymlでは MYSQL_ROOT_PASSWORD と書いてありますがDATABASE_PASSWORDと異なりますか?
tomsuma

2020/09/12 22:48 編集

ご回答ありがとうございます 同じだと思います
guest

回答1

0

ベストアンサー

docker-compose.ymlを以下のように書き換えたらうまくいかないでしょうか?
Railsの設定でENV['DATABASE_PASSWORD']を参照しているのに、その環境変数がセットされていないように見えます。

yaml

1version: '3' 2services: 3 db: 4 image: mysql:5.6 5 environment: 6 MYSQL_ROOT_PASSWORD: example 7 MYSQL_DATABASE: root 8 ports: 9 - "4306:3306" 10 volumes: 11 - mysql-data:/var/lib/mysql 12 web: 13 build: . 14 environment: 15 DATABASE_PASSWORD: example 16 command: bash -c "rm -f tmp/pids/server.pid && bundle exec rails s -p 3000 -b '0.0.0.0'" 17 volumes: 18 - .:/Books 19 ports: 20 - 3000:3000 21 depends_on: 22 - db 23 tty: true 24 stdin_open: true 25volumes: 26 mysql-data:

投稿2020/09/12 17:01

YakumoSaki

総合スコア2027

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

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

tomsuma

2020/09/12 22:26 編集

ご回答ありがとうございます 一度できるか確認のため、消してやり直したのですが docker-compose run web bundle exec rake db:create コマンド時に Can't connect to local MySQL server through socket '/var/run/mysqld/mysqld.sock' (2) のエラーが出て、database.yml socketの部分をコメントアウトしたのですがダメでした
YakumoSaki

2020/09/13 04:23

database.ymlの以下の部分を修正したらうまく行くと思います。 default: &default adapter: mysql2 encoding: utf8 pool: <%= ENV.fetch("RAILS_MAX_THREADS") { 5 } %> username: root password: example # socket: /tmp/mysql.sock <= コメントアウト host: db <= この行追加 (以降はそのまま)
tomsuma

2020/09/13 21:58

行けました! ありがとうございます
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問