Форум программистов, компьютерный форум, киберфорум
Python: Django
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.50/4: Рейтинг темы: голосов - 4, средняя оценка - 4.50
86 / 86 / 30
Регистрация: 12.08.2014
Сообщений: 1,129

Подлючиться к запущенной БД

29.06.2022, 10:57. Показов 775. Ответов 5
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Здравствуйте. Вопрос в заголовке, а проблема в следующем:

docker-compose.yml
Code
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
version: '3'
 
services:
  nginx:
    image: rodrigodiez/nginx-ssl-localhost
    ports:
      - 80:80
    volumes:
      - ./config/nginx/conf.d:/etc/nginx/conf.d
      - static_volume:/opt/services/app/static
    depends_on:
      - app
    networks:
      - nginx_network
 
  db:
    image: postgres:latest
    container_name: db
    environment:
      - POSTGRES_DB=app
      - POSTGRES_USER=user
      - POSTGRES_PASSWORD=pswd
      - POSTGRES_HOST_AUTH_METHOD=trust
      - POSTGRES_HOST=db
    networks:
      - db_network
    volumes:
      - db_volume:/var/lib/postgresql/data/
 
  app:
    restart: always
    build: .
    environment:
      - PYTHONUNBUFFERED=1
    volumes:
      - .:/opt/services/app/src
      - static_volume:/opt/services/app/static
    networks:
      - nginx_network
      - db_network
    depends_on:
      - db
    links:
      - db:db
 
networks:
  nginx_network:
    driver: bridge
  db_network:
    driver: bridge
 
volumes:
  db_volume:
  static_volume:
Dockerfile

Code
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
FROM python:3.9
 
RUN mkdir -p /opt/services/app/src
WORKDIR /opt/services/app/src
 
COPY requirements.txt /opt/services/app/src/
RUN pip install -r requirements.txt
 
COPY . /opt/services/app/src
 
RUN cd app && \
    python manage.py collectstatic --noinput && \
    python manage.py wait_for_database && \
    python manage.py makemigrations app && \
    python manage.py migrate --no-input
 
EXPOSE 80
CMD ["gunicorn", "--chdir", "app", "--bind", ":80", "app.wsgi:application"]
При попытке docker-compose up --build
получаю:
Code
1
Waiting for database (cause: could not translate host name "db" to address: Name or service not known)
и подключиться не выходит спустя минуты.
Если же отказаться от миграции, а в последюузем зайти в контейнер и выполнить все вручную - никаких проблем не возникает.
settings.py

Code
1
2
3
4
5
6
7
8
9
10
11
12
13
ALLOWED_HOSTS = [
    '0.0.0.0', '1.1.1.1', 'localhost', '127.0.0.1', 'db', 'nginx', 'database', 'db_network'
]
DATABASES = {
    'default': {
        'ENGINE': 'django.db.backends.postgresql_psycopg2',
        'NAME': 'app',
        'USER': 'user',
        'PASSWORD': 'pswd',
        'HOST': 'db',
        'PORT': 5432, # 5432
    }
}
Подскажите, как решить данную задачу?
0
Лучшие ответы (1)
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
29.06.2022, 10:57
Ответы с готовыми решениями:

Как подлючиться к базе на сервере?
Передо мной стала задача сделать на курсовой сетевое приложение. Поразмыслив не слишком большой промежуток времени я предположил что можно...

как дописать код, чтобы вводить s = "RRTGKTNTGRT" уже в запущенной программе, а также выбирать ch = 'T'; К примеру другой символ "R" в запущенной прог
Есть такой код: //--------------------------------------------------------------------------- #pragma hdrstop #include...

Показ запущенной программы
И снова вопросик) Как все знают Диспетчере W7 есть такая кнопка Переключится, он показывает программу которая запущена. а у меня проблема...

5
Эксперт по компьютерным сетям
 Аватар для Jabbson
5907 / 3359 / 1036
Регистрация: 03.11.2009
Сообщений: 10,008
29.06.2022, 16:11
есть это на гитхабе, чтобы повторить окружение?
1
86 / 86 / 30
Регистрация: 12.08.2014
Сообщений: 1,129
29.06.2022, 16:52  [ТС]
Цитата Сообщение от Jabbson Посмотреть сообщение
гитхаб
https://github.com/paskalnikita/project_test
0
Эксперт по компьютерным сетям
 Аватар для Jabbson
5907 / 3359 / 1036
Регистрация: 03.11.2009
Сообщений: 10,008
29.06.2022, 17:26
Проблема в том, что
python manage.py wait_for_database
происходит во время билда и контейнера с базой на этот момент еще нет.
1
86 / 86 / 30
Регистрация: 12.08.2014
Сообщений: 1,129
29.06.2022, 17:36  [ТС]
Цитата Сообщение от Jabbson Посмотреть сообщение
во время билда и контейнера с базой на этот момент еще нет
то есть, невозможно сначала запустить контейнер с базой, а потом сделать билд?

Добавлено через 4 минуты
то есть я хочу, чтобы при запуске всего, каждый раз изменеия в базу вносились "автоматом", одним compose все появлялось и обновленное приложение и миграции в БД. так вообще можно?
0
Эксперт по компьютерным сетям
 Аватар для Jabbson
5907 / 3359 / 1036
Регистрация: 03.11.2009
Сообщений: 10,008
29.06.2022, 17:36
Лучший ответ Сообщение было отмечено paskalnikita как решение

Решение

Нет, по крайней мере не композером. Но можно прогнать все ваши миграции при запуске, например через docker-entrypoint.sh, где выполнить миграции, а потом запустить gunicorn
1
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
29.06.2022, 17:36
Помогаю со студенческими работами здесь

Отмена запущенной задачи
И еще один вопросик давно меня мучает...:) У меня запущен длительный процесс (полный ночной backup данных) примерно на 60 мин....

Вылетает из запущенной программы
Нужна помощь, при сборке, все работает, но потом после ввода второго-третьего числа, окно закрывается. Кто подскажет, что делать? Вот...

Определить путь запущенной программы
Добрый вечер. Подскажите пожалуйста, как определить откуда были запущены программы. Раньше данный код работал foreach...

Посчитать CRC32 запущенной программы
Как посчитать контрольную сумму того же exe файла который в данный момент выполняется.

Получение лога запущенной программы
Есть программа запущенная таким образом: final ProcessBuilder gameProcessBuilder = new ProcessBuilder(); ...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
6
Ответ Создать тему
Новые блоги и статьи
делаю науч статью по влиянию грибов на сукцессию
anaschu 13.03.2026
прикрепляю статью
SDL3 для Desktop (MinGW): Создаём пустое окно с нуля для 2D-графики на SDL3, Си и C++
8Observer8 10.03.2026
Содержание блога Финальные проекты на Си и на C++: hello-sdl3-c. zip hello-sdl3-cpp. zip Результат:
Установка CMake и MinGW 13.1 для сборки С и C++ приложений из консоли и из Qt Creator в EXE
8Observer8 10.03.2026
Содержание блога MinGW - это коллекция инструментов для сборки приложений в EXE. CMake - это система сборки приложений. Здесь описаны базовые шаги для старта программирования с помощью CMake и. . .
Как дизайн сайта влияет на конверсию: 7 решений, которые реально повышают заявки
Neotwalker 08.03.2026
Многие до сих пор воспринимают дизайн сайта как “красивую оболочку”. На практике всё иначе: дизайн напрямую влияет на то, оставит человек заявку или уйдёт через несколько секунд. Даже если у вас. . .
Модульная разработка через nuget packages
DevAlt 07.03.2026
Сложившийся в . Net-среде способ разработки чаще всего предполагает монорепозиторий в котором находятся все исходники. При создании нового решения, мы просто добавляем нужные проекты и имеем. . .
Модульный подход на примере F#
DevAlt 06.03.2026
В блоге дяди Боба наткнулся на такое определение: В этой книге («Подход, основанный на вариантах использования») Ивар утверждает, что архитектура программного обеспечения — это структуры,. . .
Управление камерой с помощью скрипта OrbitControls.js на Three.js: Вращение, зум и панорамирование
8Observer8 05.03.2026
Содержание блога Финальная демка в браузере работает на Desktop и мобильных браузерах. Итоговый код: orbit-controls-threejs-js. zip. Сканируйте QR-код на мобильном. Вращайте камеру одним пальцем,. . .
SDL3 для Web (WebAssembly): Синхронизация спрайтов SDL3 и тел Box2D
8Observer8 04.03.2026
Содержание блога Финальная демка в браузере. Итоговый код: finish-sync-physics-sprites-sdl3-c. zip На первой гифке отладочные линии отключены, а на второй включены:. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru