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

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

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

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

Ruby on Rails

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

AWS(Amazon Web Services)

Amazon Web Services (AWS)は、仮想空間を機軸とした、クラスター状のコンピュータ・ネットワーク・データベース・ストーレッジ・サポートツールをAWSというインフラから提供する商用サービスです。

Q&A

解決済

1回答

513閲覧

docker-compose run app rake db:createで『Mysql2::Error』

ryouya

総合スコア14

docker-compose

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

Ruby on Rails

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

AWS(Amazon Web Services)

Amazon Web Services (AWS)は、仮想空間を機軸とした、クラスター状のコンピュータ・ネットワーク・データベース・ストーレッジ・サポートツールをAWSというインフラから提供する商用サービスです。

0グッド

0クリップ

投稿2020/05/30 02:31

編集2020/05/31 01:43

お世話になっております。
下記の件、知見がある方がいらっしゃいましたらご教示お願いします。

#起きている問題
AWS環境でnginxunicornmysqldockerコンテナで構築しdocker-compose run app rake db:create実行時にMysql2::Error::ConnectionError: Can't connect to local MySQL server through socket '/var/run/mysqld/mysqld.sock' (2 "No such file or directory")>が起きました。

$ docker-compose run app rake db:create Starting coffee_app_db_1 ... done #<Mysql2::Error::ConnectionError: Can't connect to local MySQL server through socket '/var/run/mysqld/mysqld.sock' (2 "No such file or directory")> Couldn't create database for {"adapter"=>"mysql2", "encoding"=>"utf8", "database"=>"coffee_app_development", "pool"=>5, "username"=>"karirin", "password"=>"karirin3948", "host"=>"localhost"}, {:charset=>"utf8"} (If you set the charset manually, make sure you have a matching collation) Created database 'coffee_app_development' #<Mysql2::Error::ConnectionError: Can't connect to local MySQL server through socket '/var/run/mysqld/mysqld.sock' (2 "No such file or directory")> Couldn't create database for {"adapter"=>"mysql2", "encoding"=>"utf8", "reconnect"=>false, "database"=>"coffee_app_test", "pool"=>5, "username"=>"karirin", "password"=>"karirin3948", "host"=>"localhost"}, {:charset=>"utf8"} (If you set the charset manually, make sure you have a matching collation) Created database 'coffee_app_test'

#確認したこと
####mysqld.sock確認

$ touch /var/run/mysqld/mysqld.sock [mysqld]$ ls mysqld.sock

mysqld.sockがないというエラーだったので生成しましたが、解決しませんでした。
####mysqld起動確認

$ ps ax | grep mysqld 5180 pts/0 S+ 0:00 grep --color=auto mysqld 30674 ? Ssl 1:03 /usr/sbin/mysqld 30892 ? Ssl 1:13 mysqld

mysqldは起動していることを確認しました。
####sudo mysql.server start

$ sudo mysql.server start [sudo] ryouya のパスワード: sudo: mysql.server: コマンドが見つかりません

sudo mysql.server startを実行したところ、コマンドが見つからないとでました。

$ mysql --version mysql Ver 8.0.20 for Linux on x86_64 (MySQL Community Server - GPL)

mysql --versionでは正常にバージョンが表示されました。
#関連ファイル
Dockerfile(Rails)

FROM ruby:2.5.1 RUN apt-get update -qq && \ apt-get install -y apt-utils \ build-essential \ libpq-dev \ nodejs \ default-mysql-client RUN mkdir /coffee_app WORKDIR /coffee_app ADD Gemfile /coffee_app/Gemfile ADD Gemfile.lock /coffee_app/Gemfile.lock RUN bundle install -j4 ADD . /coffee_app EXPOSE 3000

Dockerfile(mysql)

FROM mysql:8.0.17 RUN apt-get update && \ apt-get install -y apt-utils \ locales && \ rm -rf /var/lib/apt/lists/* && \ echo "ja_JP.UTF-8 UTF-8" > /etc/locale.gen && \ locale-gen ja_JP.UTF-8 ENV LC_ALL ja_JP.UTF-8 ADD ./docker/mysql/charset.cnf /etc/mysql/conf.d/charset.cnf

Dockerfile(nginx)

FROM nginx:1.12.2 RUN apt-get update && \ apt-get install -y apt-utils \ locales && \ echo "ja_JP.UTF-8 UTF-8" > /etc/locale.gen && \ locale-gen ja_JP.UTF-8 ENV LC_ALL ja_JP.UTF-8 ADD ./docker/nginx/nginx.conf /etc/nginx/nginx.conf ADD ./docker/nginx/default.conf /etc/nginx/conf.d/default.conf

docker-compose.yml

version: '2' services: app: build: context: . dockerfile: ./docker/rails/Dockerfile command: bundle exec unicorn -p 3000 -c /app/config/unicorn.rb # command: bundle exec rails s -p 3000 -b '0.0.0.0' ports: - '3000:3000' volumes: - /var/tmp - .:/coffee_app depends_on: - db extends: file: ./docker/mysql/password.yml service: password db: build: context: . dockerfile: ./docker/mysql/Dockerfile ports: - '3306:3306' volumes: - db_data:/var/lib/mysql extends: file: ./docker/mysql/password.yml service: password nginx: build: context: . dockerfile: ./docker/nginx/Dockerfile ports: - '80:80' volumes: - coffee_app volumes: db_data:

database.yml

development: adapter: mysql2 encoding: utf8 database: coffee_app_development pool: 5 username: karirin password: karirin3948 host: localhost test: adapter: mysql2 encoding: utf8 reconnect: false database: coffee_app_test pool: 5 username: karirin password: karirin3948 host: localhost production: adapter: mysql2 database: coffee_app_production host: <%= ENV['DB_HOSTNAME'] %> encoding: utf8 username: root reconnect: false pool: 5 password: <%= ENV['DB_PASSWORD'] %>

#環境
ruby 2.5.1
rails 5.1.6
docker version 19.03.6
docker-compose version 1.24.0

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

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

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

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

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

guest

回答1

0

自己解決

本件解決しました。

原因はtestdevelopment環境だけAWS上のRDSではなく、
EC2上のmysqlで実行しようとしていたためでした。
database.ymltestdevelopment環境もRDSにつながるように書き換えたら正常に動きました。

確認してくださった方々、ありがとうございましたm(_ _)m

投稿2020/05/31 02:52

ryouya

総合スコア14

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.35%

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

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

質問する

関連した質問