В настоящее время я работаю над веб-приложением Dockerized, используя Docker Compose. В моем файле docker-compose.yml определены две службы: db и api, где db — это контейнер PostgreSQL, а api — приложение Rails. Однако я столкнулся с ошибкой при попытке подключения к серверу PostgreSQL из моего приложения Rails.
.env
POSTGRES_USER=postgres
POSTGRES_PASSWORD=postgres
POSTGRES_HOST=127.0.0.1
POSTGRES_DB=postgres
docker-compose.yml
version: "3.9"
x-app: &app
env_file:
- .env
stdin_open: true
tty: true
services:
db:
<<: *app
image: postgres:16.2
volumes:
- ./tmp/db:/var/lib/postgresql/data
environment:
DATABASE_URL: "postgres://${POSTGRES_USER}:${POSTGRES_PASSWORD}@${POSTGRES_HOST}:5432/${POSTGRES_DB}"
ports:
- 5432:5432
api:
<<: *app
build: .
command: sh -c "rm -f tmp/pids/server.pid && bundle exec rails s -p 3000 -b '0.0.0.0'"
volumes:
- .:/app
- bundle-cache:/usr/local/bundle
- node_modules:/app/node_modules
ports:
- 3000:3000
depends_on:
- db
volumes:
bundle-cache: null
pg-data: null
node_modules:
Dockerfile
FROM ruby:3.2.3-alpine
RUN apk update --no-cache && apk add build-base tzdata nodejs libpq-dev postgresql-client --no-cache
WORKDIR /app
COPY . ./
RUN bundle install
EXPOSE 3000
CMD ["rails", "server", "-b", "0.0.0.0"]
Я обновил переменную среды DATABASE_URL
в своем приложении Rails до "postgres://${POSTGRES_USER}:${POSTGRES_PASSWORD}@postgres:5432/${POSTGRES_DB}"
.
Похоже на эту часть:
environment:
DATABASE_URL: "postgres://${POSTGRES_USER}:${POSTGRES_PASSWORD}@${POSTGRES_HOST}:5432/${POSTGRES_DB}"
должно быть внутри сервиса api
, верно?
Кроме того, POSTGRES_HOST
— это db
— значение, которое вы использовали в depends_on
.