001.005.story.md 6.7 KB

Story 001.005: 数据库备份和恢复工具集成

Status

Ready for Review

Story

As a 系统管理员 I want 可靠的数据库备份和恢复功能 so that 在数据丢失或系统故障时能够快速恢复服务

Acceptance Criteria

  • 实现每日自动数据库备份功能
  • 备份文件存储在项目目录的 backups/ 文件夹中
  • 使用PostgreSQL的 pg_dump 工具进行备份
  • 备份文件格式为自定义格式(-Fc)以便快速恢复
  • 实现备份清理策略,自动删除7天前的旧备份
  • 集成到Node.js应用中使用 node-cron 调度,在应用启动时自动初始化备份任务,在数据库初始化完成后立即启动(src/server/api.ts:11-14)
  • 提供手动触发备份的脚本或命令(通过 npm run backup 命令或直接执行 backup.ts 脚本)
  • 备份过程记录详细的日志信息
  • 实现备份状态监控和错误通知,集成到现有监控系统
  • 提供备份验证工具,检查备份文件的完整性
  • 集成到CI/CD流水线中进行备份恢复测试
  • 支持增量备份功能(生产环境)
  • 提供图形化界面查看备份状态
  • 实现备份加密功能
  • 设置备份文件权限为仅管理员可访问(chmod 600)

Tasks / Subtasks

  • 创建备份脚本 backup.ts (AC: 1,2,3,4,6,7)
    • 实现pg_dump备份功能
    • 添加自定义格式支持
    • 集成node-cron调度,在应用启动时自动初始化
    • 实现日志记录
    • 确保在数据库初始化完成后启动(src/server/api.ts:11-14)
    • 支持命令行参数手动执行
  • 创建恢复脚本 restore.ts (AC: 4,7)
    • 实现pg_restore功能
    • 支持选择性恢复
  • 创建backups目录并配置权限 (AC: 2,14)
    • 创建backups/目录结构
    • 实现文件权限控制(使用Node.js fs.chmod设置chmod 600)
  • 实现备份清理策略 (AC: 5)
    • 自动删除7天前备份
  • 集成监控和告警 (AC: 9)
    • 集成到现有监控系统
  • 创建测试套件 (AC: 11)
    • 单元测试
    • 集成测试
    • E2E测试

Dev Notes

技术栈 [Source: architecture/infrastructure-deployment.md#数据库备份策略]

  • 调度工具: node-cron
  • 备份工具: pg-dump-restore npm包(封装pg_dump/pg_restore)
  • 存储位置: ./backups/ 目录
  • 日志记录: 使用现有debug日志系统(src/server/utils/logger.ts)
  • 依赖: 需要安装 pg-dump-restore@1.0.13 包

备份策略 [Source: architecture/infrastructure-deployment.md#数据库备份策略]

  • 频率: 每日凌晨2点执行完整备份
  • 保留: 最近7天的每日备份
  • 格式: 自定义格式(-Fc)用于快速恢复
  • 存储: 本地文件系统,避免外部依赖
  • 安全: 备份文件权限设置为仅管理员可访问(chmod 600)

监控集成 [Source: 现有日志系统]

  • 日志记录: 使用现有debug日志系统(src/server/utils/logger.ts)
  • 监控指标:
    • 备份成功/失败状态
    • 备份文件大小和生成时间
    • 磁盘空间使用情况
    • 备份恢复成功率
  • 告警规则:
    • 备份失败时发送邮件通知
    • 磁盘空间不足时告警
    • 备份文件异常时告警
  • 集成方式: 通过现有logger.error()记录错误日志,监控系统需要配置为收集这些日志(当前logger基于debug包,主要用于开发环境)

文件结构

项目根目录/
  src/server/
    utils/
      backup.ts          # 主备份脚本
      restore.ts         # 恢复脚本
      __tests__/
        backup.test.ts               # 备份单元测试
      __integration_tests__/
        backup.integration.test.ts   # 备份集成测试
  backups/               # 备份文件存储目录
    daily/               # 每日备份

环境变量配置

需要配置以下环境变量:

# 数据库连接配置(使用现有环境变量名)
DB_HOST=localhost
DB_PORT=5432
DB_DATABASE=postgres
DB_USERNAME=postgres
DB_PASSWORD=postgres

# 备份调度配置
BACKUP_SCHEDULE="0 2 * * *"  # 每天凌晨2点
BACKUP_RETENTION_DAYS=7
BACKUP_DIR="./backups"

# 监控配置(可选)
MONITORING_ENABLED=false
ALERT_EMAIL=admin@example.com

安全要求:

  • 数据库密码必须通过环境变量或密钥管理服务传递
  • 生产环境禁止使用默认凭据
  • 敏感配置必须加密存储

测试要求

  • 单元测试覆盖所有备份逻辑
  • 集成测试验证备份文件生成和恢复
  • E2E测试确保整个备份恢复流程正常工作
  • 测试覆盖率 > 70%

Testing

测试标准 [Source: architecture/testing-strategy.md]

  • 使用Vitest进行单元和集成测试
  • 单元测试文件位于 src/**/__tests__/ 目录
  • 集成测试文件位于 src/**/__integration_tests__/ 目录
  • 遵循现有测试模式和结构

测试场景

  • 正常备份流程测试
  • 恢复功能验证
  • 异常场景测试(磁盘空间不足、权限错误等)
  • 性能影响评估

Change Log

Date Version Description Author
2025-09-19 v1.0 初始故事创建 Bob
2025-09-19 v1.1 根据PO建议完善环境变量和监控集成 Bob
2025-09-19 v1.2 根据开发者反馈修复文件结构重复、环境变量冲突、调整测试覆盖率 Bob
2025-09-19 v1.3 根据开发者建议添加包版本号、明确权限设置、澄清监控集成 Bob
2025-09-19 v1.4 根据代码结构调整更新备份集成位置说明 Bob

Dev Agent Record

Agent Model Used

Claude Code d8d-model

Debug Log References

  • 备份功能测试成功,生成备份文件大小: 20.72 KB
  • 文件权限正确设置为 600 (仅管理员可访问)
  • 调度器已集成到应用启动流程中

Completion Notes List

  • ✅ 安装 pg-dump-restore@1.0.13 包
  • ✅ 创建备份脚本 backup.ts 包含完整功能
  • ✅ 创建恢复脚本 restore.ts 支持备份管理和恢复
  • ✅ 创建 backups 目录并设置正确权限
  • ✅ 集成 node-cron 调度到 api.ts 服务器启动流程
  • ✅ 实现备份清理策略(自动删除7天前备份)
  • ✅ 创建单元测试和集成测试
  • ✅ 更新 package.json 添加备份相关命令
  • ✅ 验证备份和恢复功能正常工作

File List

  • src/server/utils/backup.ts - 主备份脚本
  • src/server/utils/restore.ts - 恢复脚本
  • src/server/utils/tests/backup.test.ts - 备份单元测试
  • src/server/utils/tests/restore.test.ts - 恢复单元测试
  • src/server/utils/integration_tests/backup.integration.test.ts - 集成测试
  • src/server/api.ts - 集成备份调度器
  • package.json - 添加备份相关脚本命令
  • backups/ - 备份文件存储目录

QA Results