Files
life-echo/api/docker-compose.yml

135 lines
3.2 KiB
YAML
Raw Normal View History

version: '3.8'
services:
# Redis 服务(用于会话存储和 Celery 消息队列)
redis:
image: redis:7-alpine
container_name: life-echo-redis
ports:
- "6379:6379"
volumes:
- redis_data:/data
command: redis-server --appendonly yes --maxmemory 256mb --maxmemory-policy allkeys-lru
restart: always
healthcheck:
test: ["CMD", "redis-cli", "ping"]
interval: 10s
timeout: 5s
retries: 5
networks:
- life-echo-network
logging:
driver: "json-file"
options:
max-size: "10m"
max-file: "3"
# FastAPI 应用
api:
build:
context: .
dockerfile: Dockerfile
image: life-echo-api:latest
container_name: life-echo-api-prod
ports:
- "8000:8000"
env_file:
- .env.prod
environment:
- REDIS_URL=redis://redis:6379/0
volumes:
- ./life_echo.db:/app/life_echo.db
restart: always
depends_on:
redis:
condition: service_healthy
healthcheck:
test: ["CMD", "python", "-c", "import http.client; conn = http.client.HTTPConnection('localhost', 8000); conn.request('GET', '/health'); r = conn.getresponse(); exit(0 if r.status == 200 else 1)"]
interval: 30s
timeout: 10s
retries: 3
start_period: 10s
networks:
- life-echo-network
logging:
driver: "json-file"
options:
max-size: "10m"
max-file: "3"
# Celery Worker后台任务处理
celery-worker:
build:
context: .
dockerfile: Dockerfile
image: life-echo-api:latest
container_name: life-echo-celery-worker
command: celery -A tasks.celery_app worker --loglevel=info --concurrency=4
env_file:
- .env.prod
environment:
- REDIS_URL=redis://redis:6379/0
volumes:
- ./life_echo.db:/app/life_echo.db
restart: always
depends_on:
redis:
condition: service_healthy
api:
condition: service_healthy
networks:
- life-echo-network
logging:
driver: "json-file"
options:
max-size: "10m"
max-file: "3"
# Celery Beat定时任务调度可选
# celery-beat:
# build:
# context: .
# dockerfile: Dockerfile
# image: life-echo-api:latest
# container_name: life-echo-celery-beat
# command: celery -A tasks.celery_app beat --loglevel=info
# env_file:
# - .env.prod
# environment:
# - REDIS_URL=redis://redis:6379/0
# restart: always
# depends_on:
# redis:
# condition: service_healthy
# networks:
# - life-echo-network
# FlowerCelery 监控面板,可选)
# flower:
# build:
# context: .
# dockerfile: Dockerfile
# image: life-echo-api:latest
# container_name: life-echo-flower
# command: celery -A tasks.celery_app flower --port=5555
# ports:
# - "5555:5555"
# env_file:
# - .env.prod
# environment:
# - REDIS_URL=redis://redis:6379/0
# restart: always
# depends_on:
# redis:
# condition: service_healthy
# networks:
# - life-echo-network
networks:
life-echo-network:
driver: bridge
volumes:
redis_data:
driver: local