139 lines
3.0 KiB
YAML
139 lines
3.0 KiB
YAML
version: '3.8'
|
|
|
|
services:
|
|
# Nginx反向代理
|
|
nginx:
|
|
image: nginx:alpine
|
|
container_name: stockagent-nginx
|
|
restart: unless-stopped
|
|
ports:
|
|
- "80:80"
|
|
- "443:443"
|
|
volumes:
|
|
- ./nginx/nginx.conf:/etc/nginx/nginx.conf:ro
|
|
- ./nginx/ssl:/etc/nginx/ssl:ro
|
|
- ./logs/nginx:/var/log/nginx
|
|
depends_on:
|
|
- frontend
|
|
- backend
|
|
networks:
|
|
- stockagent-network
|
|
|
|
# Redis缓存服务
|
|
redis:
|
|
image: redis:7-alpine
|
|
container_name: stockagent-redis
|
|
restart: unless-stopped
|
|
ports:
|
|
- "127.0.0.1:6379:6379" # 只绑定到本地
|
|
volumes:
|
|
- redis_data:/data
|
|
- ./redis/redis.conf:/usr/local/etc/redis/redis.conf:ro
|
|
command: redis-server /usr/local/etc/redis/redis.conf
|
|
networks:
|
|
- stockagent-network
|
|
healthcheck:
|
|
test: ["CMD", "redis-cli", "ping"]
|
|
interval: 10s
|
|
timeout: 3s
|
|
retries: 3
|
|
deploy:
|
|
resources:
|
|
limits:
|
|
memory: 512M
|
|
reservations:
|
|
memory: 256M
|
|
|
|
# 后端API服务
|
|
backend:
|
|
build:
|
|
context: .
|
|
dockerfile: Dockerfile.backend
|
|
container_name: stockagent-backend
|
|
restart: unless-stopped
|
|
expose:
|
|
- "8000"
|
|
environment:
|
|
- TUSHARE_TOKEN=${TUSHARE_TOKEN}
|
|
- REDIS_HOST=redis
|
|
- REDIS_PORT=6379
|
|
- REDIS_DB=0
|
|
- API_HOST=0.0.0.0
|
|
- API_PORT=8090
|
|
- LOG_LEVEL=INFO
|
|
volumes:
|
|
- ./logs:/app/logs
|
|
- ./config:/app/config
|
|
depends_on:
|
|
redis:
|
|
condition: service_healthy
|
|
networks:
|
|
- stockagent-network
|
|
healthcheck:
|
|
test: ["CMD", "curl", "-f", "http://localhost:8090/"]
|
|
interval: 30s
|
|
timeout: 10s
|
|
retries: 3
|
|
start_period: 40s
|
|
deploy:
|
|
resources:
|
|
limits:
|
|
memory: 1G
|
|
cpus: '0.5'
|
|
reservations:
|
|
memory: 512M
|
|
cpus: '0.25'
|
|
|
|
# 前端Web服务
|
|
frontend:
|
|
build:
|
|
context: .
|
|
dockerfile: Dockerfile.frontend
|
|
container_name: stockagent-frontend
|
|
restart: unless-stopped
|
|
expose:
|
|
- "5001"
|
|
environment:
|
|
- API_BASE_URL=http://backend:8090/api
|
|
- FLASK_ENV=production
|
|
depends_on:
|
|
backend:
|
|
condition: service_healthy
|
|
networks:
|
|
- stockagent-network
|
|
healthcheck:
|
|
test: ["CMD", "curl", "-f", "http://localhost:5001/"]
|
|
interval: 30s
|
|
timeout: 10s
|
|
retries: 3
|
|
start_period: 20s
|
|
deploy:
|
|
resources:
|
|
limits:
|
|
memory: 256M
|
|
cpus: '0.25'
|
|
reservations:
|
|
memory: 128M
|
|
cpus: '0.1'
|
|
|
|
# 日志收集器(可选)
|
|
# logrotate:
|
|
# image: tutum/logrotate
|
|
# container_name: stockagent-logrotate
|
|
# restart: unless-stopped
|
|
# volumes:
|
|
# - ./logs:/logs
|
|
# environment:
|
|
# - LOGS_DIRECTORIES=/logs
|
|
|
|
# 网络配置
|
|
networks:
|
|
stockagent-network:
|
|
driver: bridge
|
|
name: stockagent-network
|
|
|
|
# 数据卷配置
|
|
volumes:
|
|
redis_data:
|
|
driver: local
|
|
name: stockagent-redis-data |