前语

前段时刻发生了一件令我哭笑不得的事,布置在 Centos 服务器上的项目,由于需求从头上传 布置,所以我执行了下面一段指令:

rm -rf /*

当我按下回车之后,发现终端闪过的一行行代码,突然感觉工作并不简略,情急之下,赶忙 ctrl c 中断终端,中断之后,便开端经过 fpt 上传文件,却发现 ftp 毫无反响,这下慌了,不会把系统给干没了吧!

接下来我决定 重启 服务器,但是,emmm…,启动不了了!真的把系统给干没了!询问大佬们之后,传闻 阿里云 如果存在 快照,则能够恢复,但是我并没有保存过快照!直接GG,程序没了倒无所谓,但是 数据库没了

这时我意识到,需求做个 守时使命,守时 备份 数据库,结合之前封装的 Email 类,将备份的数据库发送至邮箱,所以才有了这篇文章。

开发布置

由于我后端运用的是 nodejs,这儿就运用 nodejs 编写守时使命吧。

装置依靠

这儿需求 node-schedule 依靠来执行守时使命,需求 child_process 依靠来执行备份指令。

npm i node-schedule child_process

编写代码

src/command 目录下新建一个 BackupDB.ts 文件,在此文件中引入依靠:

import schedule from "node-schedule";
import { spawn } from "child_process";
import fs from "fs";

界说一个办法 backupDb ,所有的备份操作都在此办法内:

export const backupDb = () => {}

在办法内运用 时刻戳 界说备份 唯一 文件名,并 创建流

export const backupDb = () => {
  const dumpFileName = `${Math.round(Date.now() / 1000)}.dump.sql`;
  const writeStream = fs.createWriteStream(dumpFileName);
}

在办法内界说备份脚本

export const backupDb = () => {
  const dumpFileName = `${Math.round(Date.now() / 1000)}.dump.sql`;
  const writeStream = fs.createWriteStream(dumpFileName);
  const dump = spawn("mysqldump",[
    "-u",
    "你的mysql账户名",
    "-p",
    "你的mysql账户暗码",
    "所要备份的数据库名"
  ])
}

接下来守时 执行备份 指令:

export const backupDb = () => {
  const dumpFileName = `${Math.round(Date.now() / 1000)}.dump.sql`;
  const writeStream = fs.createWriteStream(dumpFileName);
  const dump = spawn("mysqldump",[
    "-u",
    "你的mysql账户名",
    "-p",
    "你的mysql账户暗码",
    "所要备份的数据库名"
  ])
  schedule.scheduleJob("0 0 1 * * *", function(){
    dump.stdout.pipe(writeStream)
      .on("finish",() => {
        console.log("备份成功")
      })
      .on("error",() => {
        console.log("备份失利")
      })
  })
}

当然这儿写死的数据还能够作为函数参数可进行控制,别的这儿的 0 0 1 * * * 表明 每天凌晨1点 备份,具体时刻格式可参考下图,或官方文档:

NodeJS定时备份MySQL

在备份成功的回调中,调用 Email 类将备份内容发送至 邮箱,这儿不作为要点就暂且不写。

最后在 src/command/index.js 文件中 引入 备份办法并 调用

import { backupDb } from "./BackupDB";
backupDb();

pm2布置

这儿需求先大局装置 pm2

npm i pm2 -g

pm2 布置的指令格式为:pm2 start [nodejs文件] --name [别号]

pm2 start ./src/command/index.js --name backupDb

布置完结之后,能够经过 pm2 ls 指令查看。

至此,将在 每天凌晨1点 对数据库进行 备份,并发送至 邮箱

结语

写到这儿,我就再也不用担心由于误操作,而删库了,还好我的网站数据不大,也算是吸取教训了。

我是一名前端程序员,但不止于前端,如果文章内容有所欠妥,希望各位大佬能在评论区指出,大家一起学习,一起进步~,最后,再次感谢大家能看到此处。