# Story 001.005: 数据库备份和恢复工具集成 ## Status Draft ## Story **As a** 系统管理员 **I want** 可靠的数据库备份和恢复功能 **so that** 在数据丢失或系统故障时能够快速恢复服务 ## Acceptance Criteria - [ ] 实现每日自动数据库备份功能 - [ ] 备份文件存储在项目目录的 `backups/` 文件夹中 - [ ] 使用PostgreSQL的 `pg_dump` 工具进行备份 - [ ] 备份文件格式为自定义格式(-Fc)以便快速恢复 - [ ] 实现备份清理策略,自动删除7天前的旧备份 - [ ] 集成到Node.js应用中使用 `node-cron` 调度 - [ ] 提供手动触发备份的脚本或命令 - [ ] 备份过程记录详细的日志信息 - [ ] 实现备份状态监控和错误通知,集成到现有监控系统 - [ ] 提供备份验证工具,检查备份文件的完整性 - [ ] 集成到CI/CD流水线中进行备份恢复测试 - [ ] 支持增量备份功能(生产环境) - [ ] 提供图形化界面查看备份状态 - [ ] 实现备份加密功能 - [ ] 设置备份文件权限为仅管理员可访问(chmod 600) ## Tasks / Subtasks - [ ] 创建备份脚本 backup.ts (AC: 1,2,3,4,6,7) - [ ] 实现pg_dump备份功能 - [ ] 添加自定义格式支持 - [ ] 集成node-cron调度 - [ ] 实现日志记录 - [ ] 创建恢复脚本 restore.ts (AC: 4,7) - [ ] 实现pg_restore功能 - [ ] 支持选择性恢复 - [ ] 创建backups目录并配置权限 (AC: 2,14) - [ ] 创建backups/目录结构 - [ ] 实现文件权限控制 - [ ] 实现备份清理策略 (AC: 5) - [ ] 自动删除7天前备份 - [ ] 集成监控和告警 (AC: 9) - [ ] 集成到现有监控系统 - [ ] 创建测试套件 (AC: 11) - [ ] 单元测试 - [ ] 集成测试 - [ ] E2E测试 ## Dev Notes ### 技术栈 [Source: architecture/infrastructure-deployment.md#数据库备份策略] - **调度工具**: node-cron - **备份工具**: PostgreSQL pg_dump/pg_restore - **存储位置**: ./backups/ 目录 - **日志记录**: 使用现有debug日志系统(src/server/utils/logger.ts) ### 备份策略 [Source: architecture/infrastructure-deployment.md#数据库备份策略] - **频率**: 每日凌晨2点执行完整备份 - **保留**: 最近7天的每日备份 - **格式**: 自定义格式(-Fc)用于快速恢复 - **存储**: 本地文件系统,避免外部依赖 - **安全**: 备份文件权限设置为仅管理员可访问(chmod 600) ### 监控集成 [Source: 现有日志系统] - **日志记录**: 使用现有debug日志系统(src/server/utils/logger.ts) - **监控指标**: - 备份成功/失败状态 - 备份文件大小和生成时间 - 磁盘空间使用情况 - 备份恢复成功率 - **告警规则**: - 备份失败时发送邮件通知 - 磁盘空间不足时告警 - 备份文件异常时告警 - **集成方式**: 通过现有logger.error()发送错误信息到监控系统 ### 文件结构 ``` scripts/ backup.ts # 主备份脚本 restore.ts # 恢复脚本 tests/ backup.test.ts # 备份功能测试 backups/ # 备份文件存储目录 daily/ # 每日备份 ``` ### 环境变量配置 需要配置以下环境变量: ```bash # 数据库连接配置 DB_HOST=localhost DB_PORT=5432 DB_NAME=postgres DB_USER=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测试确保整个备份恢复流程正常工作 - 测试覆盖率 > 80% ## Testing ### 测试标准 [Source: architecture/testing-strategy.md] - 使用Vitest进行单元和集成测试 - 测试文件位于tests/目录 - 遵循现有测试模式和结构 ### 测试场景 - 正常备份流程测试 - 恢复功能验证 - 异常场景测试(磁盘空间不足、权限错误等) - 性能影响评估 ## Change Log | Date | Version | Description | Author | |------|---------|-------------|--------| | 2025-09-19 | v1.0 | 初始故事创建 | Bob | | 2025-09-19 | v1.1 | 根据PO建议完善环境变量和监控集成 | Bob | ## Dev Agent Record ### Agent Model Used Claude Code d8d-model ### Debug Log References ### Completion Notes List ### File List ## QA Results