chore: 对齐测试与生产 Docker 配置
- 新增 .dockerignore,减少构建上下文体积 - 修复 Dockerfile 缺失 config/ 目录复制 - docker-compose.test.yml: DEBUG=false, ENV=production, SECRET_KEY 强制传入 - 新增 docker-compose.dev.yml(开发专用)和 docker-compose.prod.yml(生产专用) - deploy-test.sh: 加入 SECRET_KEY 强制检查,统一步骤编号
This commit is contained in:
@@ -0,0 +1,99 @@
|
||||
# =============================================================================
|
||||
# 美家卡智影 API - Docker 构建上下文排除列表
|
||||
# =============================================================================
|
||||
|
||||
# --- Git ---
|
||||
.git/
|
||||
.gitignore
|
||||
.gitattributes
|
||||
|
||||
# --- 环境变量(安全)---
|
||||
.env
|
||||
.env.*
|
||||
.env.local
|
||||
.env.example
|
||||
|
||||
# --- Python 虚拟环境 ---
|
||||
venv/
|
||||
env/
|
||||
ENV/
|
||||
.venv/
|
||||
|
||||
# --- Python 缓存 ---
|
||||
__pycache__/
|
||||
*.py[cod]
|
||||
*$py.class
|
||||
*.so
|
||||
.Python
|
||||
build/
|
||||
develop-eggs/
|
||||
dist/
|
||||
downloads/
|
||||
eggs/
|
||||
.eggs/
|
||||
lib/
|
||||
lib64/
|
||||
parts/
|
||||
sdist/
|
||||
var/
|
||||
wheels/
|
||||
*.egg-info/
|
||||
.installed.cfg
|
||||
*.egg
|
||||
.pytest_cache/
|
||||
.mypy_cache/
|
||||
.ruff_cache/
|
||||
|
||||
# --- 测试与覆盖率 ---
|
||||
tests/
|
||||
.coverage
|
||||
htmlcov/
|
||||
.tox/
|
||||
|
||||
# --- IDE / 编辑器 ---
|
||||
.idea/
|
||||
.vscode/
|
||||
*.swp
|
||||
*.swo
|
||||
*~
|
||||
.DS_Store
|
||||
|
||||
# --- 本地数据库与缓存 ---
|
||||
*.db
|
||||
*.sqlite3
|
||||
meijiaka.db
|
||||
dump.rdb
|
||||
celerybeat-schedule
|
||||
.qiniu_pythonsdk_hostscache.json
|
||||
|
||||
# --- 日志 ---
|
||||
*.log
|
||||
logs/
|
||||
|
||||
# --- Docker 自身 ---
|
||||
Dockerfile
|
||||
docker-compose.yml
|
||||
docker-compose.*.yml
|
||||
.dockerignore
|
||||
|
||||
# --- 部署脚本(仅本地使用)---
|
||||
deploy-test.sh
|
||||
scripts/upload_release.py
|
||||
|
||||
# --- 文档 ---
|
||||
README.md
|
||||
|
||||
# --- 临时/数据目录 ---
|
||||
data/
|
||||
local/
|
||||
temp/
|
||||
tmp/
|
||||
|
||||
# --- 开发配置 ---
|
||||
.pre-commit-config.yaml
|
||||
.python-version
|
||||
uv.lock
|
||||
|
||||
# --- Alembic 迁移版本(如不需要在容器内执行迁移可忽略)---
|
||||
# 注:若需在容器内运行 alembic upgrade,请注释掉下面这行
|
||||
# alembic/versions/
|
||||
@@ -63,7 +63,7 @@ celerybeat-schedule
|
||||
dump.rdb
|
||||
|
||||
# Docker
|
||||
.dockerignore
|
||||
!.dockerignore
|
||||
|
||||
# Local development
|
||||
local/
|
||||
|
||||
@@ -35,8 +35,9 @@ COPY --from=builder /opt/venv /opt/venv
|
||||
|
||||
WORKDIR /app
|
||||
|
||||
# 复制应用代码
|
||||
# 复制应用代码和配置
|
||||
COPY app/ ./app/
|
||||
COPY config/ ./config/
|
||||
COPY pyproject.toml .
|
||||
|
||||
EXPOSE 8000
|
||||
|
||||
@@ -17,7 +17,7 @@ GIT_REPO="http://git2.haodian.cn/xiaoyu/meijiaka-zy.git"
|
||||
API_PORT=8081
|
||||
|
||||
# 1. 检查 Docker
|
||||
echo "[1/6] 检查 Docker 环境..."
|
||||
echo "[1/7] 检查 Docker 环境..."
|
||||
if ! command -v docker &> /dev/null; then
|
||||
echo "Docker 未安装,请先安装 Docker"
|
||||
exit 1
|
||||
@@ -31,7 +31,7 @@ echo "Docker 版本: $(docker --version)"
|
||||
docker compose version || echo "docker-compose 版本: $(docker-compose --version)"
|
||||
|
||||
# 2. 克隆/更新代码
|
||||
echo "[2/6] 更新代码..."
|
||||
echo "[2/7] 更新代码..."
|
||||
if [ -d "$PROJECT_DIR/.git" ]; then
|
||||
cd "$PROJECT_DIR"
|
||||
git pull origin master
|
||||
@@ -41,7 +41,7 @@ else
|
||||
fi
|
||||
|
||||
# 3. 创建数据目录
|
||||
echo "[3/6] 创建数据目录..."
|
||||
echo "[3/7] 创建数据目录..."
|
||||
mkdir -p /opt/meijiaka-zy/data/{postgres,redis,logs}
|
||||
chmod 755 /opt/meijiaka-zy/data
|
||||
|
||||
@@ -64,7 +64,7 @@ fi
|
||||
|
||||
# 检查关键环境变量
|
||||
MISSING_VARS=()
|
||||
for var in VOLCENGINE_API_KEY KLINGAI_ACCESS_KEY KLINGAI_SECRET_KEY; do
|
||||
for var in SECRET_KEY VOLCENGINE_API_KEY KLINGAI_ACCESS_KEY KLINGAI_SECRET_KEY; do
|
||||
if ! grep -q "^$var=" .env || grep -q "^$var=\$" .env; then
|
||||
MISSING_VARS+=($var)
|
||||
fi
|
||||
|
||||
@@ -0,0 +1,63 @@
|
||||
# =============================================================================
|
||||
# 美家卡智影 API - 本地开发配置(开发专用)
|
||||
# =============================================================================
|
||||
# ⚠️ 此配置仅用于本地开发:
|
||||
# • 挂载源码目录(热重载)
|
||||
# • DEBUG=true
|
||||
# • 依赖外部 docker-infra 网络
|
||||
#
|
||||
# 测试/生产环境请使用:
|
||||
# • docker-compose.test.yml (All-in-One 测试服)
|
||||
# • docker-compose.prod.yml (生产:仅 api + scheduler)
|
||||
# =============================================================================
|
||||
|
||||
services:
|
||||
api:
|
||||
build:
|
||||
context: .
|
||||
dockerfile: Dockerfile
|
||||
container_name: meijiaka-zy-api-dev
|
||||
environment:
|
||||
- ENV=development
|
||||
- DEBUG=true
|
||||
- DATABASE_URL=postgresql+asyncpg://postgres:postgres@meijiaka-db:5432/meijiaka_zy
|
||||
- REDIS_HOST=meijiaka-redis
|
||||
- REDIS_PORT=6379
|
||||
- REDIS_DB=1
|
||||
- SECRET_KEY=dev-secret-key-change-in-production
|
||||
- MINIMAX_API_KEY=${MINIMAX_API_KEY}
|
||||
- MINIMAX_BASE_URL=${MINIMAX_BASE_URL:-https://api.minimaxi.com}
|
||||
- VIDU_API_KEY=${VIDU_API_KEY}
|
||||
- VIDU_BASE_URL=${VIDU_BASE_URL:-https://api.vidu.cn}
|
||||
volumes:
|
||||
- .:/app
|
||||
- ~/Documents/Meijiaka-zy:/root/Documents/Meijiaka-zy
|
||||
ports:
|
||||
- "8081:8000"
|
||||
command: uvicorn app.main:app --host 0.0.0.0 --port 8000 --reload
|
||||
networks:
|
||||
- meijiaka-network
|
||||
|
||||
scheduler:
|
||||
build:
|
||||
context: .
|
||||
dockerfile: Dockerfile
|
||||
container_name: meijiaka-zy-scheduler-dev
|
||||
environment:
|
||||
- ENV=development
|
||||
- DEBUG=true
|
||||
- DATABASE_URL=postgresql+asyncpg://postgres:postgres@meijiaka-db:5432/meijiaka_zy
|
||||
- REDIS_HOST=meijiaka-redis
|
||||
- REDIS_PORT=6379
|
||||
- REDIS_DB=1
|
||||
- SECRET_KEY=dev-secret-key-change-in-production
|
||||
volumes:
|
||||
- .:/app
|
||||
- ~/Documents/Meijiaka-zy:/root/Documents/Meijiaka-zy
|
||||
command: python -m app.scheduler.main
|
||||
networks:
|
||||
- meijiaka-network
|
||||
|
||||
networks:
|
||||
meijiaka-network:
|
||||
external: true
|
||||
@@ -0,0 +1,77 @@
|
||||
# =============================================================================
|
||||
# 美家卡智影 API - 生产环境配置
|
||||
# =============================================================================
|
||||
# 说明:
|
||||
# • 此配置仅运行 api + scheduler 服务
|
||||
# • 假设 PostgreSQL 和 Redis 由外部基础设施提供(云数据库 / 自建集群)
|
||||
# • 与测试环境使用**同一套 Dockerfile**,仅环境变量不同
|
||||
#
|
||||
# 用法:
|
||||
# export $(cat .env | xargs) # 或从 CI/CD / 密钥管理注入
|
||||
# docker compose -f docker-compose.prod.yml up -d --build
|
||||
# =============================================================================
|
||||
|
||||
services:
|
||||
api:
|
||||
build:
|
||||
context: .
|
||||
dockerfile: Dockerfile
|
||||
container_name: meijiaka-zy-api
|
||||
environment:
|
||||
- ENV=production
|
||||
- DEBUG=false
|
||||
- DATABASE_URL=${DATABASE_URL}
|
||||
- REDIS_HOST=${REDIS_HOST}
|
||||
- REDIS_PORT=${REDIS_PORT:-6379}
|
||||
- REDIS_DB=${REDIS_DB:-0}
|
||||
- SECRET_KEY=${SECRET_KEY}
|
||||
- VOLCENGINE_API_KEY=${VOLCENGINE_API_KEY}
|
||||
- VOLCENGINE_BASE_URL=${VOLCENGINE_BASE_URL:-https://ark.cn-beijing.volces.com/api/v3}
|
||||
- KLINGAI_ACCESS_KEY=${KLINGAI_ACCESS_KEY}
|
||||
- KLINGAI_SECRET_KEY=${KLINGAI_SECRET_KEY}
|
||||
- MINIMAX_API_KEY=${MINIMAX_API_KEY}
|
||||
- MINIMAX_BASE_URL=${MINIMAX_BASE_URL:-https://api.minimaxi.com}
|
||||
- VIDU_API_KEY=${VIDU_API_KEY}
|
||||
- VIDU_BASE_URL=${VIDU_BASE_URL:-https://api.vidu.cn}
|
||||
- ANYTOCOPY_API_KEY=${ANYTOCOPY_API_KEY}
|
||||
- ANYTOCOPY_API_SECRET=${ANYTOCOPY_API_SECRET}
|
||||
- QINIU_ACCESS_KEY=${QINIU_ACCESS_KEY}
|
||||
- QINIU_SECRET_KEY=${QINIU_SECRET_KEY}
|
||||
volumes:
|
||||
# 仅持久化日志到宿主机,其他数据走对象存储
|
||||
- /opt/meijiaka-zy/logs:/root/Documents/Meijiaka-zy/logs
|
||||
ports:
|
||||
- "8000:8000"
|
||||
restart: unless-stopped
|
||||
healthcheck:
|
||||
test: ["CMD-SHELL", "python -c \"import urllib.request; urllib.request.urlopen('http://localhost:8000/health')\""]
|
||||
interval: 30s
|
||||
timeout: 10s
|
||||
retries: 3
|
||||
start_period: 10s
|
||||
|
||||
scheduler:
|
||||
build:
|
||||
context: .
|
||||
dockerfile: Dockerfile
|
||||
container_name: meijiaka-zy-scheduler
|
||||
environment:
|
||||
- ENV=production
|
||||
- DEBUG=false
|
||||
- DATABASE_URL=${DATABASE_URL}
|
||||
- REDIS_HOST=${REDIS_HOST}
|
||||
- REDIS_PORT=${REDIS_PORT:-6379}
|
||||
- REDIS_DB=${REDIS_DB:-0}
|
||||
- SECRET_KEY=${SECRET_KEY}
|
||||
- VOLCENGINE_API_KEY=${VOLCENGINE_API_KEY}
|
||||
- KLINGAI_ACCESS_KEY=${KLINGAI_ACCESS_KEY}
|
||||
- KLINGAI_SECRET_KEY=${KLINGAI_SECRET_KEY}
|
||||
- MINIMAX_API_KEY=${MINIMAX_API_KEY}
|
||||
- VIDU_API_KEY=${VIDU_API_KEY}
|
||||
volumes:
|
||||
- /opt/meijiaka-zy/logs:/root/Documents/Meijiaka-zy/logs
|
||||
command: python -m app.scheduler.main
|
||||
restart: unless-stopped
|
||||
depends_on:
|
||||
api:
|
||||
condition: service_healthy
|
||||
@@ -47,13 +47,13 @@ services:
|
||||
dockerfile: Dockerfile
|
||||
container_name: meijiaka-zy-api
|
||||
environment:
|
||||
- ENV=staging
|
||||
- DEBUG=true
|
||||
- ENV=production
|
||||
- DEBUG=false
|
||||
- DATABASE_URL=postgresql+asyncpg://postgres:postgres@db:5432/meijiaka_zy
|
||||
- REDIS_HOST=redis
|
||||
- REDIS_PORT=6379
|
||||
- REDIS_DB=0
|
||||
- SECRET_KEY=${SECRET_KEY:-test-secret-key-change-me}
|
||||
- SECRET_KEY=${SECRET_KEY}
|
||||
- VOLCENGINE_API_KEY=${VOLCENGINE_API_KEY}
|
||||
- VOLCENGINE_BASE_URL=${VOLCENGINE_BASE_URL:-https://ark.cn-beijing.volces.com/api/v3}
|
||||
- KLINGAI_ACCESS_KEY=${KLINGAI_ACCESS_KEY}
|
||||
@@ -83,13 +83,13 @@ services:
|
||||
dockerfile: Dockerfile
|
||||
container_name: meijiaka-zy-scheduler
|
||||
environment:
|
||||
- ENV=staging
|
||||
- DEBUG=true
|
||||
- ENV=production
|
||||
- DEBUG=false
|
||||
- DATABASE_URL=postgresql+asyncpg://postgres:postgres@db:5432/meijiaka_zy
|
||||
- REDIS_HOST=redis
|
||||
- REDIS_PORT=6379
|
||||
- REDIS_DB=0
|
||||
- SECRET_KEY=${SECRET_KEY:-test-secret-key-change-me}
|
||||
- SECRET_KEY=${SECRET_KEY}
|
||||
- VOLCENGINE_API_KEY=${VOLCENGINE_API_KEY}
|
||||
- KLINGAI_ACCESS_KEY=${KLINGAI_ACCESS_KEY}
|
||||
- KLINGAI_SECRET_KEY=${KLINGAI_SECRET_KEY}
|
||||
|
||||
Reference in New Issue
Block a user