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

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

新規登録して質問してみよう
ただいま回答率
85.35%
データベース

データベースとは、データの集合体を指します。また、そのデータの集合体の共用を可能にするシステムの意味を含めます

Docker

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

Q&A

解決済

2回答

5759閲覧

[Docker] Mysql3::Error::ConnectionError: Unknown MySQL server host 'db' (-2)

FUJIMURASJ

総合スコア1

データベース

データベースとは、データの集合体を指します。また、そのデータの集合体の共用を可能にするシステムの意味を含めます

Docker

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

0グッド

0クリップ

投稿2021/04/12 15:45

##前提・実現したいこと

Docker-compose upの後、
Docker-compose run web rails db:createを
実行しようとした時に課題のErrorが発生しました。

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

ActiveRecord::ConnectionNotEstablished Unknown MySQL server host 'db' (-2)

該当のソースコード

####▼Dockerfile

FROM ruby:2.6.7 RUN curl -sL https://deb.nodesource.com/setup_10.x | bash - \ && apt-get install -y nodejs RUN mkdir /myapp WORKDIR /myapp COPY Gemfile /myapp/Gemfile COPY Gemfile.lock /myapp/Gemfile.lock RUN gem install bundler RUN bundle install COPY . /myapp

####▼Database.yml

# MySQL. Versions 5.5.8 and up are supported. # # Install the MySQL driver # gem install mysql2 # # Ensure the MySQL gem is defined in your Gemfile # gem 'mysql2' # # And be sure to use new-style password hashing: # https://dev.mysql.com/doc/refman/5.7/en/password-hashing.html # default: &default adapter: mysql2 encoding: utf8mb4 pool: <%= ENV.fetch("RAILS_MAX_THREADS") { 5 } %> username: root password: password host: db development: <<: *default database: myapp_development # Warning: The database defined as "test" will be erased and # re-generated from your development database when you run "rake". # Do not set this db to the same as development or production. test: <<: *default database: myapp_test # As with config/credentials.yml, you never want to store sensitive information, # like your database password, in your source code. If your source code is # ever seen by anyone, they now have access to your database. # # Instead, provide the password or a full connection URL as an environment # variable when you boot the app. For example: # # DATABASE_URL="mysql2://myuser:mypass@localhost/somedatabase" # # If the connection URL is provided in the special DATABASE_URL environment # variable, Rails will automatically merge its configuration values on top of # the values provided in this file. Alternatively, you can specify a connection # URL environment variable explicitly: # # production: # url: <%= ENV['MY_APP_DATABASE_URL'] %> # # Read https://guides.rubyonrails.org/configuring.html#configuring-a-database # for a full overview on how database connection configuration can be specified. # production: <<: *default database: myapp_production username: myapp password: <%= ENV['MYAPP_DATABASE_PASSWORD'] %>

####▼Dockercompose.yml

version: '3' services: db: image: mysql:5.7 environment: MYSQL_USER: root MYSQL_ROOT_PASSWORD: password ports: - "3306:3306" volumes: - ./db/mysql/volumes:/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: - .:/myapp ports: - 3000:3000 depends_on: - db tty: true stdin_open: true

試したこと

作業ディレクトリ1

% sudo mysql.server restart % docker-compose run web rails db:create

もしました。

作業ディレクトリ2

$ docker stop $(docker ps -q) $ docker rm $(docker ps -aq) $ docker rmi $(docker images -q) Docker起動 $ docker-compose build $ docker-compose up

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

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

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

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

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

guest

回答2

0

ベストアンサー

問題発生の状況について

おそらく docker-compose ps を実行すると、 db サービスが Exit 状態であり、MySQL が起動できていません。

Docker Compose では、接続先のサービス(ここでは db )が起動していないため、アプリケーション側からは db と言うホストが不明、というエラーが出ます。

そのため、web サービスの rails から db サービスに接続しようとしても、エラー Unknown MySQL server host 'db' (-2) が出ています。

原因と回避策

原因は、docker-compose.yml の記述が正確ではないためです。

回避するには、MYSQL_USER: root の行を削除します。

これは、 docker-compose.ymldb サービスを定義する環境変数の中で、

yaml

1 environment: 2 MYSQL_USER: root 3 MYSQL_ROOT_PASSWORD: password

MYSQL_USER は、新規ユーザを作成する指定です(ドキュメントの "Environment Variables" を参照)。

「root」というユーザは、何も操作しなくても初期状態から作られていますので、このようなエラーになりました。

ちなみに、この状態で docker-compose logs コマンドを実行すると、次のように当該行を削除しなさいというメッセージも出ています。

Remove MYSQL_USER="root" and use one of the following to control the root user password:

捕捉

MySQL のボリュームを ./db/mysql/volumes として定義されていますので、既にデータベースが作成済みの状態です。 docker-compose -v down などを実行しても消えません。

mv db db.orig のように一度別名にするか、ディレクトリを削除しないと docker-compose up を再度実行してもデータベースは中身が変わらないので、注意が必要です。

参考

投稿2021/04/12 19:24

zembutsu

総合スコア1584

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

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

FUJIMURASJ

2021/04/13 06:51

ご返信ありがとうございました。 docker-compose.ymlの方から MYSQL_USER: rootを削除し、 docker-compose buildして、 docker-compose run web rails db:createを行いましたが、できませんでした。 捕捉に書いてくださった「mv db db.orig のように一度別名にする」という意味は volumes: - ./db/mysql/volumes:/var/lib/mysql の部分を volumes: - ./mv/db/db.orig:/var/lib/mysql に変えるということでしょうか? その部分だけよく理解できませんでした。 宜しければ、もう一度説明していただけるのでしょうか?
zembutsu

2021/04/13 08:51

docker-compose.yml の中身はそのままで、記述は変更しません。 この docker-compose.yml のボリュームの記述は、 「docker-compose up」コマンドを実行したディレクトリの中に、「./db/mysql/volumes」というディレクトリを作っています。 この「./db/」 として見えている場所を一旦別名にするには「docker-compose up」を実行したディレクトリで「mv db db.orig」というコマンドを実行すると、「./db/」が「./db.orig/」になります。 その後、「docker-compose up」を再度実行すると、新しい設定で再び「./db/」が作り直されるでしょう。
FUJIMURASJ

2021/04/19 08:19

ありがとうございます! 解決できました!
zembutsu

2021/04/19 10:34

解決できて何よりです!
guest

0

runではなくexecを使うとどうでしょうか。

投稿2021/04/12 18:54

inductor

総合スコア428

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

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

FUJIMURASJ

2021/04/13 07:01

ご返信ありがとうございます。 runではなくexecを使うということは Dockerfileの中のことでしょうか? それとも ターミナルでdocker-compose run web rails db:createを打つ時のことでしょうか?
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.35%

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

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

質問する

関連した質問