Как подключиться к PostgreSQL контейнеру с помощью Rails - PullRequest
0 голосов
/ 23 февраля 2020

У меня есть Docker -файл, который объявляет мое Ruby на Rails-приложении с nginx и PostgreSQL базой данных.

Я пытаюсь понять, как мое приложение Rails подключается к мой PostgreSQL контейнер, потому что он вообще не соединяется.

Я создал Docker -файл, связывающий изображения:

web:
  build: .
  command: bundle exec puma -C config/puma.rb
  volumes:
    - /tmp:/tmp
    # - /log:/data
    - .:/my_project_folder
  links:
    - nginx
    - db

nginx:
  build: ./nginx
  volumes:
    - /tmp:/tmp
  ports:
    - 80:80

db:
  image: postgres
  environment:
      POSTGRES_PASSWORD: "Postgres2019!"
  ports:
    - "15432:5432"
  volumes:
    - /Users/fred/Documents/Postgres/data:/var/lib/postgresql/data

и настроил свой database.yml следующим образом:

default: &default
  adapter: postgresql
  encoding: unicode
  host: 0.0.0.0
  port: 15432
  # For details on connection pooling, see Rails configuration guide
  # https://guides.rubyonrails.org/configuring.html#database-pooling
  pool: <%= ENV.fetch("RAILS_MAX_THREADS") { 5 } %>
  username: postgres
  password: Postgres2019!
development:
  <<: *default
  database: mos_development

Но всякий раз, когда я пытаюсь запустить свое приложение, Rails не может подключиться к базе данных, возвращая

ActiveRecord::ConnectionTimeoutError

, но когда я проверяю свои контейнеры, все работает нормально:

CONTAINER ID        IMAGE                 COMMAND                  CREATED             STATUS              PORTS                     NAMES
1cfbc010829a        project_web           "bundle exec puma -C…"   19 minutes ago      Up 13 minutes                                 project_web_1
1774e2b89452        postgres              "docker-entrypoint.s…"   20 minutes ago      Up 13 minutes       0.0.0.0:15432->5432/tcp   project_db_1
0ce7dbb6d735        project_nginx         "nginx -g 'daemon of…"   3 hours ago         Up 13 minutes       0.0.0.0:80->80/tcp        project_nginx_1

Если мой PostgreSQL контейнер работает на 0.0.0.0:15432, тогда мой Rails-контейнер должен иметь возможность подключаться к нему также на 0.0.0.0:15432, верно?

Ответы [ 3 ]

1 голос
/ 23 февраля 2020

Попробуйте:

default: &default
  adapter: postgresql
  encoding: unicode
  host: db    # <-- change this line
  port: 15432
  # For details on connection pooling, see Rails configuration guide
  # https://guides.rubyonrails.org/configuring.html#database-pooling
  pool: <%= ENV.fetch("RAILS_MAX_THREADS") { 5 } %>
  username: postgres
  password: Postgres2019!
development:
  <<: *default
  database: mos_development

Приложение Rails связано с db, db:15432.

1 голос
/ 23 февраля 2020

Обычно это проблема конфигурации Active Record, а не самой базы данных.

Чтобы убедиться, что в вашей базе данных есть доступные подключения, запустите heroku pg:info из командной строки и просмотрите количество подключений по сравнению с максимальным количеством для вашего плана.

Эта ошибка обычно вызывается когда размер пула Active Record задан слишком мал или когда вы пытаетесь разделить небольшое количество соединений с базой данных между большим числом рабочих процессов.

Вы можете поиграть с этим:

pool: <%= ENV.fetch("RAILS_MAX_THREADS") { 1 } %>

Что касается этой части вопроса:

Если мой контейнер postgres работает с 0.0.0.0:15432, тогда мой контейнер rails должен быть подключен к нему также с 0.0.0.0: 15432, верно?

Да, вы должны использовать:

 docker-host-ip:15432 
0 голосов
/ 24 февраля 2020

Если у вас слишком много переменных окружения, вы можете установить их в файлах env. например,

# .env.docker
RAILS_MAX_THREADS=4
USERNAME=posgres
...
...

Затем укажите файл .env.docker в вашем docker -компонентном файле с помощью env_file:

db:
  image: postgres
  env_file: .env.docker
  environment:
      POSTGRES_PASSWORD: "Postgres2019!"
  ports:
    - "15432:5432"
  volumes:
    - /Users/fred/Documents/Postgres/data:/var/lib/postgresql/data
...
...
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...