Railsの環境をDockerで作りましたが、rails db
を実行するとCouldn't find database client: psql. Check your $PATH and try again.
のエラーが出てdbにアクセスできません。
PATHを繋げろということは理解できるのですが、volumesで設定したはずなので、なぜこのエラーがでるのかが分からない状態です。
なぜかrails db:migrate
やrails 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
回答1件
あなたの回答
tips
プレビュー
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。
退会済みユーザー
2018/11/11 04:11