Ubuntu Nodejs如何备份数据
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 -a v --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 -a vz /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 -a vz --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 - 定期做恢复演练与校验和比对,确保备份可用。
- 检查服务状态:
游乐网为非赢利性网站,所展示的游戏/软件/文章内容均来自于互联网或第三方用户上传分享,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系youleyoucom@outlook.com。
同类文章
Apache配置中如何实现压缩
在Apache HTTP服务器中实现压缩 想让你的网站加载速度更快,用户体验更流畅吗?一个行之有效的方法,就是在Apache服务器上启用内容压缩。这听起来有点技术门槛,但其实配置起来并不复杂,核心就是用好mod_deflate这个模块。下面,我们就来一步步拆解如何实现。 1 确保mod_defla
怎样在Apache中配置防盗版
Apache防盗版配置实用方案 一 核心思路与适用场景 保护网站资源不被随意盗用,核心目标在于增加未授权外链、抓取和盗用的门槛。常用的技术手段有好几种,它们各有侧重,通常组合起来才能构建起有效的多层防护。 简单来说,你可以从这几个方向入手:基于来源的Referer检查、强制身份认证、部署WAF规则、
Sublime如何配置Solidity环境?Sublime编写智能合约代码高亮
应安装SublimeEthereum插件而非零散语法文件,配置solc路径与版本以实现语义校验,并在Syntax Specific中设置 "extensions ": [ "sol "]确保 sol文件默认使用Solidity语法。 安装 Solidity 语法高亮插件 想让Sublime Text读懂So
Apache配置中如何实现缓存
Apache服务器缓存配置全攻略:提升网站性能的关键步骤 你是否希望显著提升Apache服务器的响应速度并降低资源消耗?合理配置缓存是实现这一目标的核心优化策略。在Apache服务器中,缓存功能主要通过mod_cache及其磁盘存储模块mod_cache_disk协同实现。本文将为您提供一份清晰、可
Filebeat如何进行多线程处理
Filebeat多线程处理实践 核心思路 说到Filebeat的多线程处理,其实它的核心优势在于Go语言运行时提供的原生并发能力。每个日志文件都由一个独立的harvester来读取,多个文件自然就能并行处理了。不过,这里有个常见的误解需要澄清:Filebeat并没有一个直接让用户去调的“全局线程数”
- 日榜
- 周榜
- 月榜
1
2
3
4
5
6
7
8
9
10
相关攻略
2015-03-10 11:25
2015-03-10 11:05
2021-08-04 13:30
2015-03-10 11:22
2015-03-10 12:39
2022-05-16 18:57
2025-05-23 13:43
2025-05-23 14:01
热门教程
- 游戏攻略
- 安卓教程
- 苹果教程
- 电脑教程
热门话题

