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

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

29.06.2022, 10:57. Показов 760. Ответов 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
Ответ Создать тему
Новые блоги и статьи
http://iceja.net/ математические сервисы
iceja 20.01.2026
Обновила свой сайт http:/ / iceja. net/ , приделала Fast Fourier Transform экстраполяцию сигналов. Однако предсказывает далеко не каждый сигнал (см ограничения http:/ / iceja. net/ fourier/ docs ). Также. . .
http://iceja.net/ сервер решения полиномов
iceja 18.01.2026
Выкатила http:/ / iceja. net/ сервер решения полиномов (находит действительные корни полиномов методом Штурма). На сайте документация по API, но скажу прямо VPS слабенький и 200 000 полиномов. . .
Расчёт переходных процессов в цепи постоянного тока
igorrr37 16.01.2026
/ * Дана цепь постоянного тока с R, L, C, k(ключ), U, E, J. Программа составляет систему уравнений по 1 и 2 законам Кирхгофа, решает её и находит переходные токи и напряжения на элементах схемы. . . .
Восстановить юзерскрипты Greasemonkey из бэкапа браузера
damix 15.01.2026
Если восстановить из бэкапа профиль Firefox после переустановки винды, то список юзерскриптов в Greasemonkey будет пустым. Но восстановить их можно так. Для этого понадобится консольная утилита. . .
Сукцессия микоризы: основная теория в виде двух уравнений.
anaschu 11.01.2026
https:/ / rutube. ru/ video/ 7a537f578d808e67a3c6fd818a44a5c4/
WordPad для Windows 11
Jel 10.01.2026
WordPad для Windows 11 — это приложение, которое восстанавливает классический текстовый редактор WordPad в операционной системе Windows 11. После того как Microsoft исключила WordPad из. . .
Classic Notepad for Windows 11
Jel 10.01.2026
Old Classic Notepad for Windows 11 Приложение для Windows 11, позволяющее пользователям вернуть классическую версию текстового редактора «Блокнот» из Windows 10. Программа предоставляет более. . .
Почему дизайн решает?
Neotwalker 09.01.2026
В современном мире, где конкуренция за внимание потребителя достигла пика, дизайн становится мощным инструментом для успеха бренда. Это не просто красивый внешний вид продукта или сайта — это. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru