rwadurian/backend/services/admin-service/docs/DEPLOYMENT.md

26 KiB

Admin Service 部署文档

目录


1. 部署概述

1.1 部署架构

┌─────────────────────────────────────────────────┐
│                   Load Balancer                 │
│            (Nginx / AWS ALB / etc.)             │
└───────────────────┬─────────────────────────────┘
                    │
        ┌───────────┼───────────┐
        │           │           │
        ▼           ▼           ▼
┌──────────┐  ┌──────────┐  ┌──────────┐
│ Admin    │  │ Admin    │  │ Admin    │
│ Service  │  │ Service  │  │ Service  │
│ Instance │  │ Instance │  │ Instance │
└────┬─────┘  └────┬─────┘  └────┬─────┘
     │             │             │
     └─────────────┼─────────────┘
                   │
                   ▼
        ┌──────────────────┐
        │   PostgreSQL     │
        │   (Primary +     │
        │    Replicas)     │
        └──────────────────┘

1.2 部署环境

环境 说明 数据库 实例数
Development 开发环境 本地/Docker 1
Staging 预发布环境 独立数据库 1-2
Production 生产环境 高可用集群 3+

1.3 系统要求

最低配置

资源 要求
CPU 2 核心
内存 2 GB
硬盘 20 GB (SSD)
网络 100 Mbps

推荐配置 (生产环境)

资源 要求
CPU 4 核心
内存 4-8 GB
硬盘 50 GB (SSD)
网络 1 Gbps

2. 环境准备

2.1 服务器准备

# Ubuntu 22.04 LTS 示例

# 1. 更新系统
sudo apt update && sudo apt upgrade -y

# 2. 安装基础工具
sudo apt install -y \
  curl \
  wget \
  git \
  build-essential \
  ca-certificates \
  gnupg \
  lsb-release

# 3. 安装 Node.js 20.x
curl -fsSL https://deb.nodesource.com/setup_20.x | sudo -E bash -
sudo apt install -y nodejs

# 验证
node --version  # v20.x.x
npm --version   # 10.x.x

# 4. 安装 PM2 (进程管理器)
sudo npm install -g pm2

# 5. 安装 PostgreSQL 16
sudo sh -c 'echo "deb http://apt.postgresql.org/pub/repos/apt $(lsb_release -cs)-pgdg main" > /etc/apt/sources.list.d/pgdg.list'
wget --quiet -O - https://www.postgresql.org/media/keys/ACCC4CF8.asc | sudo apt-key add -
sudo apt update
sudo apt install -y postgresql-16

2.2 数据库配置

# 1. 切换到 postgres 用户
sudo -u postgres psql

# 2. 创建数据库和用户
CREATE DATABASE admin_service_prod;
CREATE USER admin_service WITH ENCRYPTED PASSWORD 'your_secure_password';
GRANT ALL PRIVILEGES ON DATABASE admin_service_prod TO admin_service;

# 3. 退出 psql
\q

# 4. 配置 PostgreSQL 允许远程连接 (如果需要)
sudo nano /etc/postgresql/16/main/postgresql.conf
# 修改: listen_addresses = '*'

sudo nano /etc/postgresql/16/main/pg_hba.conf
# 添加: host all all 0.0.0.0/0 md5

# 5. 重启 PostgreSQL
sudo systemctl restart postgresql

2.3 防火墙配置

# UFW 防火墙配置
sudo ufw allow 22/tcp    # SSH
sudo ufw allow 3005/tcp  # Admin Service (或通过 Nginx 反向代理)
sudo ufw allow 5432/tcp  # PostgreSQL (仅内网)

sudo ufw enable
sudo ufw status

3. 快速开始

3.1 一键启动 (推荐)

使用 deploy.sh 脚本快速启动所有服务:

# 进入项目目录
cd backend/services/admin-service

# 启动所有服务 (包含 PostgreSQL, Redis)
./deploy.sh start

# 检查服务状态
./deploy.sh status

# 查看日志
./deploy.sh logs

# 健康检查
./deploy.sh health

3.2 验证部署

# 健康检查
curl http://localhost:3010/api/v1/health

# 预期响应
{
  "status": "ok",
  "service": "admin-service",
  "timestamp": "2025-12-02T12:00:00.000Z"
}

3.3 环境文件说明

文件 用途 说明
.env.example 配置模板 所有配置项的参考
.env.development 本地开发 使用本地数据库连接
.env.production 生产环境 使用变量引用,部署时注入
.env.test 测试环境 独立的测试数据库
.env 实际使用 复制自上述文件,不提交到 Git

3.4 deploy.sh 命令速查

# 构建
./deploy.sh build            # 构建 Docker 镜像
./deploy.sh build-no-cache   # 无缓存构建

# 生命周期
./deploy.sh start            # 启动所有服务
./deploy.sh stop             # 停止所有服务
./deploy.sh restart          # 重启服务
./deploy.sh up               # 前台启动 (查看日志)
./deploy.sh down             # 停止并删除容器和卷

# 监控
./deploy.sh logs             # 实时日志
./deploy.sh logs-tail        # 最近 100 行日志
./deploy.sh status           # 服务状态
./deploy.sh health           # 健康检查

# 数据库
./deploy.sh migrate          # 生产迁移
./deploy.sh migrate-dev      # 开发迁移
./deploy.sh prisma-studio    # Prisma GUI

# 开发
./deploy.sh dev              # 开发模式
./deploy.sh test             # 运行测试
./deploy.sh shell            # 进入容器

# 清理
./deploy.sh clean            # 清理容器
./deploy.sh clean-all        # 清理容器、卷和镜像

# 信息
./deploy.sh info             # 显示服务信息

4. 本地部署

4.1 克隆代码

cd /opt
sudo git clone https://github.com/your-org/rwa-durian.git
cd rwa-durian/backend/services/admin-service

# 设置权限
sudo chown -R $USER:$USER /opt/rwa-durian

4.2 安装依赖

npm ci --omit=dev

4.3 环境配置

创建 .env.production:

# 应用配置
NODE_ENV=production
APP_PORT=3010
API_PREFIX=api/v1

# 数据库配置
DATABASE_URL=postgresql://admin_service:your_secure_password@localhost:5432/rwa_admin?schema=public

# 日志配置
LOG_LEVEL=info

# CORS 配置
CORS_ORIGIN=https://admin.rwadurian.com,https://app.rwadurian.com

# 安全配置 (待实现)
JWT_SECRET=your_super_secret_jwt_key_change_in_production

4.4 数据库迁移

# 生成 Prisma Client
npm run prisma:generate

# 运行迁移
npm run prisma:migrate:deploy

# (可选) 运行初始化脚本
psql -U admin_service -d admin_service_prod -f database/init.sql

4.5 构建应用

npm run build

4.6 使用 PM2 启动

创建 ecosystem.config.js:

module.exports = {
  apps: [
    {
      name: 'admin-service',
      script: 'dist/main.js',
      instances: 2, // CPU 核心数
      exec_mode: 'cluster',
      env: {
        NODE_ENV: 'production',
        APP_PORT: 3010,
      },
      env_file: '.env.production',
      error_file: 'logs/error.log',
      out_file: 'logs/out.log',
      log_date_format: 'YYYY-MM-DD HH:mm:ss',
      merge_logs: true,
      autorestart: true,
      max_memory_restart: '500M',
      watch: false,
    },
  ],
};

启动服务:

# 启动
pm2 start ecosystem.config.js

# 查看状态
pm2 status

# 查看日志
pm2 logs admin-service

# 重启
pm2 restart admin-service

# 停止
pm2 stop admin-service

# 删除
pm2 delete admin-service

4.7 设置开机自启动

# 保存 PM2 进程列表
pm2 save

# 生成启动脚本
pm2 startup systemd

# 执行输出的命令 (类似):
# sudo env PATH=$PATH:/usr/bin /usr/lib/node_modules/pm2/bin/pm2 startup systemd -u your_user --hp /home/your_user

4.8 验证部署

# 检查服务状态
curl http://localhost:3010/api/v1/health

# 预期响应
{"status": "ok", "service": "admin-service", "timestamp": "..."}

# 检查版本查询
curl "http://localhost:3010/api/v1/versions/check-update?platform=android&currentVersionCode=1"

# PM2 状态
pm2 status

5. Docker 部署

5.1 使用 deploy.sh (推荐)

# 构建镜像
./deploy.sh build

# 启动所有服务
./deploy.sh start

# 查看状态
./deploy.sh status

# 运行数据库迁移
./deploy.sh migrate

5.2 Dockerfile

已配置的 Dockerfile 特性:

# 构建阶段
FROM node:20-alpine AS builder

WORKDIR /app

# 安装 OpenSSL (Prisma 需要)
RUN apk add --no-cache openssl

# 复制 package.json 和 package-lock.json
COPY package*.json ./
COPY prisma ./prisma/

# 安装依赖
RUN npm ci

# 生成 Prisma Client
RUN npx prisma generate

# 复制源代码
COPY . .

# 构建
RUN npm run build

# 生产阶段
FROM node:20-alpine

WORKDIR /app

RUN apk add --no-cache openssl

# 复制依赖
COPY --from=builder /app/node_modules ./node_modules
COPY --from=builder /app/package*.json ./
COPY --from=builder /app/dist ./dist
COPY --from=builder /app/prisma ./prisma

# 暴露端口
EXPOSE 3010

# 健康检查
HEALTHCHECK --interval=30s --timeout=10s --retries=3 --start-period=40s \
  CMD curl -f http://localhost:3010/api/v1/health || exit 1

# 启动命令
CMD ["node", "dist/main.js"]

5.3 Docker Compose

docker-compose.yml 服务架构:

┌─────────────────────────────────────┐
│        admin-service (3010)         │
│         NestJS Application          │
└──────────────┬──────────────────────┘
               │
       ┌───────┴───────┐
       │               │
       ▼               ▼
┌──────────────┐ ┌──────────────┐
│  PostgreSQL  │ │    Redis     │
│    (5433)    │ │    (6380)    │
└──────────────┘ └──────────────┘

端口映射 (避免与其他服务冲突):

  • admin-service: 3010
  • PostgreSQL: 5433 (外部) → 5432 (内部)
  • Redis: 6380 (外部) → 6379 (内部)
services:
  admin-service:
    build: .
    container_name: rwa-admin-service
    ports:
      - "3010:3010"
    environment:
      - NODE_ENV=production
      - APP_PORT=3010
      - API_PREFIX=api/v1
      - DATABASE_URL=postgresql://postgres:password@postgres:5432/rwa_admin?schema=public
      - JWT_SECRET=your-admin-jwt-secret-change-in-production
      - REDIS_HOST=redis
      - REDIS_PORT=6379
    depends_on:
      postgres:
        condition: service_healthy
    healthcheck:
      test: ["CMD", "curl", "-f", "http://localhost:3010/api/v1/health"]
      interval: 30s
      timeout: 10s
      retries: 3
      start_period: 40s
    restart: unless-stopped

  postgres:
    image: postgres:16-alpine
    container_name: rwa-admin-postgres
    environment:
      - POSTGRES_USER=postgres
      - POSTGRES_PASSWORD=password
      - POSTGRES_DB=rwa_admin
    ports:
      - "5433:5432"
    volumes:
      - postgres_data:/var/lib/postgresql/data
      - ./database/init.sql:/docker-entrypoint-initdb.d/init.sql:ro
    healthcheck:
      test: ["CMD-SHELL", "pg_isready -U postgres -d rwa_admin"]
      interval: 5s
      timeout: 5s
      retries: 10
    restart: unless-stopped

  redis:
    image: redis:7-alpine
    container_name: rwa-admin-redis
    ports:
      - "6380:6379"
    volumes:
      - redis_data:/data
    healthcheck:
      test: ["CMD", "redis-cli", "ping"]
      interval: 5s
      timeout: 5s
      retries: 10
    restart: unless-stopped

volumes:
  postgres_data:
    name: admin-service-postgres-data
  redis_data:
    name: admin-service-redis-data

5.4 Docker 部署步骤

# 使用 deploy.sh (推荐)
./deploy.sh build      # 构建镜像
./deploy.sh start      # 启动服务
./deploy.sh migrate    # 运行迁移
./deploy.sh logs       # 查看日志
./deploy.sh status     # 查看状态
./deploy.sh stop       # 停止服务
./deploy.sh down       # 清理 (包括数据)

# 或使用原生 docker compose
docker compose build
docker compose up -d
docker compose exec admin-service npx prisma migrate deploy
docker compose logs -f admin-service
docker compose ps
docker compose down
docker compose down -v

5.5 Docker 健康检查

# 检查容器健康状态
docker ps

# 查看健康检查日志
docker inspect rwa-admin-service | jq '.[0].State.Health'

# 手动健康检查
docker exec rwa-admin-service curl -f http://localhost:3010/api/v1/health

6. 生产环境部署

6.1 Nginx 反向代理

安装 Nginx:

sudo apt install -y nginx

集成到 RWA API 网关 (/etc/nginx/sites-available/rwaapi.szaiai.com.conf):

upstream admin_service {
    least_conn;
    server 192.168.1.111:3010;
    # server 192.168.1.112:3010; # 多实例负载均衡
}

# 在主 server 块中添加 admin-service 路由
server {
    listen 443 ssl http2;
    server_name rwaapi.szaiai.com;

    # SSL 配置 (已在主配置中设置)
    ssl_certificate /etc/letsencrypt/live/rwaapi.szaiai.com/fullchain.pem;
    ssl_certificate_key /etc/letsencrypt/live/rwaapi.szaiai.com/privkey.pem;
    include /etc/nginx/snippets/ssl-params.conf;

    # Admin Service 路由 - 版本管理
    location /api/v1/versions {
        include /etc/nginx/snippets/proxy-params.conf;
        include /etc/nginx/snippets/cors-params.conf;
        proxy_pass http://admin_service;
    }

    # Admin Service 路由 - 管理接口 (预留)
    location /api/v1/admin {
        include /etc/nginx/snippets/proxy-params.conf;
        include /etc/nginx/snippets/cors-params.conf;
        proxy_pass http://admin_service;
    }

    # ... 其他服务路由 (identity, wallet, etc.)
}

启用配置:

# 测试配置
sudo nginx -t

# 重载配置
sudo systemctl reload nginx

6.2 SSL 证书 (Let's Encrypt)

# 安装 Certbot
sudo apt install -y certbot python3-certbot-nginx

# 获取证书
sudo certbot --nginx -d admin-api.rwadurian.com

# 自动续期测试
sudo certbot renew --dry-run

# 自动续期 (crontab)
sudo crontab -e
# 添加: 0 3 * * * certbot renew --quiet

6.3 日志管理

日志轮转

创建 /etc/logrotate.d/admin-service:

/opt/rwa-durian/backend/services/admin-service/logs/*.log {
    daily
    rotate 30
    compress
    delaycompress
    notifempty
    create 0640 your_user your_user
    sharedscripts
    postrotate
        pm2 reloadLogs
    endscript
}

查看日志

# PM2 日志
pm2 logs admin-service

# 实时日志
pm2 logs admin-service --lines 100

# 错误日志
pm2 logs admin-service --err

# Nginx 日志
sudo tail -f /var/log/nginx/admin-service-access.log
sudo tail -f /var/log/nginx/admin-service-error.log

6.4 数据库备份

自动备份脚本

创建 /opt/scripts/backup-admin-db.sh:

#!/bin/bash

# 配置
DB_NAME="admin_service_prod"
DB_USER="admin_service"
BACKUP_DIR="/opt/backups/admin-service"
DATE=$(date +%Y%m%d_%H%M%S)
RETENTION_DAYS=30

# 创建备份目录
mkdir -p $BACKUP_DIR

# 执行备份
pg_dump -U $DB_USER -d $DB_NAME -F c -b -v -f "$BACKUP_DIR/admin_service_$DATE.backup"

# 压缩
gzip "$BACKUP_DIR/admin_service_$DATE.backup"

# 删除旧备份
find $BACKUP_DIR -name "*.backup.gz" -mtime +$RETENTION_DAYS -delete

echo "Backup completed: admin_service_$DATE.backup.gz"

设置定时任务

chmod +x /opt/scripts/backup-admin-db.sh

# 添加到 crontab
crontab -e
# 每天凌晨 2 点备份
0 2 * * * /opt/scripts/backup-admin-db.sh >> /var/log/admin-service-backup.log 2>&1

恢复数据库

# 解压备份
gunzip admin_service_20250103_020000.backup.gz

# 恢复
pg_restore -U admin_service -d admin_service_prod -v admin_service_20250103_020000.backup

6.5 监控告警

PM2 监控

# 安装 PM2 Plus (可选)
pm2 install pm2-logrotate
pm2 install pm2-server-monit

# 查看监控
pm2 monit

健康检查脚本

创建 /opt/scripts/health-check.sh:

#!/bin/bash

HEALTH_URL="http://localhost:3010/api/v1/health"
ALERT_EMAIL="admin@rwadurian.com"

response=$(curl -s -o /dev/null -w "%{http_code}" $HEALTH_URL)

if [ "$response" != "200" ]; then
    echo "Admin Service health check failed! HTTP code: $response" | \
        mail -s "Admin Service Alert" $ALERT_EMAIL

    # 自动重启 (可选)
    pm2 restart admin-service
fi

设置监控定时任务

crontab -e
# 每 5 分钟检查一次
*/5 * * * * /opt/scripts/health-check.sh

7. 监控和维护

7.1 性能监控

应用指标

# CPU 和内存使用
pm2 monit

# 详细指标
pm2 describe admin-service

# 进程列表
pm2 list

数据库监控

# 连接数
sudo -u postgres psql -c "SELECT count(*) FROM pg_stat_activity WHERE datname = 'admin_service_prod';"

# 慢查询
sudo -u postgres psql -d admin_service_prod -c "SELECT query, calls, total_time, mean_time FROM pg_stat_statements ORDER BY mean_time DESC LIMIT 10;"

# 数据库大小
sudo -u postgres psql -c "SELECT pg_size_pretty(pg_database_size('admin_service_prod'));"

7.2 日常维护

更新应用

cd /opt/rwa-durian/backend/services/admin-service

# 1. 备份当前版本
cp -r dist dist.backup.$(date +%Y%m%d)

# 2. 拉取最新代码
git pull origin main

# 3. 安装依赖
npm ci --omit=dev

# 4. 运行迁移
npm run prisma:migrate:deploy

# 5. 构建
npm run build

# 6. 重启服务
pm2 restart admin-service

# 7. 验证
curl http://localhost:3010/api/v1/health

# 8. 查看日志
pm2 logs admin-service --lines 50

数据库维护

# 1. 分析表
sudo -u postgres psql -d admin_service_prod -c "ANALYZE;"

# 2. 清理死元组
sudo -u postgres psql -d admin_service_prod -c "VACUUM ANALYZE;"

# 3. 重建索引
sudo -u postgres psql -d admin_service_prod -c "REINDEX DATABASE admin_service_prod;"

7.3 扩容方案

垂直扩容 (增加资源)

# 1. 调整 PM2 实例数
pm2 scale admin-service 4  # 增加到 4 个实例

# 2. 调整内存限制
# 编辑 ecosystem.config.js
max_memory_restart: '1G'  # 增加到 1GB

pm2 restart admin-service

水平扩容 (增加服务器)

  1. 在新服务器上重复本地部署步骤
  2. 配置 Nginx 负载均衡:
upstream admin_service {
    least_conn;
    server 192.168.1.111:3010 weight=1;
    server 192.168.1.112:3010 weight=1;
    server 192.168.1.113:3010 weight=1;
}
  1. 重新加载 Nginx:
sudo nginx -t
sudo systemctl reload nginx

8. 故障排查

8.1 常见问题

问题 1: 服务无法启动

症状:

pm2 logs admin-service
# Error: Cannot find module '@prisma/client'

解决方案:

npm run prisma:generate
pm2 restart admin-service

问题 2: 数据库连接失败

症状:

Error: P1001: Can't reach database server

排查步骤:

# 1. 检查 PostgreSQL 状态
sudo systemctl status postgresql

# 2. 测试数据库连接
psql -U admin_service -h localhost -d admin_service_prod

# 3. 检查 DATABASE_URL 配置
cat .env.production | grep DATABASE_URL

# 4. 检查防火墙
sudo ufw status

问题 3: 内存泄漏

症状:

pm2 list
# admin-service 内存持续增长

排查步骤:

# 1. 查看内存使用
pm2 describe admin-service

# 2. 分析堆内存
node --inspect dist/main.js
# 访问 chrome://inspect

# 3. 临时解决 - 重启
pm2 restart admin-service

# 4. 调整内存限制
# ecosystem.config.js
max_memory_restart: '500M'

问题 4: 高并发性能下降

症状: 响应时间变长,超时增加

优化方案:

  1. 增加实例数:
pm2 scale admin-service +2
  1. 数据库连接池:
// prisma/schema.prisma
datasource db {
  provider = "postgresql"
  url      = env("DATABASE_URL")
}

generator client {
  provider = "prisma-client-js"
  previewFeatures = ["metrics"]
}

// src/infrastructure/prisma/prisma.service.ts
@Injectable()
export class PrismaService extends PrismaClient {
  constructor() {
    super({
      datasources: {
        db: {
          url: process.env.DATABASE_URL,
        },
      },
      connectionLimit: 10, // 增加连接池
    });
  }
}
  1. 添加缓存 (Redis):
# 安装 Redis
sudo apt install -y redis-server

# 配置缓存
npm install @nestjs/cache-manager cache-manager cache-manager-redis-store

8.2 日志分析

错误日志

# 查看最近的错误
pm2 logs admin-service --err --lines 100

# 搜索特定错误
pm2 logs admin-service --err | grep "Error"

# Nginx 错误日志
sudo tail -100 /var/log/nginx/admin-service-error.log

性能分析

# PM2 性能监控
pm2 monit

# Node.js profiler
node --prof dist/main.js
# 生成 isolate-*.log

# 分析 profile
node --prof-process isolate-*.log > profile.txt

8.3 回滚策略

应用回滚

# 1. 停止服务
pm2 stop admin-service

# 2. 恢复备份代码
rm -rf dist
mv dist.backup.20250103 dist

# 3. 回滚数据库迁移 (谨慎!)
DATABASE_URL="..." npx prisma migrate resolve --rolled-back 20250103100000_add_new_field

# 4. 重启服务
pm2 start admin-service

# 5. 验证
curl http://localhost:3010/api/v1/health

数据库回滚

# 恢复数据库备份
pg_restore -U admin_service -d admin_service_prod -c admin_service_20250103_020000.backup

9. 安全加固

9.1 应用安全

# 1. 限制 Node.js 进程权限
# 创建专用用户
sudo useradd -r -s /bin/false admin_service

# 2. 设置文件权限
sudo chown -R admin_service:admin_service /opt/rwa-durian/backend/services/admin-service
sudo chmod -R 750 /opt/rwa-durian/backend/services/admin-service

# 3. 使用环境变量管理敏感信息
# .env.production 权限
chmod 600 .env.production

9.2 数据库安全

# 1. 修改默认密码
sudo -u postgres psql
ALTER USER admin_service WITH PASSWORD 'new_strong_password';

# 2. 限制网络访问
# /etc/postgresql/16/main/pg_hba.conf
host admin_service_prod admin_service 127.0.0.1/32 md5

# 3. 启用 SSL
# postgresql.conf
ssl = on

9.3 Nginx 安全

# 隐藏版本号
server_tokens off;

# 限流
limit_req_zone $binary_remote_addr zone=api_limit:10m rate=10r/s;

server {
    # ...
    location /api/v1/ {
        limit_req zone=api_limit burst=20;
        proxy_pass http://admin_service;
    }
}

10. 快速参考

10.1 常用命令

# PM2 管理
pm2 start admin-service
pm2 stop admin-service
pm2 restart admin-service
pm2 reload admin-service  # 零停机重启
pm2 delete admin-service
pm2 logs admin-service
pm2 monit

# 数据库
npm run prisma:migrate:deploy
npm run prisma:generate
npm run prisma:studio

# 构建
npm run build
npm run start:prod

# 健康检查
curl http://localhost:3010/api/v1/health

# Nginx
sudo systemctl status nginx
sudo systemctl reload nginx
sudo nginx -t

10.2 deploy.sh 命令速查

# 构建
./deploy.sh build            # 构建镜像
./deploy.sh build-no-cache   # 无缓存构建

# 生命周期
./deploy.sh start            # 启动服务
./deploy.sh stop             # 停止服务
./deploy.sh restart          # 重启服务
./deploy.sh up               # 前台启动
./deploy.sh down             # 停止并清理

# 监控
./deploy.sh logs             # 实时日志
./deploy.sh logs-tail        # 最近日志
./deploy.sh status           # 服务状态
./deploy.sh health           # 健康检查

# 数据库
./deploy.sh migrate          # 生产迁移
./deploy.sh migrate-dev      # 开发迁移
./deploy.sh prisma-studio    # Prisma GUI

# 开发
./deploy.sh dev              # 开发模式
./deploy.sh test             # 运行测试
./deploy.sh shell            # 进入容器

# 清理
./deploy.sh clean            # 清理容器
./deploy.sh clean-all        # 完全清理

# 信息
./deploy.sh info             # 服务信息

10.3 检查清单

部署前

  • 代码已通过所有测试
  • 环境变量已正确配置
  • 数据库迁移已准备
  • SSL 证书已配置
  • 备份策略已设置
  • 监控告警已配置

部署后

  • 服务健康检查通过
  • 数据库连接正常
  • API 端点可访问
  • 日志正常输出
  • 性能指标正常
  • 备份自动执行

最后更新: 2025-12-03 版本: 1.0.0 维护者: RWA Durian Team