🎄teratailクリスマスプレゼントキャンペーン2024🎄』開催中!

\teratail特別グッズやAmazonギフトカード最大2,000円分が当たる!/

詳細はこちら
docker-compose

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

PostgreSQL

PostgreSQLはオープンソースのオブジェクトリレーショナルデータベース管理システムです。 Oracle Databaseで使われるPL/SQLを参考に実装されたビルトイン言語で、Windows、 Mac、Linux、UNIX、MSなどいくつものプラットフォームに対応しています。

Ruby on Rails

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

Docker

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

Q&A

1回答

1995閲覧

DockerでRailsを環境構築する際のrails db:create がうまく機能しない(PostgreSQL)

adject246

総合スコア0

docker-compose

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

PostgreSQL

PostgreSQLはオープンソースのオブジェクトリレーショナルデータベース管理システムです。 Oracle Databaseで使われるPL/SQLを参考に実装されたビルトイン言語で、Windows、 Mac、Linux、UNIX、MSなどいくつものプラットフォームに対応しています。

Ruby on Rails

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

Docker

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

0グッド

0クリップ

投稿2021/02/01 03:21

前提・実現したいこと

rails db:creteでデータベースを作りたい

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

rails db:create とコマンドで叩くとUnknown hostとなり、データベースが作られない。それゆえrailsのウェルカムページが表示されない。

Caused by: PG::ConnectionBad: could not translate host name "db" to address: Unknown host

該当のソースコード

database.yml

default: &default adapter: postgresql encoding: unicode host: db username: postgres password: password pool: 5 development: <<: *default database: reruforcomapany test: <<: *default database: myapp_test production: <<: *default database: myapp_production username: myapp password: <%= ENV['MYAPP_DATABASE_PASSWORD'] %>

docker-compose.yml

version: '3' services: db: image: postgres volumes: - postgres-data:/var/lib/postgresql/data environment: - POSTGRES_PASSWORD=password - POSTGRES_DB=postgres - POSTGRES_USER=postgres api: build: context: ./api/ dockerfile: Dockerfile command: /bin/sh -c "rm -f /myapp/tmp/pids/server.pid && bundle exec rails s -p 3000 -b '0.0.0.0'" image: rails:dev volumes: - ./api:/myapp - ./api/vendor/bundle:/myapp/vendor/bundle environment: TZ: Asia/Tokyo RAILS_ENV: development ports: - 3000:3000 depends_on: - db front: build: context: ./front/ dockerfile: Dockerfile volumes: - ./front:/usr/src/app command: sh -c "cd react-sample && yarn start" ports: - "8000:3000" volumes: postgres-data: driver: local

docker-compose psの実行結果(Nameは作成中のアプリ名)

Name Command State Ports ---------------------------------------------------------------------------------------- reruforcompany_api_1 entrypoint.sh /bin/sh -c r ... Up 0.0.0.0:3000->3000/tcp reruforcompany_db_1 docker-entrypoint.sh postgres Up 5432/tcp reruforcompany_front_1 docker-entrypoint.sh sh -c ... Up 0.0.0.0:8000->3000/tcp

Dockerfile

FROM ruby:2.6 RUN apt-get update -qq && apt-get install -y nodejs postgresql-client RUN mkdir /myapp WORKDIR /myapp COPY Gemfile /myapp/Gemfile COPY Gemfile.lock /myapp/Gemfile.lock RUN bundle install COPY . /myapp COPY entrypoint.sh /usr/bin/ RUN chmod +x /usr/bin/entrypoint.sh ENTRYPOINT ["entrypoint.sh"] EXPOSE 3000 CMD ["rails", "server", "-b", "0.0.0.0"]

試したこと

hostが見つからないということで、
database.ymlのhost部分をlocalhostなどいろいろ変換したがエラー変わらず
postgresのイメージのバージョンを変えてみるも変わらず
一度コンテナやイメージを全削除して一から構築するも変わらず

補足情報(FW/ツールのバージョンなど)

ホストOS:Windows10
Docker version 20.10.2
docker-compose version 1.27.4
rails : 6.1.1
フロントはReactで環境構築してますが、Reactは正常にウェルカムページが表示されました。

確認なのですが、PostgreSQLが入ったコンテナがあればホストOSの方にPostgreSQLをインストールする必要はないですよね??
PostgreSQLについて調べると、ユーザー登録が必要である場合と必要でない場合があるのがよく分かりません。

ググってもMySQLの記事が多く状況を打開する記事が見つかりませんでした。
プログラミング初めて2か月の大学生です。お優しい方ぜひご教授ください。よろしくお願いします。

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

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

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

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

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

guest

回答1

0

rails db:create のコマンドはDocker Composeから起動したapiコンテナから実行していますか?

"db" というホスト名はこのdocker-composeの定義の中だけで有効なので、ローカルからrailsコマンドを直接実行している場合にはこの"db"というホストが見つけられずアクセスができないはずです。

apiコンテナから直接実行するには docker-compose run --rm api rails db:migrate などのようにすればよいかと思います。

投稿2021/03/17 10:33

ha4gu

総合スコア29

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

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

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

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

ただいまの回答率
85.36%

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

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

質問する

関連した質問