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

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

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

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

Docker

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

Q&A

解決済

1回答

2426閲覧

Couldn't find database client: psql. Check your $PATH and try again.

退会済みユーザー

退会済みユーザー

総合スコア0

Ruby on Rails 5

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

Docker

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

0グッド

0クリップ

投稿2018/11/11 01:42

Railsの環境をDockerで作りましたが、rails dbを実行するとCouldn't find database client: psql. Check your $PATH and try again.のエラーが出てdbにアクセスできません。

PATHを繋げろということは理解できるのですが、volumesで設定したはずなので、なぜこのエラーがでるのかが分からない状態です。

なぜかrails db:migraterails db:createは実行できます。

参考にしたのは、Quickstart: Compose and Railsです。

$ docker-compose run web rails db Starting sample_db_1 ... done Couldn't find database client: psql. Check your $PATH and try again. $ docker-compose run web rake db:migrate:status Starting sample_db_1 ... done database: myapp_development Status Migration ID Migration Name -------------------------------------------------- up 20181106115320 Devise create users

Docker-compose.yml

version: '3' services: db: image: postgres volumes: - ./tmp/db:/var/lib/postgresql/data web: build: . command: bundle exec rails s -p 3000 -b '0.0.0.0' volumes: - .:/myapp ports: - "3000:3000" depends_on: - db

database.yml

default: &default adapter: postgresql encoding: unicode host: db username: postgres password: pool: <%= ENV.fetch("RAILS_MAX_THREADS") { 5 } %> development: <<: *default database: myapp_development test: <<: *default database: myapp_test production: <<: *default database: myapp_production username: myapp password: <%= ENV['MYAPP_DATABASE_PASSWORD'] %>

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

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

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

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

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

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

guest

回答1

0

ベストアンサー

こんにちは。

rake db:migrateやdb:createはpostgresqlに対してrails側で接続して実行します。
(コアのライブラリが入っていれば良い)

一方、rails db コマンドは、railsからdatabase.yml で設定されているDBに対して、各DBに対応した「コマンドラインインタフェース」を起動します。
なので、PostgreSQLであれば、psqlコマンドが必要です。

rails用にビルドしているDockerfileでは、

RUN apt-get update -qq && apt-get install -y build-essential libpq-dev nodejs

libpq-devは入っていますがpsqlは入っていない状態なので、apt postgresql-client が追加で必要になると思います。

$ docker-compose run web which psql

として、psqlコマンドが入っているか確認してみると、command not foundになると思います。

投稿2018/11/11 02:40

suama

総合スコア1997

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

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

退会済みユーザー

退会済みユーザー

2018/11/11 04:11

ありがとうございます。アドバイス通りやったらできました。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問