使用nodejs定时备份mysql数据库与恢复

写在前面

  • 备份是在node.js中使用mysqldump实现
  • 备份的是sql语句
  • 恢复通过直接执行sql语句实现

备份代码

  • 写在nodejs中

    //依赖
    const fs = require('fs');
    const mysqldump = require('mysqldump');

    // 设置数据库连接参数
    const config = {
    connection: {
    host: '127.0.0.1',
    user: '填自己的',
    password: '填自己的',
    database: '填自己的',
    },
    dumpToFile: './backup.sql', // 设置备份文件路径
    };

    // 每1分钟执行一次的定时任务
    const job = new cron.CronJob('0 * * * * *', () => {
    mysqldump(config).then(output => {
    fs.writeFileSync(config.dumpToFile,output.dump);
    })
    .catch(error => {
    console.error(error);
    });
    });

    //启动定时任务
    job.start();

  • 会弹出一个报错,但是对数据没有影响

恢复代码

  • 恢复是直接在cmd窗口中运行

    mysql -uroot -p -Dship_copy < C:/Users/user/Desktop/共享/web/backup.sql

  • 回车后会要求你输入密码

  • -D 后面的是你数据库的名字

  • < 右边的是sql文件的路径

写在后面

  • 网上的教程真的是,一言难尽...
  • 真的很想骂人,互相抄也就算了,抄的还是垃圾...
  • 不知道这样做的意义是什么,把网络环境搞成这样...
相关推荐
vvvae12347 小时前
分布式数据库
数据库
雪域迷影7 小时前
PostgreSQL Docker Error – 5432: 地址已被占用
数据库·docker·postgresql
bug菌¹8 小时前
滚雪球学Oracle[4.2讲]:PL/SQL基础语法
数据库·oracle
逸巽散人8 小时前
SQL基础教程
数据库·sql·oracle
月空MoonSky9 小时前
Oracle中TRUNC()函数详解
数据库·sql·oracle
momo小菜pa9 小时前
【MySQL 06】表的增删查改
数据库·mysql
向上的车轮10 小时前
Django学习笔记二:数据库操作详解
数据库·django
编程老船长10 小时前
第26章 Java操作Mongodb实现数据持久化
数据库·后端·mongodb
全栈师10 小时前
SQL Server中关于个性化需求批量删除表的做法
数据库·oracle
Data 31710 小时前
Hive数仓操作(十七)
大数据·数据库·数据仓库·hive·hadoop