温馨提示×

Linux服务器上Node.js如何进行备份恢复

小樊
37
2025-12-10 12:25:01
栏目: 云计算

Linux服务器上Node.js备份与恢复实操指南

一、备份范围与策略

  • 备份范围应覆盖:应用代码与依赖配置文件(如 .env)、数据库(如 MySQL/PostgreSQL/MongoDB)、上传/附件等用户数据SSL 证书日志文件
  • 备份策略建议:采用全量 + 增量/日志的组合;例如每日做全量、每小时增量,并保留7–30天;对数据库启用事务日志/时间点恢复能力;将备份离线或异地/云端存放,并做好定期恢复演练完整性校验

二、文件与配置备份

  • 打包项目目录(适合代码与静态资源):
    • 命令:tar -czvf /backup/nodejs/app_$(date +%F_%H-%M-%S).tar.gz -C /var/www/my-node-app .
  • 同步目录(适合持续增量与镜像,保留权限与时间戳):
    • 命令:rsync -avz --delete /var/www/my-node-app/ /backup/nodejs/app_latest/
  • 单独备份关键配置与证书:
    • 命令:cp /var/www/my-node-app/.env /backup/nodejs/ && cp -r /etc/ssl/myapp.* /backup/nodejs/ssl/
  • 传输到远程或云端(示例):
    • 命令:scp /backup/nodejs/app_*.tar.gz user@backup-server:/backup/nodejs/
  • 建议:代码纳入 Git 管理;依赖以 package.json 为准,部署时执行 npm ci --only=production 还原依赖。

三、数据库备份

  • MySQL
    • 备份:mysqldump -h $DB_HOST -u $DB_USER -p$DB_PASS $DB_NAME > /backup/db_$(date +%F).sql
    • 恢复:mysql -h $DB_HOST -u $DB_USER -p$DB_PASS $DB_NAME < /backup/db_YYYY-MM-DD.sql
  • PostgreSQL
    • 备份:pg_dump -h $DB_HOST -U $DB_USER -d $DB_NAME -F c -f /backup/db_$(date +%F).dump
    • 恢复:pg_restore -h $DB_HOST -U $DB_USER -d $DB_NAME /backup/db_YYYY-MM-DD.dump
  • MongoDB
    • 备份:mongodump --uri "$MONGODB_URI" --out /backup/mongo_$(date +%F)
    • 恢复:mongorestore --uri "$MONGODB_URI" /backup/mongo_YYYY-MM-DD
  • 提示:生产库备份尽量在低峰期进行;如为事务型业务,结合WAL/oplog实现时间点恢复

四、自动化与远程备份

  • 示例备份脚本(全量+数据库+配置,带保留策略):
    • 脚本:
      #!/usr/bin/env bash
      set -e
      APP_DIR="/var/www/my-node-app"
      BACKUP_BASE="/backup/nodejs"
      DATE=$(date +%F_%H-%M-%S)
      mkdir -p "$BACKUP_BASE/$DATE"
      
      # 1) 代码与静态资源
      tar -czf "$BACKUP_BASE/$DATE/app.tar.gz" -C "$APP_DIR" .
      
      # 2) 数据库
      if [[ -n "$DB_TYPE" ]]; then
        case "$DB_TYPE" in
          mysql)
            mysqldump -h "$DB_HOST" -u "$DB_USER" -p"$DB_PASS" "$DB_NAME" > "$BACKUP_BASE/$DATE/db.sql"
            ;;
          postgres)
            pg_dump -h "$DB_HOST" -U "$DB_USER" -d "$DB_NAME" -F c -f "$BACKUP_BASE/$DATE/db.dump"
            ;;
          mongodb)
            mongodump --uri "$MONGODB_URI" --out "$BACKUP_BASE/$DATE/mongo"
            ;;
        esac
      fi
      
      # 3) 配置与证书
      cp "$APP_DIR/.env" "$BACKUP_BASE/$DATE/"
      [ -d "$APP_DIR/ssl" ] && cp -r "$APP_DIR/ssl" "$BACKUP_BASE/$DATE/"
      
      # 4) 保留最近7天
      find "$BACKUP_BASE" -maxdepth 1 -type d -mtime +7 -exec rm -rf {} +
      
      # 5) 可选:同步到远程
      # rsync -avz --delete -e ssh "$BACKUP_BASE/" user@backup-server:/backup/nodejs/
      echo "Backup finished: $BACKUP_BASE/$DATE"
      
    • 定时任务(每天 02:00 执行):
      • 命令:0 2 * * * /usr/local/bin/backup_nodejs.sh >> /var/log/backup.log 2>&1
  • 建议:为备份脚本与传输链路配置最小权限账号访问控制,并保留执行日志以便审计与排障。

五、恢复流程与验证

  • 文件系统与配置:
    • 命令:tar -xzvf /backup/nodejs/app_YYYY-MM-DD_HH-MM-SS.tar.gz -C /var/www/my-node-app
    • 命令:rsync -avz --delete /backup/nodejs/app_latest/ /var/www/my-node-app/
    • 命令:cp /backup/nodejs/.env /var/www/my-node-app/.env
  • 数据库:
    • 参考第三部分对应命令(mysql <pg_restoremongorestore)。
  • 应用启动与验证:
    • 建议使用进程管理工具(如 systemdpm2)拉起服务,并进行健康检查(接口连通性、关键业务查询、日志无异常)。
  • 误删文件的紧急恢复(仅限未被覆盖时):
    • extundelete(ext3/ext4):extundelete /dev/sdXN --inode 2 扫描并尝试恢复;
    • TestDisk:用于分区表/分区恢复。
    • 操作前请先卸载分区并尽快处理,成功率取决于覆盖情况。

0