72 lines
1.5 KiB
YAML
72 lines
1.5 KiB
YAML
services:
|
|
nginx:
|
|
image: nginx:alpine
|
|
container_name: sentinel-nginx
|
|
restart: unless-stopped
|
|
ports:
|
|
- "8016:80"
|
|
depends_on:
|
|
- sentinel-app
|
|
volumes:
|
|
- ./nginx/nginx.conf:/etc/nginx/nginx.conf:ro
|
|
- ./frontend/dist:/etc/nginx/html/admin/ui:ro
|
|
networks:
|
|
- sentinel-net
|
|
|
|
sentinel-app:
|
|
build:
|
|
context: .
|
|
dockerfile: Dockerfile
|
|
image: key-ip-sentinel:latest
|
|
container_name: sentinel-app
|
|
restart: unless-stopped
|
|
env_file:
|
|
- .env
|
|
depends_on:
|
|
- redis
|
|
- postgres
|
|
networks:
|
|
- sentinel-net
|
|
- shared_network
|
|
|
|
redis:
|
|
image: redis:7-alpine
|
|
container_name: sentinel-redis
|
|
restart: unless-stopped
|
|
command:
|
|
[
|
|
"sh",
|
|
"-c",
|
|
"if [ -n \"$REDIS_PASSWORD\" ]; then exec redis-server --requirepass \"$REDIS_PASSWORD\"; else exec redis-server; fi"
|
|
]
|
|
env_file:
|
|
- .env
|
|
volumes:
|
|
- redis_data:/data
|
|
networks:
|
|
- sentinel-net
|
|
|
|
postgres:
|
|
image: postgres:16
|
|
container_name: sentinel-postgres
|
|
restart: unless-stopped
|
|
environment:
|
|
POSTGRES_USER: sentinel
|
|
POSTGRES_PASSWORD: password
|
|
POSTGRES_DB: sentinel
|
|
volumes:
|
|
- pg_data:/var/lib/postgresql/data
|
|
- ./db/init.sql:/docker-entrypoint-initdb.d/init.sql:ro
|
|
networks:
|
|
- sentinel-net
|
|
|
|
volumes:
|
|
redis_data:
|
|
pg_data:
|
|
|
|
networks:
|
|
sentinel-net:
|
|
driver: bridge
|
|
shared_network:
|
|
external: true
|