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

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

新規登録して質問してみよう
ただいま回答率
85.50%
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回答

981閲覧

Docker-composeでRailsとPostgreSQLの接続がうまくいかない

kakedashi-man

総合スコア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クリップ

投稿2023/01/18 14:06

編集2023/01/20 09:24

前提

Ruby on Rails で投稿アプリケーションを作成しています。
Docker composeで構築しています。

色々なサイトの環境構築を参考にしながらDockerfile, database.ymlの設定をしました。
(Dockerfile設定の理解度は完璧でない)

ローカル環境でRailsの画面はデプロイできたのですが、
投稿機能を実装し、投稿画面でRailsのモデルのテーブルに値を保存するところで
UnknownAttributeErrorエラーが発生しました。

$rails dbconsole でテーブルの中身を見ようとしたところ、
Couldn't find database client: psql. Check your $PATH and try again.
と表示されたので、DB接続がうまくいっていないのではないかと考えています。

実現したいこと

  • Docker上でPostgreSQLをRailsに接続したい
  • Dockerfile, database.yml, docker-compose.ymlの設定を完了させたい。

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

root@30efd8784ab1:/app# rails dbconsole /usr/local/lib/ruby/2.7.0/net/protocol.rb:66: warning: already initialized constant Net::ProtocRetryError /usr/local/bundle/gems/net-protocol-0.2.1/lib/net/protocol.rb:68: warning: previous definition of ProtocRetryError was here /usr/local/lib/ruby/2.7.0/net/protocol.rb:206: warning: already initialized constant Net::BufferedIO::BUFSIZE /usr/local/bundle/gems/net-protocol-0.2.1/lib/net/protocol.rb:214: warning: previous definition of BUFSIZE was here /usr/local/lib/ruby/2.7.0/net/protocol.rb:503: warning: already initialized constant Net::NetPrivate::Socket /usr/local/bundle/gems/net-protocol-0.2.1/lib/net/protocol.rb:541: warning: previous definition of Socket was here Couldn't find database client: psql. Check your $PATH and try again.

該当のソースコード

database.yml

1default: &default 2 adapter: postgresql 3 encoding: unicode 4 # For details on connection pooling, see Rails configuration guide 5 # https://guides.rubyonrails.org/configuring.html#database-pooling 6 host: db 7 username: postgres 8 password: password 9 pool: <%= ENV.fetch("RAILS_MAX_THREADS") { 5 } %> 10 11development: 12 <<: *default 13 database: app_development 14 15test: 16 <<: *default 17 database: app_test 18 19production: 20 <<: *default 21 database: <%= ENV['APP_DATABASE'] %> 22 username: <%= ENV['APP_DATABASE_USERNAME'] %> 23 password: <%= ENV['APP_DATABASE_PASSWORD'] %> 24 host: <%= ENV['APP_DATABASE_HOST'] %>

dockercompose.yml

1version: '3' 2services: 3 db: 4 image: postgres 5 volumes: 6 - ./docker/pg:/var/lib/postgresql 7 environment: 8 POSTGRES_USER: postgres 9 POSTGRES_PASSWORD: password 10 web: 11 build: . 12 command: bundle exec rails s -p 3000 -b '0.0.0.0' 13 volumes: 14 - ./src:/app 15 ports: 16 - "3000:3000" 17 environment: 18 RAILS_ENV: development 19 depends_on: 20 - db

Dockerfile

1FROM ruby:2.7 2 3ENV RAILS_ENV=production 4 5RUN curl -sS https://dl.yarnpkg.com/debian/pubkey.gpg | apt-key add - \ 6 && echo "deb https://dl.yarnpkg.com/debian/ stable main" | tee /etc/apt/sources.list.d/yarn.list \ 7 && apt-get update -qq \ 8 && apt-get install -y nodejs yarn 9WORKDIR /app 10COPY ./src /app 11RUN bundle config --local set path 'vendor/bundle' \ 12 && bundle install

試したこと

  • $ rails db:migrate の実行ではエラーは出ない
  • ローカル環境でブラウザ上でページの表示や遷移は動作する。
  • docker composeで実行したコマンドは以下です

terminal

1//railsアプリ作成時 2$docker-compose run web rails new .--force --database=postgresql 3$docker-compose build 4$docker-compose up 5 6//モデル作成、データベース追記 7$docker-compose run web rails g model PostBook 8$docker-compose run web rails db:migrate 9 10//deviseインストール後、モデル作成 11$docker-compose run web rails g controller PostBooks new index show 12$docker-compose build 13$docker-compose up

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

Macbook
DB: PostgreSQL
ruby: ver.2.7

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

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

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

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

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

yuma.inaura

2023/01/18 14:13

コードはテキストで載せてみませんか?再現するために回答者が写経しなければいけないので
no1knows

2023/01/18 23:45

docker compose で実行したコマンドを追記してください。
guest

回答1

0

Docker初心者ですが…
そもそも原因の切り分けのために、Docker Desktopもしくはコマンドで、PostgreSQLが立ち上がっているか確認したほうが良いかと思います。
またタイポだと思いますが、念の為・・・

> $docker-compose run web rails new .--force --database=postgresql ↓ $docker-compose run web rails new . --force --database=postgresql

投稿2023/01/20 00:24

no1knows

総合スコア3365

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

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

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

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

ただいまの回答率
85.50%

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

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

質問する

関連した質問