Linux服务器上Node.js如何进行备份恢复
导读:Linux服务器上Node.js备份与恢复实操指南 一、备份范围与策略 备份范围应覆盖:应用代码与依赖、配置文件(如 .env)、数据库(如 MySQL/PostgreSQL/MongoDB)、上传/附件等用户数据、SSL 证书、日志文件...
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_restore、mongorestore)。
- 参考第三部分对应命令(
- 应用启动与验证:
- 建议使用进程管理工具(如 systemd 或 pm2)拉起服务,并进行健康检查(接口连通性、关键业务查询、日志无异常)。
- 误删文件的紧急恢复(仅限未被覆盖时):
- extundelete(ext3/ext4):
extundelete /dev/sdXN --inode 2扫描并尝试恢复; - TestDisk:用于分区表/分区恢复。
- 操作前请先卸载分区并尽快处理,成功率取决于覆盖情况。
- extundelete(ext3/ext4):
声明:本文内容由网友自发贡献,本站不承担相应法律责任。对本内容有异议或投诉,请联系2913721942#qq.com核实处理,我们将尽快回复您,谢谢合作!
若转载请注明出处: Linux服务器上Node.js如何进行备份恢复
本文地址: https://pptw.com/jishu/768748.html
