126 lines
3.3 KiB
YAML
126 lines
3.3 KiB
YAML
# =============================================
|
|
# DeepAudit 生产环境一键部署配置
|
|
# =============================================
|
|
# 使用预构建的 GHCR 镜像,无需本地构建
|
|
# 部署命令: curl -fsSL https://raw.githubusercontent.com/lintsinghua/DeepAudit/main/docker-compose.prod.yml | docker compose -f - up -d
|
|
|
|
services:
|
|
db:
|
|
image: postgres:15-alpine
|
|
restart: unless-stopped
|
|
volumes:
|
|
- postgres_data:/var/lib/postgresql/data
|
|
environment:
|
|
- POSTGRES_USER=postgres
|
|
- POSTGRES_PASSWORD=postgres
|
|
- POSTGRES_DB=deepaudit
|
|
healthcheck:
|
|
test: [ "CMD-SHELL", "pg_isready -U postgres" ]
|
|
interval: 5s
|
|
timeout: 5s
|
|
retries: 5
|
|
networks:
|
|
- deepaudit-network
|
|
|
|
redis:
|
|
image: redis:7-alpine
|
|
restart: unless-stopped
|
|
volumes:
|
|
- redis_data:/data
|
|
healthcheck:
|
|
test: [ "CMD", "redis-cli", "ping" ]
|
|
interval: 10s
|
|
timeout: 5s
|
|
retries: 5
|
|
networks:
|
|
- deepaudit-network
|
|
|
|
backend:
|
|
image: sl.vrgon.com:3000/zk_senlan/codereview:backend
|
|
restart: unless-stopped
|
|
volumes:
|
|
- backend_uploads:/app/uploads
|
|
- chroma_data:/app/data/vector_db
|
|
- ci_workspace:/app/data/ci_workspace
|
|
- ci_vectordb:/app/data/ci_vectordb
|
|
- /var/run/docker.sock:/var/run/docker.sock
|
|
ports:
|
|
- "8000:8000"
|
|
environment:
|
|
- DATABASE_URL=postgresql+asyncpg://postgres:postgres@db:5432/deepaudit
|
|
- REDIS_URL=redis://redis:6379/0
|
|
- AGENT_ENABLED=true
|
|
- SANDBOX_ENABLED=true
|
|
- SANDBOX_IMAGE=sl.vrgon.com:3000/zk_senlan/codereview:sandbox
|
|
# LLM 配置 - 请根据需要修改
|
|
- LLM_PROVIDER=${LLM_PROVIDER:-openai}
|
|
- LLM_MODEL=${LLM_MODEL:-gpt-4o}
|
|
- LLM_API_KEY=${LLM_API_KEY:-your-api-key-here}
|
|
- LLM_BASE_URL=${LLM_BASE_URL:-}
|
|
# 禁用代理 - 必须同时设置大小写变量
|
|
- HTTP_PROXY=
|
|
- HTTPS_PROXY=
|
|
- http_proxy=
|
|
- https_proxy=
|
|
- all_proxy=
|
|
- ALL_PROXY=
|
|
- NO_PROXY=*
|
|
- no_proxy=*
|
|
depends_on:
|
|
db:
|
|
condition: service_healthy
|
|
redis:
|
|
condition: service_healthy
|
|
db-migrate:
|
|
condition: service_completed_successfully
|
|
networks:
|
|
- deepaudit-network
|
|
|
|
# 数据库迁移服务 - 在后端启动前自动执行
|
|
db-migrate:
|
|
image: sl.vrgon.com:3000/zk_senlan/codereview:backend
|
|
restart: "no"
|
|
environment:
|
|
- DATABASE_URL=postgresql+asyncpg://postgres:postgres@db:5432/deepaudit
|
|
command: [ ".venv/bin/alembic", "upgrade", "head" ]
|
|
depends_on:
|
|
db:
|
|
condition: service_healthy
|
|
networks:
|
|
- deepaudit-network
|
|
|
|
frontend:
|
|
image: sl.vrgon.com:3000/zk_senlan/codereview:frontend
|
|
restart: unless-stopped
|
|
ports:
|
|
- "83:80" # Nginx 监听 80 端口
|
|
environment:
|
|
# 禁用代理 - nginx 需要直连后端
|
|
- HTTP_PROXY=
|
|
- HTTPS_PROXY=
|
|
- http_proxy=
|
|
- https_proxy=
|
|
- NO_PROXY=*
|
|
depends_on:
|
|
- backend
|
|
networks:
|
|
- deepaudit-network
|
|
|
|
# 预拉取沙箱镜像(后端会按需调用)
|
|
sandbox-pull:
|
|
image: sl.vrgon.com:3000/zk_senlan/codereview:sandbox
|
|
restart: "no"
|
|
command: echo "Sandbox image ready"
|
|
|
|
networks:
|
|
deepaudit-network:
|
|
driver: bridge
|
|
|
|
volumes:
|
|
postgres_data:
|
|
backend_uploads:
|
|
chroma_data:
|
|
ci_workspace:
|
|
ci_vectordb:
|
|
redis_data:
|