前提・実現したいこと
既存のRailsアプリの開発環境をDockerに変更中です。
docker-compose upを実行し、docker-compose run web rails db:createを実行するとエラーになってしまいます。
改善方法がわからないため、ご教授頂けますと幸いです。
発生している問題・エラーメッセージ
Unknown MySQL server host 'db' (-2) Couldn't create 'docker_development' database. Please check your configuration.
該当のソースコード
datebase.yml
default: &default adapter: mysql2 encoding: utf8 pool: <%= ENV.fetch("RAILS_MAX_THREADS") { 5 } %> username: root password: password # docker-compose.ymlのMYSQL_ROOT_PASSWORD host: db development: <<: *default username: root password: password database: docker_development production: <<: *default database: <%= ENV['DB_DATABASE'] %> adapter: mysql2 encoding: utf8mb4 charset: utf8mb4 collation: utf8mb4_general_ci host: <%= ENV['DB_HOST'] %> username: <%= ENV['DB_USERNAME'] %> password: <%= ENV['DB_PASSWORD'] %>
docker-compose.yml
version: '2' services: db: image: mysql:latest environment: MYSQL_USER: root MYSQL_ROOT_PASSWORD: password MYSQL_DATABASE: docker_development MYSQL_PASSWORD: password volumes: - mysql-data:/var/lib/mysql #データの永続化のために必要 ports: - "4306:3306" #両方3306でもok。詳細は下の「番外編:DBをsequel proで可視化したい」へ web: tty: true #コンテナ上でbinding.pryするために必要 stdin_open: true #コンテナ上でbinding.pryするために必要 build: . command: bundle exec rails s -p 3000 -b '0.0.0.0' volumes: - .:/myproject #ローカルのディレクトリをコンテナ上にマウント - bundle:/usr/local/bundle #bundle installした後buildし直さなくてよくなる ports: - "3000:3000" links: - db volumes: mysql-data: bundle: #bundle installした後buildし直さなくてよくなる]
Dockerfile
1FROM ruby:2.6.3 2 3RUN apt-get update && \ 4 apt-get install -y mariadb-client nodejs vim --no-install-recommends && \ 5 rm -rf /var/lib/apt/lists/* 6 7RUN mkdir /myproject 8 9WORKDIR /myproject 10 11ADD Gemfile /myproject/Gemfile 12ADD Gemfile.lock /myproject/Gemfile.lock 13 14RUN gem install bundler 15RUN bundle install 16 17ADD . /myproject
試したこと
docker-compose run --rm web rake db:create imageとコンテナを全て削除
また、docker logsでは以下のエラーが出現しました。
[ERROR] [MY-013090] [InnoDB] Unsupported redo log format (0). The redo log was created before MySQL 5.7.9 [ERROR] [MY-012930] [InnoDB] Plugin initialization aborted with error Generic error. [ERROR] [MY-011013] [Server] Failed to initialize DD Storage Engine. [ERROR] [MY-010020] [Server] Data Dictionary initialization failed. [ERROR] [MY-010119] [Server] Aborting
よろしくお願いします。
補足情報(FW/ツールのバージョンなど)
ここにより詳細な情報を記載してください。
回答1件
あなたの回答
tips
プレビュー
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。
2020/07/12 11:04
2020/07/12 11:46
2020/07/12 11:57
2020/07/12 14:24