优化docker容器

This commit is contained in:
2026-03-17 10:29:22 +08:00
parent 8acb8a3d2a
commit 38e8ace5ae
6 changed files with 138 additions and 232 deletions

8
backend/.dockerignore Normal file
View File

@@ -0,0 +1,8 @@
venv/
__pycache__/
*.pyc
.pytest_cache/
.env
.env.local
*.db
tests/

View File

@@ -1,103 +1,51 @@
# Base stage for all Python services # ============================================================
# Weibo-HotSign Backend Multi-Stage Dockerfile
# 构建目标: auth-service, api-service
# ============================================================
# ---- 基础层 ----
FROM python:3.11-slim AS base FROM python:3.11-slim AS base
# Set working directory
WORKDIR /app WORKDIR /app
# Install common system dependencies for MySQL RUN apt-get update && apt-get install -y --no-install-recommends \
RUN apt-get update && apt-get install -y \ gcc default-libmysqlclient-dev curl \
gcc \
default-libmysqlclient-dev \
&& rm -rf /var/lib/apt/lists/* && rm -rf /var/lib/apt/lists/*
# Copy and install unified requirements
COPY requirements.txt . COPY requirements.txt .
RUN pip install --no-cache-dir -r requirements.txt RUN pip install --no-cache-dir -r requirements.txt
# Create non-root user for security # 复制共享模块
COPY shared/ ./shared/
RUN groupadd -r appuser && useradd -r -g appuser appuser RUN groupadd -r appuser && useradd -r -g appuser appuser
# --- API Gateway Service Stage --- # ---- Auth Service ----
FROM base AS api_gateway FROM base AS auth-service
# Copy shared module COPY auth_service/ ./auth_service/
COPY shared/ ./shared/
# Copy application code ENV PYTHONPATH=/app
COPY api_service/app/ ./app/
# Switch to non-root user
USER appuser USER appuser
EXPOSE 8001
# Expose port HEALTHCHECK --interval=30s --timeout=10s --retries=3 \
CMD curl -f http://localhost:8001/health || exit 1
CMD ["uvicorn", "auth_service.app.main:app", "--host", "0.0.0.0", "--port", "8001"]
# ---- API Service ----
FROM base AS api-service
COPY api_service/ ./api_service/
ENV PYTHONPATH=/app
USER appuser
EXPOSE 8000 EXPOSE 8000
# Health check HEALTHCHECK --interval=30s --timeout=10s --retries=3 \
HEALTHCHECK --interval=30s --timeout=30s --start-period=5s --retries=3 \
CMD curl -f http://localhost:8000/health || exit 1 CMD curl -f http://localhost:8000/health || exit 1
# Start application CMD ["uvicorn", "api_service.app.main:app", "--host", "0.0.0.0", "--port", "8000"]
CMD ["uvicorn", "app.main:app", "--host", "0.0.0.0", "--port", "8000"]
# --- Auth Service Stage ---
FROM base AS auth_service
# Copy shared module
COPY shared/ ./shared/
# Copy application code
COPY auth_service/app/ ./app/
# Switch to non-root user
USER appuser
# Expose port
EXPOSE 8000
# Health check
HEALTHCHECK --interval=30s --timeout=30s --start-period=5s --retries=3 \
CMD curl -f http://localhost:8000/health || exit 1
# Start application
CMD ["python", "-m", "app.main"]
# --- Task Scheduler Service Stage ---
FROM base AS task_scheduler
# Copy shared module
COPY shared/ ./shared/
# Copy application code
COPY task_scheduler/app/ ./app/
# Switch to non-root user
USER appuser
# Start Celery Beat scheduler
CMD ["celery", "-A", "app.celery_app", "beat", "--loglevel=info"]
# --- Sign-in Executor Service Stage ---
FROM base AS signin_executor
# Copy shared module
COPY shared/ ./shared/
# Copy application code
COPY signin_executor/app/ ./app/
# Switch to non-root user
USER appuser
# Expose port
EXPOSE 8000
# Health check
HEALTHCHECK --interval=30s --timeout=30s --start-period=5s --retries=3 \
CMD curl -f http://localhost:8000/health || exit 1
# Start application
CMD ["python", "-m", "app.main"]

View File

@@ -1,170 +1,85 @@
version: '3.8' version: '3.8'
# ============================================================
# Weibo-HotSign Docker Compose
# 使用方式:
# 1. 填写下方 x-db-env 中的 MySQL/Redis 密码
# 2. docker-compose up -d --build
# 3. 访问 http://localhost:5000
# ============================================================
# 共享环境变量(避免重复)
x-db-env: &db-env
DATABASE_URL: "mysql+aiomysql://weibo:123456@host.docker.internal:3306/weibo_hotsign?charset=utf8mb4"
REDIS_URL: "redis://:123456@host.docker.internal:6379/0"
USE_REDIS: "true"
JWT_SECRET_KEY: "change-me-to-a-random-string-in-production"
JWT_ALGORITHM: "HS256"
JWT_EXPIRATION_HOURS: "24"
COOKIE_ENCRYPTION_KEY: "change-me-to-a-32byte-key-prod!"
WX_APPID: ""
WX_SECRET: ""
ENVIRONMENT: "production"
services: services:
# Redis缓存服务 # 认证服务 (端口 8001)
redis: auth-service:
image: redis:7-alpine build:
container_name: weibo-redis context: ./backend
dockerfile: Dockerfile
target: auth-service
container_name: weibo-auth
restart: unless-stopped
ports: ports:
- "6379:6379" - "8001:8001"
volumes: environment:
- redis_data:/data <<: *db-env
extra_hosts:
- "host.docker.internal:host-gateway"
networks: networks:
- weibo-network - weibo-net
# Nginx反向代理 # API 服务 (端口 8000)
nginx: api-service:
image: nginx:alpine build:
container_name: weibo-nginx context: ./backend
dockerfile: Dockerfile
target: api-service
container_name: weibo-api
restart: unless-stopped
ports: ports:
- "80:80" - "8000:8000"
- "443:443" environment:
volumes: <<: *db-env
- ./nginx/nginx.conf:/etc/nginx/nginx.conf extra_hosts:
- ./nginx/ssl:/etc/nginx/ssl - "host.docker.internal:host-gateway"
depends_on: depends_on:
- api-gateway - auth-service
- frontend
networks: networks:
- weibo-network - weibo-net
# 前端React应用 # Flask 前端 (端口 5000)
frontend: frontend:
build: build:
context: ./frontend context: ./frontend
dockerfile: Dockerfile dockerfile: Dockerfile
container_name: weibo-frontend container_name: weibo-frontend
restart: unless-stopped
ports: ports:
- "3000:3000" - "5000:5000"
environment: environment:
- REACT_APP_API_BASE_URL=http://localhost/api/v1 FLASK_ENV: "production"
FLASK_DEBUG: "False"
SECRET_KEY: "change-me-flask-secret-key"
API_BASE_URL: "http://api-service:8000"
AUTH_BASE_URL: "http://auth-service:8001"
SESSION_TYPE: "filesystem"
depends_on: depends_on:
- api-gateway - api-service
- auth-service
networks: networks:
- weibo-network - weibo-net
# API网关和主API服务
api-gateway:
build:
context: ./backend
dockerfile: Dockerfile
target: api_gateway
container_name: weibo-api-gateway
ports:
- "8000:8000"
environment:
- DATABASE_URL=mysql+aiomysql://weibo:123456789@XX.XX.XX.XX/weibo
- REDIS_URL=redis://redis:6379
- JWT_SECRET_KEY=your-super-secret-jwt-key-here
- ENVIRONMENT=development
depends_on:
- redis
networks:
- weibo-network
# 认证服务
auth-service:
build:
context: ./backend
dockerfile: Dockerfile
target: auth_service
container_name: weibo-auth-service
ports:
- "8001:8000"
environment:
- DATABASE_URL=mysql+aiomysql://weibo:123456789@XX.XX.XX.XX/weibo
- JWT_SECRET_KEY=your-super-secret-jwt-key-here
networks:
- weibo-network
# 任务调度服务
task-scheduler:
build:
context: ./backend
dockerfile: Dockerfile
target: task_scheduler
container_name: weibo-task-scheduler
environment:
- DATABASE_URL=mysql+aiomysql://weibo:123456789@XX.XX.XX.XX/weibo
- REDIS_URL=redis://redis:6379
depends_on:
- redis
networks:
- weibo-network
# 签到执行Worker
signin-executor:
build:
context: ./backend
dockerfile: Dockerfile
target: signin_executor
container_name: weibo-signin-executor
environment:
- DATABASE_URL=mysql+aiomysql://weibo:123456789@XX.XX.XX.XX/weibo
- REDIS_URL=redis://redis:6379
- PROXY_POOL_URL=http://proxy-pool:8080
- BROWSER_AUTOMATION_URL=http://browser-automation:3001
depends_on:
- redis
networks:
- weibo-network
# 通知中心服务
notification-hub:
build:
context: ./backend/notification_hub
dockerfile: Dockerfile
container_name: weibo-notification-hub
ports:
- "8002:8000"
environment:
- REDIS_URL=redis://redis:6379
depends_on:
- redis
networks:
- weibo-network
# 浏览器自动化服务
browser-automation:
build:
context: ./backend/browser_automation_service
dockerfile: Dockerfile
container_name: weibo-browser-automation
ports:
- "3001:3000"
environment:
- PLAYWRIGHT_BROWSERS_PATH=/app/browsers
volumes:
- browser_data:/app/browsers
networks:
- weibo-network
# 代理池管理器
proxy-pool:
build:
context: ./elk-stack/proxy_pool
dockerfile: Dockerfile
container_name: weibo-proxy-pool
ports:
- "8080:8080"
networks:
- weibo-network
# 浏览器指纹生成器
fingerprint-generator:
build:
context: ./browser_fingerprint_generator
dockerfile: Dockerfile
container_name: weibo-fingerprint-generator
ports:
- "8081:8080"
networks:
- weibo-network
volumes:
redis_data:
browser_data:
networks: networks:
weibo-network: weibo-net:
driver: bridge driver: bridge

5
frontend/.dockerignore Normal file
View File

@@ -0,0 +1,5 @@
venv/
__pycache__/
*.pyc
flask_session/
.env

29
frontend/Dockerfile Normal file
View File

@@ -0,0 +1,29 @@
# ============================================================
# Weibo-HotSign Frontend Dockerfile (Flask)
# ============================================================
FROM python:3.11-slim
WORKDIR /app
RUN apt-get update && apt-get install -y --no-install-recommends curl \
&& rm -rf /var/lib/apt/lists/*
COPY requirements.txt .
RUN pip install --no-cache-dir -r requirements.txt
COPY . .
# 创建 flask_session 目录
RUN mkdir -p flask_session
RUN groupadd -r appuser && useradd -r -g appuser appuser \
&& chown -R appuser:appuser /app
USER appuser
EXPOSE 5000
HEALTHCHECK --interval=30s --timeout=10s --retries=3 \
CMD curl -f http://localhost:5000/ || exit 1
CMD ["python", "app.py"]

View File

@@ -911,5 +911,6 @@ def server_error(error):
return render_template('500.html'), 500 return render_template('500.html'), 500
if __name__ == '__main__': if __name__ == '__main__':
debug_mode = os.getenv('FLASK_DEBUG', 'True').lower() in ('true', '1', 'yes')
# use_reloader=False 避免 Windows 终端 QuickEdit 模式导致进程挂起 # use_reloader=False 避免 Windows 终端 QuickEdit 模式导致进程挂起
app.run(debug=True, port=5000, use_reloader=False) app.run(host='0.0.0.0', debug=debug_mode, port=5000, use_reloader=False)