feat: add production docker-compose with hrynco-services network
- Base compose: explicit internal network, named volumes with VOLUME_PREFIX - docker-compose.prod.yml: production images, ports, restart policies, hrynco-services external network on rabbitmq - docker-compose.Development.yml: cleaned up orphan volumes, named dev volumes Co-authored-by: Copilot <223556219+Copilot@users.noreply.github.com>
This commit is contained in:
@@ -6,7 +6,7 @@ services:
|
||||
context: ../..
|
||||
dockerfile: HrynCo.NotificationService.Migrator/Dockerfile
|
||||
environment:
|
||||
- App__ConnectionString=${CONNECTION_STRING}
|
||||
- App__ConnectionString=Host=db;Port=5432;Database=${DB_NAME:?DB_NAME is required};Username=${DB_USER:?DB_USER is required};Password=${DB_PASS:?DB_PASS is required}
|
||||
depends_on:
|
||||
db:
|
||||
condition: service_started
|
||||
@@ -18,7 +18,7 @@ services:
|
||||
dockerfile: HrynCo.NotificationService.Web/Dockerfile
|
||||
environment:
|
||||
- ASPNETCORE_ENVIRONMENT=Production
|
||||
- App__ConnectionString=${CONNECTION_STRING}
|
||||
- App__ConnectionString=Host=db;Port=5432;Database=${DB_NAME:?DB_NAME is required};Username=${DB_USER:?DB_USER is required};Password=${DB_PASS:?DB_PASS is required}
|
||||
depends_on:
|
||||
db:
|
||||
condition: service_started
|
||||
@@ -31,10 +31,11 @@ services:
|
||||
dockerfile: HrynCo.NotificationService.Worker/Dockerfile
|
||||
environment:
|
||||
- DOTNET_ENVIRONMENT=Production
|
||||
- App__ConnectionString=${CONNECTION_STRING}
|
||||
- App__ConnectionString=Host=db;Port=5432;Database=${DB_NAME:?DB_NAME is required};Username=${DB_USER:?DB_USER is required};Password=${DB_PASS:?DB_PASS is required}
|
||||
- App__RabbitMq__Host=rabbitmq
|
||||
- App__RabbitMq__User=${RABBITMQ_USER:-guest}
|
||||
- App__RabbitMq__Password=${RABBITMQ_PASSWORD:-guest}
|
||||
- App__RabbitMq__Port=5672
|
||||
- App__RabbitMq__User=${RABBITMQ_USER:?RABBITMQ_USER is required}
|
||||
- App__RabbitMq__Password=${RABBITMQ_PASSWORD:?RABBITMQ_PASSWORD is required}
|
||||
depends_on:
|
||||
db:
|
||||
condition: service_started
|
||||
@@ -46,10 +47,38 @@ services:
|
||||
rabbitmq:
|
||||
image: rabbitmq:4-management-alpine
|
||||
environment:
|
||||
RABBITMQ_DEFAULT_USER: ${RABBITMQ_USER:-guest}
|
||||
RABBITMQ_DEFAULT_PASS: ${RABBITMQ_PASSWORD:-guest}
|
||||
RABBITMQ_DEFAULT_USER: ${RABBITMQ_USER:?RABBITMQ_USER is required}
|
||||
RABBITMQ_DEFAULT_PASS: ${RABBITMQ_PASSWORD:?RABBITMQ_PASSWORD is required}
|
||||
ports:
|
||||
- "${RABBITMQ_AMQP_PORT:?RABBITMQ_AMQP_PORT is required}:5672"
|
||||
- "${RABBITMQ_MANAGEMENT_PORT:?RABBITMQ_MANAGEMENT_PORT is required}:15672"
|
||||
volumes:
|
||||
- rabbitmq_data:/var/lib/rabbitmq
|
||||
networks:
|
||||
- internal
|
||||
healthcheck:
|
||||
test: ["CMD", "rabbitmq-diagnostics", "ping"]
|
||||
interval: 10s
|
||||
timeout: 5s
|
||||
retries: 5
|
||||
retries: 5
|
||||
|
||||
db:
|
||||
image: postgres:17
|
||||
environment:
|
||||
- POSTGRES_DB=${DB_NAME:?DB_NAME is required}
|
||||
- POSTGRES_USER=${DB_USER:?DB_USER is required}
|
||||
- POSTGRES_PASSWORD=${DB_PASS:?DB_PASS is required}
|
||||
volumes:
|
||||
- pgdata:/var/lib/postgresql/data
|
||||
networks:
|
||||
- internal
|
||||
|
||||
volumes:
|
||||
pgdata:
|
||||
name: ${VOLUME_PREFIX:?VOLUME_PREFIX is required}-pgdata
|
||||
rabbitmq_data:
|
||||
name: ${VOLUME_PREFIX:?VOLUME_PREFIX is required}-rabbitmq-data
|
||||
|
||||
networks:
|
||||
internal:
|
||||
driver: bridge
|
||||
Reference in New Issue
Block a user