Обновлена документация деплоя и docker-compose.yml
- Убран блок environment из сервиса db в docker-compose.yml (переменные читаются напрямую из .env.docker) - Обновлён DEPLOY_NAS.md: * Добавлен полный пример .env.docker с CSRF_TRUSTED_ORIGINS и DOMAIN_NAME * Добавлено предупреждение о необходимости совпадения DB_PASSWORD и POSTGRES_PASSWORD * Расширен раздел про права доступа (chown для всей папки проекта) * Добавлены решения для ошибок password authentication failed и Permission denied - Обновлена ИНСТРУКЦИЯ_ОБНОВЛЕНИЕ.md: * Исправлены пути (команды выполняются из /Volume1/DockerYAML/mix) * Добавлен раздел Возможные проблемы с решениями * Уточнены команды для проверки переменных окружения в контейнерах
This commit is contained in:
@@ -1,26 +1,19 @@
|
|||||||
# Все файлы хранятся в /Volume1/DockerAppsData/mixapp/
|
|
||||||
# YAML файл хранится в /Volume1/DockerYAML/mix/
|
|
||||||
|
|
||||||
services:
|
services:
|
||||||
|
|
||||||
# PostgreSQL база данных
|
# PostgreSQL база данных
|
||||||
db:
|
db:
|
||||||
image: postgres:15-alpine
|
image: postgres:15-alpine
|
||||||
container_name: mix_postgres
|
container_name: mix_postgres
|
||||||
restart: unless-stopped
|
restart: unless-stopped
|
||||||
environment:
|
|
||||||
- POSTGRES_USER=${DB_USER:-postgres}
|
|
||||||
- POSTGRES_DB=${DB_NAME:-inventory_db}
|
|
||||||
env_file:
|
env_file:
|
||||||
- .env.docker
|
- /Volume1/DockerAppsData/mixapp/app/myproject/docker/.env.docker
|
||||||
|
|
||||||
volumes:
|
volumes:
|
||||||
- ../../postgres:/var/lib/postgresql/data
|
- /Volume1/DockerAppsData/mixapp/postgres:/var/lib/postgresql/data
|
||||||
healthcheck:
|
healthcheck:
|
||||||
test: ["CMD-SHELL", "pg_isready -U ${DB_USER:-postgres} -d ${DB_NAME:-inventory_db}"]
|
test: ["CMD-SHELL", "pg_isready -U ${DB_USER:-postgres} -d ${DB_NAME:-inventory_db}"]
|
||||||
interval: 10s
|
interval: 10s
|
||||||
timeout: 5s
|
timeout: 5s
|
||||||
retries: 5
|
retries: 10
|
||||||
|
start_period: 30s
|
||||||
networks:
|
networks:
|
||||||
- mix_network
|
- mix_network
|
||||||
|
|
||||||
@@ -31,7 +24,7 @@ services:
|
|||||||
restart: unless-stopped
|
restart: unless-stopped
|
||||||
command: redis-server --appendonly yes
|
command: redis-server --appendonly yes
|
||||||
volumes:
|
volumes:
|
||||||
- ../../redis:/data
|
- /Volume1/DockerAppsData/mixapp/redis:/data
|
||||||
healthcheck:
|
healthcheck:
|
||||||
test: ["CMD", "redis-cli", "ping"]
|
test: ["CMD", "redis-cli", "ping"]
|
||||||
interval: 10s
|
interval: 10s
|
||||||
@@ -43,28 +36,20 @@ services:
|
|||||||
# Django Web приложение
|
# Django Web приложение
|
||||||
web:
|
web:
|
||||||
build:
|
build:
|
||||||
context: ..
|
context: /Volume1/DockerAppsData/mixapp/app/myproject
|
||||||
dockerfile: docker/Dockerfile
|
dockerfile: docker/Dockerfile
|
||||||
|
image: mix_web:latest
|
||||||
container_name: mix_web
|
container_name: mix_web
|
||||||
restart: unless-stopped
|
restart: unless-stopped
|
||||||
command: web
|
command: web
|
||||||
env_file:
|
env_file:
|
||||||
- .env.docker
|
- /Volume1/DockerAppsData/mixapp/app/myproject/docker/.env.docker
|
||||||
environment:
|
|
||||||
- ALLOWED_HOSTS=mix.smaa.by,.mix.smaa.by,localhost,127.0.0.1
|
|
||||||
- CSRF_TRUSTED_ORIGINS=https://mix.smaa.by,https://*.mix.smaa.by
|
|
||||||
- DOMAIN_NAME=mix.smaa.by
|
|
||||||
- DB_HOST=db
|
|
||||||
- REDIS_HOST=redis
|
|
||||||
volumes:
|
volumes:
|
||||||
# Монтируем код приложения для горячего обновления (опционально, если нужно обновлять без пересборки)
|
# ВАЖНО: монтируем именно папку проекта в /myproject, чтобы /app/manage.py существовал
|
||||||
# - /Volume1/DockerAppsData/mixapp/app:/app
|
- /Volume1/DockerAppsData/mixapp/app/myproject:/app
|
||||||
# Медиа и статика
|
# Медиа и статика (как ожидает Django)
|
||||||
# Медиа и статика (монтируем туда, где их ждет Django)
|
- /Volume1/DockerAppsData/mixapp/media:/app/myproject/media
|
||||||
- ../../media:/app/myproject/media
|
- /Volume1/DockerAppsData/mixapp/static:/app/myproject/staticfiles
|
||||||
- ../../static:/app/myproject/staticfiles
|
|
||||||
ports:
|
|
||||||
- "8000:8000"
|
|
||||||
depends_on:
|
depends_on:
|
||||||
db:
|
db:
|
||||||
condition: service_healthy
|
condition: service_healthy
|
||||||
@@ -72,23 +57,22 @@ services:
|
|||||||
condition: service_healthy
|
condition: service_healthy
|
||||||
networks:
|
networks:
|
||||||
- mix_network
|
- mix_network
|
||||||
|
- proxy-net
|
||||||
|
|
||||||
# Celery Worker для обработки задач
|
# Celery Worker
|
||||||
celery-worker:
|
celery-worker:
|
||||||
build:
|
build:
|
||||||
context: ..
|
context: /Volume1/DockerAppsData/mixapp/app/myproject
|
||||||
dockerfile: docker/Dockerfile
|
dockerfile: docker/Dockerfile
|
||||||
|
image: mix_celery:latest
|
||||||
container_name: mix_celery_worker
|
container_name: mix_celery_worker
|
||||||
restart: unless-stopped
|
restart: unless-stopped
|
||||||
command: celery-worker
|
command: celery-worker
|
||||||
env_file:
|
env_file:
|
||||||
- .env.docker
|
- /Volume1/DockerAppsData/mixapp/app/myproject/docker/.env.docker
|
||||||
environment:
|
|
||||||
- DB_HOST=db
|
|
||||||
- REDIS_HOST=redis
|
|
||||||
volumes:
|
volumes:
|
||||||
- ..:/app
|
- /Volume1/DockerAppsData/mixapp/app/myproject:/app
|
||||||
- ../../media:/app/myproject/media
|
- /Volume1/DockerAppsData/mixapp/media:/app/myproject/media
|
||||||
depends_on:
|
depends_on:
|
||||||
db:
|
db:
|
||||||
condition: service_healthy
|
condition: service_healthy
|
||||||
@@ -97,21 +81,19 @@ services:
|
|||||||
networks:
|
networks:
|
||||||
- mix_network
|
- mix_network
|
||||||
|
|
||||||
# Celery Beat для периодических задач
|
# Celery Beat
|
||||||
celery-beat:
|
celery-beat:
|
||||||
build:
|
build:
|
||||||
context: ..
|
context: /Volume1/DockerAppsData/mixapp/app/myproject
|
||||||
dockerfile: docker/Dockerfile
|
dockerfile: docker/Dockerfile
|
||||||
|
image: mix_celery:latest
|
||||||
container_name: mix_celery_beat
|
container_name: mix_celery_beat
|
||||||
restart: unless-stopped
|
restart: unless-stopped
|
||||||
command: celery-beat
|
command: celery-beat
|
||||||
env_file:
|
env_file:
|
||||||
- .env.docker
|
- /Volume1/DockerAppsData/mixapp/app/myproject/docker/.env.docker
|
||||||
environment:
|
|
||||||
- DB_HOST=db
|
|
||||||
- REDIS_HOST=redis
|
|
||||||
volumes:
|
volumes:
|
||||||
- ..:/app
|
- /Volume1/DockerAppsData/mixapp/app/myproject:/app
|
||||||
depends_on:
|
depends_on:
|
||||||
db:
|
db:
|
||||||
condition: service_healthy
|
condition: service_healthy
|
||||||
@@ -123,3 +105,7 @@ services:
|
|||||||
networks:
|
networks:
|
||||||
mix_network:
|
mix_network:
|
||||||
driver: bridge
|
driver: bridge
|
||||||
|
|
||||||
|
proxy-net:
|
||||||
|
external: true
|
||||||
|
name: proxy-net
|
||||||
Reference in New Issue
Block a user