Как мне запустить Rails в Docker? PG :: ConnectionBad не смог перевести имя хоста "pg" в адрес: адрес не связан с именем хоста - PullRequest
0 голосов
/ 29 апреля 2018

Я пытался следовать руководству здесь: https://docs.docker.com/compose/rails/

docker-compose.yml
version: '3'
services:
  pg:                                     ######### LOOK HERE!
    image: postgres
    volumes:
      - ./tmp/db:/var/lib/postgresql/data
  web:
    build: .
    command: bundle exec rails server -p 3000 -b '0.0.0.0'
    volumes:
      - .:/app
    ports:
      - "3000:3000"
    depends_on:
      - pg
    links:
      - pg                                     ######### LOOK HERE!
  cms:
    image: joomla
    restart: always
    links:
      - mysql:joomladb
    ports:
      - 8080:80
    environment:
      JOOMLA_DB_HOST: mysql
      JOOMLA_DB_PASSWORD: example
  mysql:
    image: mysql:5.6
    restart: always
    environment:
      MYSQL_ROOT_PASSWORD: example
config/database.yml
# SQLite version 3.x
#   gem install sqlite3
#
#   Ensure the SQLite 3 gem is defined in your Gemfile
#   gem 'sqlite3'
#
default: &default
  adapter: postgresql
  encoding: unicode
  pool: 5
  timeout: 5000
  host: pg                                     ######### LOOK HERE!
  username: postgres
  password:

development:
  <<: *default
  database: project

# Warning: The database defined as "test" will be erased and
# re-generated from your development database when you run "rake".
# Do not set this db to the same as development or production.
test:
  <<: *default
  database: project_test

production:
  <<: *default
  database: project

Консоль

C:\Users\Chloe\workspace\project\src>docker-compose run web rake db:create
Starting src_pg_1 ... done
could not translate host name "pg" to address: No address associated with hostname
Couldn't create database for {"adapter"=>"postgresql", "encoding"=>"unicode", "pool"=>5, "timeout"=>5000, "host"=>"pg", "username"=>"postgres", "password"=>nil, "database"=>"project"}
rake aborted!
PG::ConnectionBad: could not translate host name "pg" to address: No address associated with hostname

docker-compose версия 1.20.1, сборка 5d8c71b2, Docker версия 18.03.0-ce, сборка 0520e24302

Ответы [ 2 ]

0 голосов
/ 05 сентября 2018

Хорошо, я постараюсь ответить на это:

Обычно, когда появляется эта ошибка, это, вероятно, означает, что запуск контейнера db возвратил некоторые ошибки и остановился.

У меня была такая же проблема, и после некоторого копания я обнаружил, что у меня

LANG='en_US.UTF-8'
LANGUAGE='en_US:en'
LC_ALL='en_US.UTF-8'

установлен в моей переменной окружения, и это привело к остановке контейнера db. Поэтому, поскольку контейнер не работал, у меня не было db хоста.

Вот как выглядит мой docker-compose.yml файл:

version: '3'

services:
  db:
    image: postgres
    volumes:
      - ./tmp/db:/var/lib/postgresql/data
    env_file: .env
  app:
    build: .
    command: bundle exec puma -p 3000 -C config/puma.rb
    env_file: .env
    volumes:
      - .:/app
    ports:
      - "3031:3000"
    depends_on:
      - db

Вот config/database.yml

default: &default
  adapter: postgresql
  encoding: unicode
  host: db
  pool: 5
  username: <%= ENV['POSTGRES_USER'] %>
  password: <%= ENV['POSTGRES_PASSWORD'] %>

development:
  <<: *default
  database: driggl_dev

test:
  <<: *default
  database: driggl_test

production:
  <<: *default
  database: driggl_prod

... и файл .env для разработки:

POSTGRES_USER=driggl
POSTGRES_PASSWORD=driggl

Поскольку у меня были общие тома для данных базы данных, я просто удалил папку tmp/db из репозитория, чтобы быть уверенным.

rm -rf tmp/*

затем я удалил все контейнеры и изображения

docker rm $(docker ps -q -a) -f
docker rmi $(docker images -q) -f

Наконец я снова раскручиваю контейнеры:

docker-compose up --build

и все наконец пошло правильно.

Резюме

  1. Убедитесь, что в системе ничего не кэшировано
  2. Убедитесь, что ваш контейнер БД не возвращает ошибок при запуске.

Надеюсь, это поможет любому, кто столкнется с этой проблемой.

0 голосов
/ 29 апреля 2018

Эта настройка работает для меня запуск рельсов на докере. В основном нужно указать URL, поэтому вы будете использовать файл .env для указания URL-адреса postgres, и вы будете переключаться между _development _test и _production с помощью файла config / database, просто заставив добавить env. файл в файл docker-compose вашего веб-сервиса:

/ докер-compose.yml:

services:
  postgres:
    image: postgres:9.6
    restart: always
    environment:
      POSTGRES_USER: kunzig #DockerHub postgres docs state this is optional but must be used when password is set.  It will also create a db under the supplied username which you'll use to connect to in rails console such as: $docker-compose exec postgres psql -U YourUserNameHere
      POSTGRES_PASSWORD: 'whateverPWYouWant'
    ports:
      - '5432' #Was originally 5432:5432 with the Left hand side being port on host machine, right hand side is the port on the docker container.  However I let docker choose the port it will use by supplying because 5432 is running on my local for other projects.  
    volumes:
      - postgres:/var/lib/postgresql/data 



  web:
    build: . #Runs the docker build command on the current directory
    links: #Links the listed services to our application so containers can talk to eachother
      - postgres
      - redis
    restart: always
    volumes:
      - .:/kunzig #Left hand side is current directory of compose file, right hand side is container folder.  This needs to be same as Install_path folder in Dockerfile.
    ports:
      - '8000:8000' #Left is the local port and the right side is the container port
    env_file:
      - .YourProjectNameHere.env #This should be in your root project directory along side the Dockerfile and docker-compose file
    depends_on:
      - 'redis'
      - 'postgres'

/. Projectname.env

DATABASE_URL=postgresql://PostgresUserNameHere:PasswordFromDockerCompose@postgres:5432/PostgresUsername?encoding=utf8&pool=5&timeout=5000

/ конфиг / database.yml

development:
  url: <%= ENV['DATABASE_URL'].gsub('?', '_development?' ) %>
test:
  url: <%= ENV['DATABASE_URL'].gsub('?', '_test?' ) %>
production:
  url: <%= ENV['DATABASE_URL'].gsub('?', '_production?' ) %>

Держите ваш веб-сервис связанным с сервисом pg, как он есть, и вы должны хорошо отметить, что вместо этого я позвонил в мой сервис postgres.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...