当前位置: 首页
编程语言
Ubuntu Nodejs如何备份数据

Ubuntu Nodejs如何备份数据

热心网友 时间:2026-05-02
转载

Ubuntu Node.js 数据备份实用方案

Ubuntu Nodejs如何备份数据

免费影视、动漫、音乐、游戏、小说资源长期稳定更新! 👉 点此立即查看 👈

一 备份范围与准备

在动手之前,我们得先搞清楚,服务器上哪些数据是真正需要保护的“命脉”。

  • 明确需要保护的数据:
    • 代码与依赖: 项目源码(建议已在 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)
  • 远程备份与传输
    • 上传到远端: 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
  • 云端生命周期
    • 若使用对象存储(如 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
  • 配置与密钥
    • 还原 .env、证书、Nginx/PM2 配置,检查文件权限与属主。
  • 日志与验证
    • 检查服务状态: systemctl status my-node-app
    • 抽查日志: tail -n 100 /path/to/nodejs/logs/app.log
    • 定期做恢复演练与校验和比对,确保备份可用。
来源:https://www.yisu.com/ask/90697570.html

游乐网为非赢利性网站,所展示的游戏/软件/文章内容均来自于互联网或第三方用户上传分享,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系youleyoucom@outlook.com。

同类文章
更多
Apache配置中如何实现压缩

Apache配置中如何实现压缩

在Apache HTTP服务器中实现压缩 想让你的网站加载速度更快,用户体验更流畅吗?一个行之有效的方法,就是在Apache服务器上启用内容压缩。这听起来有点技术门槛,但其实配置起来并不复杂,核心就是用好mod_deflate这个模块。下面,我们就来一步步拆解如何实现。 1 确保mod_defla

时间:2026-05-02 15:45
怎样在Apache中配置防盗版

怎样在Apache中配置防盗版

Apache防盗版配置实用方案 一 核心思路与适用场景 保护网站资源不被随意盗用,核心目标在于增加未授权外链、抓取和盗用的门槛。常用的技术手段有好几种,它们各有侧重,通常组合起来才能构建起有效的多层防护。 简单来说,你可以从这几个方向入手:基于来源的Referer检查、强制身份认证、部署WAF规则、

时间:2026-05-02 15:45
Sublime如何配置Solidity环境?Sublime编写智能合约代码高亮

Sublime如何配置Solidity环境?Sublime编写智能合约代码高亮

应安装SublimeEthereum插件而非零散语法文件,配置solc路径与版本以实现语义校验,并在Syntax Specific中设置 "extensions ": [ "sol "]确保 sol文件默认使用Solidity语法。 安装 Solidity 语法高亮插件 想让Sublime Text读懂So

时间:2026-05-02 15:45
Apache配置中如何实现缓存

Apache配置中如何实现缓存

Apache服务器缓存配置全攻略:提升网站性能的关键步骤 你是否希望显著提升Apache服务器的响应速度并降低资源消耗?合理配置缓存是实现这一目标的核心优化策略。在Apache服务器中,缓存功能主要通过mod_cache及其磁盘存储模块mod_cache_disk协同实现。本文将为您提供一份清晰、可

时间:2026-05-02 15:45
Filebeat如何进行多线程处理

Filebeat如何进行多线程处理

Filebeat多线程处理实践 核心思路 说到Filebeat的多线程处理,其实它的核心优势在于Go语言运行时提供的原生并发能力。每个日志文件都由一个独立的harvester来读取,多个文件自然就能并行处理了。不过,这里有个常见的误解需要澄清:Filebeat并没有一个直接让用户去调的“全局线程数”

时间:2026-05-02 15:44
热门专题
更多
刀塔传奇破解版无限钻石下载大全 刀塔传奇破解版无限钻石下载大全
洛克王国正式正版手游下载安装大全 洛克王国正式正版手游下载安装大全
思美人手游下载专区 思美人手游下载专区
好玩的阿拉德之怒游戏下载合集 好玩的阿拉德之怒游戏下载合集
不思议迷宫手游下载合集 不思议迷宫手游下载合集
百宝袋汉化组游戏最新合集 百宝袋汉化组游戏最新合集
jsk游戏合集30款游戏大全 jsk游戏合集30款游戏大全
宾果消消消原版下载大全 宾果消消消原版下载大全
  • 日榜
  • 周榜
  • 月榜
热门教程
更多
  • 游戏攻略
  • 安卓教程
  • 苹果教程
  • 电脑教程