Ubuntu Nodejs如何备份数据
导读:Ubuntu Node.js 数据备份实用方案 一 备份范围与准备 明确需要保护的数据: 代码与依赖:项目源码(建议已在 Git 管理)、package.json 与 package-lock.json/yarn.lock。 数据库:如...
Ubuntu Node.js 数据备份实用方案
一 备份范围与准备
- 明确需要保护的数据:
- 代码与依赖:项目源码(建议已在 Git 管理)、package.json 与 package-lock.json/yarn.lock。
- 数据库:如 MySQL、PostgreSQL、MongoDB 的数据与结构。
- 配置与密钥:如 .env、Nginx/PM2 配置、证书等。
- 用户上传/静态资源:如 uploads/、public/static/。
- 日志:应用日志目录(按策略保留与归档)。
- 建议做法:
- 代码走 Git 常态备份;服务器侧保留一份打包归档用于快速恢复。
- 数据库使用各自工具导出为可移植的转储文件(如 .sql/.dump)。
- 配置与密钥纳入备份,注意权限与脱敏。
- 日志采用轮转+归档,避免无限增长。
二 本地与远程备份命令
- 项目代码与依赖打包
- 打包:
tar -czvf project-$(date +%F).tar.gz -C /path/to/project . - 同步到备份目录:
rsync -av --delete /path/to/project/ /backup/nodejs/
- 打包:
- 数据库备份
- MySQL:
mysqldump -u USER -p DATABASE > backup_$(date +%F).sql - PostgreSQL:
pg_dump -U USER -d DATABASE -f backup_$(date +%F).sql - MongoDB:
mongodump --db DATABASE --out /backup/mongo/DATABASE_$(date +%F)
- MySQL:
- 远程备份与传输
- 上传到远端:
rsync -avz /backup/ user@remote:/backup/nodejs/ - 安全拷贝:
scp project-$(date +%F).tar.gz user@remote:/backup/
- 上传到远端:
- 说明
- 以上命令可按需加入 -h 主机、-P 端口、–single-transaction(MySQL InnoDB)、-Fc(PostgreSQL 自定义格式)等选项以提升一致性与效率。
三 日志备份与轮转
- 使用 logrotate 做日常轮转与压缩(推荐)
- 新建配置:
sudo nano /etc/logrotate.d/nodejs - 示例:
/path/to/nodejs/logs/*.log { daily rotate 7 compress missingok notifempty create 0640 node node postrotate systemctl reload my-node-app.service > /dev/null 2> & 1 || true endscript } - 测试与强制执行:
- 校验:
sudo logrotate -d /etc/logrotate.d/nodejs - 立即轮转:
sudo logrotate -f /etc/logrotate.d/nodejs
- 校验:
- 新建配置:
- 按日归档脚本示例(配合 cron)
- 脚本要点:
#!/usr/bin/env bash set -e LOGS=/path/to/nodejs/logs BACKUP=/backup/logs/$(date +%F) mkdir -p "$BACKUP" tar -czf "$BACKUP/nodejs_logs_$(date +%F).tar.gz" -C "$LOGS" . find /backup/logs -type f -mtime +7 -delete - 定时:
0 1 * * * /usr/bin/bash /usr/local/bin/backup_nodejs_logs.sh
- 脚本要点:
- 远程归档同步
0 0 * * * rsync -avz --delete /backup/logs/ user@remote:/backup/nodejs-logs/
- 提示
- 生产环境优先用 logrotate 做滚动与压缩;归档与异地同步用脚本或 rsync 补充。
四 定时备份与云存储
- 数据库定时备份脚本(含本地保留与云端上传)
- 示例(MySQL,按日保留 7 天):
#!/usr/bin/env bash set -e BACKUP_DIR=/backup/db NOW=$(date +%F_%H%M%S) mkdir -p "$BACKUP_DIR" mysqldump -u USER -pPASSWORD mydb | gzip > "$BACKUP_DIR/mydb_$NOW.sql.gz" find "$BACKUP_DIR" -name "mydb_*.sql.gz" -mtime +7 -delete # 可选:上传到对象存储(示例思路) # node /opt/scripts/upload.js "$BACKUP_DIR/mydb_$NOW.sql.gz" - 定时:
30 1 * * * /usr/bin/bash /usr/local/bin/db_backup.sh
- 示例(MySQL,按日保留 7 天):
- 云端生命周期
- 若使用对象存储(如 OSS),可配置 生命周期规则 自动清理 7 天前备份,降低存储成本。
- 安全建议
- 避免在命令行中明文写密码,使用 ~/.my.cnf 或凭据文件,并确保权限为 600。
五 恢复与验证
- 项目代码与依赖
- 解压:
tar -xzvf project-2025-09-01.tar.gz -C /opt/app - 安装依赖:
cd /opt/app & & npm ci --only=production
- 解压:
- 数据库恢复
- MySQL:
mysql -u USER -p DATABASE < backup_2025-09-01.sql - PostgreSQL:
psql -U USER -d DATABASE -f backup_2025-09-01.sql - MongoDB:
mongorestore --db DATABASE /backup/mongo/DATABASE_2025-09-01
- MySQL:
- 配置与密钥
- 还原 .env、证书、Nginx/PM2 配置,检查文件权限与属主。
- 日志与验证
- 检查服务状态:
systemctl status my-node-app - 抽查日志:
tail -n 100 /path/to/nodejs/logs/app.log - 定期做恢复演练与校验和比对,确保备份可用。
- 检查服务状态:
声明:本文内容由网友自发贡献,本站不承担相应法律责任。对本内容有异议或投诉,请联系2913721942#qq.com核实处理,我们将尽快回复您,谢谢合作!
若转载请注明出处: Ubuntu Nodejs如何备份数据
本文地址: https://pptw.com/jishu/770258.html
