Files
MuMuAINovel/docker-compose.yml
T

141 lines
4.8 KiB
YAML
Raw Normal View History

2025-10-30 11:14:43 +08:00
services:
2025-11-10 21:16:55 +08:00
postgres:
image: postgres:18-alpine
container_name: mumuainovel-postgres
environment:
2025-11-11 20:11:32 +08:00
POSTGRES_DB: ${POSTGRES_DB:-mumuai_novel}
POSTGRES_USER: ${POSTGRES_USER:-mumuai}
POSTGRES_PASSWORD: ${POSTGRES_PASSWORD:-123456}
2025-11-10 21:16:55 +08:00
POSTGRES_INITDB_ARGS: "--encoding=UTF8 --locale=C"
2025-11-11 20:11:32 +08:00
TZ: ${TZ:-Asia/Shanghai}
2025-11-10 21:16:55 +08:00
volumes:
- postgres_data:/var/lib/postgresql
2025-11-10 21:16:55 +08:00
- ./backend/scripts/init_postgres.sql:/docker-entrypoint-initdb.d/init.sql:ro
ports:
2025-11-11 20:11:32 +08:00
- "${POSTGRES_PORT:-5432}:5432"
2025-11-10 21:16:55 +08:00
restart: unless-stopped
healthcheck:
2025-11-11 20:11:32 +08:00
test: ["CMD-SHELL", "pg_isready -U ${POSTGRES_USER:-mumuai} -d ${POSTGRES_DB:-mumuai_novel}"]
2025-11-10 21:16:55 +08:00
interval: 10s
timeout: 5s
retries: 5
start_period: 10s
networks:
- ai-story-network
command:
- postgres
- -c
2025-11-11 20:11:32 +08:00
- max_connections=${POSTGRES_MAX_CONNECTIONS:-200}
2025-11-10 21:16:55 +08:00
- -c
2025-11-11 20:11:32 +08:00
- shared_buffers=${POSTGRES_SHARED_BUFFERS:-256MB}
2025-11-10 21:16:55 +08:00
- -c
2025-11-11 20:11:32 +08:00
- effective_cache_size=${POSTGRES_EFFECTIVE_CACHE_SIZE:-1GB}
2025-11-10 21:16:55 +08:00
- -c
2025-11-11 20:11:32 +08:00
- maintenance_work_mem=${POSTGRES_MAINTENANCE_WORK_MEM:-64MB}
2025-11-10 21:16:55 +08:00
- -c
2025-11-11 20:11:32 +08:00
- checkpoint_completion_target=${POSTGRES_CHECKPOINT_COMPLETION_TARGET:-0.9}
2025-11-10 21:16:55 +08:00
- -c
2025-11-11 20:11:32 +08:00
- wal_buffers=${POSTGRES_WAL_BUFFERS:-16MB}
2025-11-10 21:16:55 +08:00
- -c
2025-11-11 20:11:32 +08:00
- default_statistics_target=${POSTGRES_DEFAULT_STATISTICS_TARGET:-100}
2025-11-10 21:16:55 +08:00
- -c
2025-11-11 20:11:32 +08:00
- random_page_cost=${POSTGRES_RANDOM_PAGE_COST:-1.1}
2025-11-10 21:16:55 +08:00
- -c
2025-11-11 20:11:32 +08:00
- effective_io_concurrency=${POSTGRES_EFFECTIVE_IO_CONCURRENCY:-200}
2025-11-10 21:16:55 +08:00
- -c
2025-11-11 20:11:32 +08:00
- work_mem=${POSTGRES_WORK_MEM:-4MB}
2025-11-10 21:16:55 +08:00
- -c
2025-11-11 20:11:32 +08:00
- min_wal_size=${POSTGRES_MIN_WAL_SIZE:-1GB}
2025-11-10 21:16:55 +08:00
- -c
2025-11-11 20:11:32 +08:00
- max_wal_size=${POSTGRES_MAX_WAL_SIZE:-4GB}
2025-11-10 21:16:55 +08:00
2025-11-06 16:15:08 +08:00
mumuainovel:
2025-10-30 11:14:43 +08:00
build:
context: .
dockerfile: Dockerfile
2026-04-29 08:53:22 +08:00
image: mumujie/mumuainovel:latest
2025-11-06 16:15:08 +08:00
container_name: mumuainovel
2025-11-10 21:16:55 +08:00
depends_on:
postgres:
condition: service_healthy
2025-10-30 11:14:43 +08:00
ports:
2025-11-11 20:11:32 +08:00
- "${APP_PORT:-8000}:8000"
2025-10-30 11:14:43 +08:00
volumes:
- ./logs:/app/logs
2026-03-17 16:04:53 +08:00
- ./storage/generated_covers:/app/storage/generated_covers
2025-10-30 11:14:43 +08:00
- ./.env:/app/.env:ro
environment:
# 应用配置
2025-11-11 20:11:32 +08:00
- APP_NAME=${APP_NAME:-MuMuAINovel}
- APP_VERSION=${APP_VERSION:-1.0.0}
- APP_HOST=${APP_HOST:-0.0.0.0}
2025-10-30 11:14:43 +08:00
- APP_PORT=8000
2025-11-11 20:11:32 +08:00
- DEBUG=${DEBUG:-false}
2025-10-30 11:14:43 +08:00
2025-11-11 20:11:32 +08:00
# 数据库配置
- DATABASE_URL=postgresql+asyncpg://${POSTGRES_USER:-mumuai}:${POSTGRES_PASSWORD:-123456}@postgres:5432/${POSTGRES_DB:-mumuai_novel}
2025-11-10 21:16:55 +08:00
# 数据库连接信息(用于 entrypoint.sh
- DB_HOST=postgres
- DB_PORT=5432
- POSTGRES_PASSWORD=${POSTGRES_PASSWORD:-123456}
2025-11-11 20:11:32 +08:00
# PostgreSQL 连接池配置
- DATABASE_POOL_SIZE=${DATABASE_POOL_SIZE:-30}
- DATABASE_MAX_OVERFLOW=${DATABASE_MAX_OVERFLOW:-20}
- DATABASE_POOL_TIMEOUT=${DATABASE_POOL_TIMEOUT:-60}
- DATABASE_POOL_RECYCLE=${DATABASE_POOL_RECYCLE:-1800}
- DATABASE_POOL_PRE_PING=${DATABASE_POOL_PRE_PING:-True}
- DATABASE_POOL_USE_LIFO=${DATABASE_POOL_USE_LIFO:-True}
2025-11-10 21:16:55 +08:00
2025-11-11 20:11:32 +08:00
# 代理配置(可选)
- HTTP_PROXY=${HTTP_PROXY:-}
- HTTPS_PROXY=${HTTPS_PROXY:-}
- NO_PROXY=${NO_PROXY:-localhost,127.0.0.1}
2025-10-30 11:14:43 +08:00
2025-11-11 20:11:32 +08:00
# AI 服务配置
- OPENAI_API_KEY=${OPENAI_API_KEY:-}
- OPENAI_BASE_URL=${OPENAI_BASE_URL:-https://api.openai.com/v1}
- GEMINI_API_KEY=${GEMINI_API_KEY:-}
- GEMINI_BASE_URL=${GEMINI_BASE_URL:-}
- ANTHROPIC_API_KEY=${ANTHROPIC_API_KEY:-}
- ANTHROPIC_BASE_URL=${ANTHROPIC_BASE_URL:-}
- DEFAULT_AI_PROVIDER=${DEFAULT_AI_PROVIDER:-openai}
- DEFAULT_MODEL=${DEFAULT_MODEL:-gpt-4o-mini}
- DEFAULT_TEMPERATURE=${DEFAULT_TEMPERATURE:-0.7}
- DEFAULT_MAX_TOKENS=${DEFAULT_MAX_TOKENS:-32000}
2025-10-30 11:14:43 +08:00
2025-11-11 20:11:32 +08:00
# LinuxDO OAuth 配置
2025-11-12 10:44:13 +08:00
- LINUXDO_CLIENT_ID=${LINUXDO_CLIENT_ID:-11111}
- LINUXDO_CLIENT_SECRET=${LINUXDO_CLIENT_SECRET:-11111}
- LINUXDO_REDIRECT_URI=${LINUXDO_REDIRECT_URI:-http://localhost:8000/api/auth/linuxdo/callback}
2025-11-11 20:11:32 +08:00
- FRONTEND_URL=${FRONTEND_URL:-http://localhost:8000}
# 本地账户登录配置
- LOCAL_AUTH_ENABLED=${LOCAL_AUTH_ENABLED:-true}
- LOCAL_AUTH_USERNAME=${LOCAL_AUTH_USERNAME:-admin}
- LOCAL_AUTH_PASSWORD=${LOCAL_AUTH_PASSWORD:-admin123}
- LOCAL_AUTH_DISPLAY_NAME=${LOCAL_AUTH_DISPLAY_NAME:-本地管理员}
# 会话配置
- SESSION_EXPIRE_MINUTES=${SESSION_EXPIRE_MINUTES:-120}
- SESSION_REFRESH_THRESHOLD_MINUTES=${SESSION_REFRESH_THRESHOLD_MINUTES:-30}
2025-10-30 11:14:43 +08:00
restart: unless-stopped
healthcheck:
test: ["CMD", "python", "-c", "import urllib.request; urllib.request.urlopen('http://localhost:8000/health')"]
interval: 30s
timeout: 10s
retries: 3
2025-11-10 21:16:55 +08:00
start_period: 30s
2025-10-30 11:14:43 +08:00
networks:
- ai-story-network
2025-11-10 21:16:55 +08:00
volumes:
postgres_data:
driver: local
2025-10-30 11:14:43 +08:00
networks:
ai-story-network:
driver: bridge
2025-11-10 21:16:55 +08:00