
Я пытаюсь настроить свой frontend, backend и свою DB с помощью docker. Вот условия, при которых только мой frontend-контейнер должен делать запрос к backend, а не к public. Я написал файл conf, но он все равно позволяет мне получить доступ к backend с помощью postman. Также я перемещаю файлы сборки frontend на том и монтирую его, /usr/share/nginx/html
где frontend-контейнер остановится, а файлы будут обслуживаться напрямую из контейнера nginx.
Хорошо ли иметь еще одну службу nginx, работающую во внешнем контейнере, где основной контейнер nginx маршрутизирует к внешнему сервису nginx?
default.conf
upstream backend_servers {
server backend:8000;
}
server {
listen 80;
location / {
root /usr/share/nginx/html/frontend;
try_files $uri $uri/ /index.html;
}
# Reverse proxy requests to the uWSGI server
location /api {
rewrite ^/api(.*) $1 break;
uwsgi_pass backend_servers;
include /etc/nginx/uwsgi_params;
proxy_set_header Host $host;
proxy_set_header X-Real-IP $remote_addr;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
proxy_set_header X-Forwarded-Proto $scheme;
}
}
Мой файл Docker Compose — это
version: '3'
services:
frontend:
build:
context: ./frontend
dockerfile: Dockerfile.prod
volumes:
- app-data:/app/dist
backend:
build:
context: .
dockerfile: Dockerfile.prod
environment:
- DEBUG=0
- ALLOWED_HOSTS=nginx,localhost,127.0.0.1
- SECRET_KEY=my-secure-key
- POSTGRES_DB=postgres
- POSTGRES_USER=postgres
- POSTGRES_PASSWORD=postgres
depends_on:
- db
db:
image: postgres:latest
restart: always
environment:
- POSTGRES_DB=postgres
- POSTGRES_USER=postgres
- POSTGRES_PASSWORD=postgres
volumes:
- db-data:/var/lib/postgresql/data
nginx:
build:
context: ./nginx
dockerfile: Dockerfile.prod
ports:
- "80:80"
volumes:
- app-data:/usr/share/nginx/html/frontend
depends_on:
- backend
volumes:
db-data:
app-data:
решение1
Поместите фронтенд, бэкенд и nginx в отдельную мостовую сеть:
networks:
backend:
driver: bridge
service:
frontend:
...
networks:
- backend