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

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

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

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

Ruby on Rails

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

Docker

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

Q&A

1回答

762閲覧

docker + rails + mysql で環境構築したい

kengoo

総合スコア10

MySQL

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

Ruby on Rails

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

Docker

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

0グッド

0クリップ

投稿2021/04/01 13:51

前提・実現したいこと

https://www.youtube.com/watch?v=Fq1PH0Gwi8I
こちらの動画を見ながらdockerの環境構築をしています。
再生時間20:00のところと現状で違うエラーが起こっていて先に進めないのでお力添えいただければと思います。

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

docker-compose up
とコマンド、サーバーを立ち上げ
ローカルホスト3000にアクセスしたときのエラーメッセージ

現状のエラーメッセージ Unknown MySQL server host 'db' (-2)
動画でのエラーメッセージ unknown database mysql'myapp_development'

その後
docker-compose run web rails db:create
とコマンドしても

エラーメッセージ Unknown MySQL server host 'db' (-2) Couldn't create 'myapp_development' database. Please check your configuration. rails aborted! Mysql2::Error::ConnectionError: Unknown MySQL server host 'db' (-2) /usr/local/bundle/gems/mysql2-0.5.3/lib/mysql2/client.rb:90:in `conne

とエラーが出る

該当のソースコード

Dockerfile

FROM ruby:2.5 RUN apt-get update -qq && apt-get install -y build-essential libpq-dev nodejs RUN mkdir /myapp WORKDIR /myapp COPY Gemfile /myapp/Gemfile COPY Gemfile.lock /myapp/Gemfile.lock RUN bundle install COPY . /myapp

Docker-compose.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: # 同じディレクトリ配下にあるDockerfileをビルド build: . command: bash -c "rm -f tmp/pids/server.pid && bundle exec rails s -p 3000 -b '0.0.0.0'" # ローカルPCのディレクトリをrubyコンテナにマウント volumes: - .:/myapp - gem_data:/usr/local/bundle # アプリ公開ポートを指定<公開ポート番号>:<コンテナ内の転送先ポート> ports: - 3000:3000 depends_on: - db # デバッグに使用するため設定 tty: true stdin_open: true # マウントするデータ領域を指定 volumes: gem_data:

database.yml

# MySQL. Versions 5.1.10 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: utf8 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/secrets.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 as a unix environment variable when you boot # the app. Read http://guides.rubyonrails.org/configuring.html#configuring-a-database # for a full rundown on how to provide these environment variables in a # production deployment. # # On Heroku and other platform providers, you may have a full connection URL # available as an environment variable. For example: # # DATABASE_URL="mysql2://myuser:mypass@localhost/somedatabase" # # You can use this database configuration with: # # production: # url: <%= ENV['DATABASE_URL'] %> # production: <<: *default database: myapp_production username: myapp password: <%= ENV['MYAPP_DATABASE_PASSWORD'] %>

試したこと

1 再実行

Dockerイメージの削除

$ docker stop $(docker ps -q) $ docker rm $(docker ps -aq) $ docker rmi $(docker images -q)

Dockerの起動

$ docker-compose build $ docker-compose up

2 mysqlの起動

sudo mysql.server restart

いずれも変化なし。

初質問のため、読みづらい文章や説明不足とうあるかもしれませんがそれも含めてフィードバックいただければと思います。
よろしくお願いします。

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

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

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

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

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

guest

回答1

0

エラー内容の可能性は、 Docker Compose で「db」という名前のサービス(コンテナ)が起動できていない可能性があります。

「docker-compose ps」コマンドで「db」サービスが起動しているかどうかの確認が必要です。起動していなければ「docker-compose logs」コマンドを実行し、エラー内容を確認して、対処が必要になります。

起動している場合は、Docker ではなく Rails 側がデータベース(dbという名前のサービス)に接続できないため、Rails 側の設定かなにかの確認をされてみてはいかがでしょうか。

投稿2021/04/02 20:59

zembutsu

総合スコア1584

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

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

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

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問