使用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文件的路径

写在后面

  • 网上的教程真的是,一言难尽...
  • 真的很想骂人,互相抄也就算了,抄的还是垃圾...
  • 不知道这样做的意义是什么,把网络环境搞成这样...
相关推荐
随风飘的云11 小时前
MySQL的慢查询优化解决思路
数据库
IvorySQL14 小时前
PostgreSQL 技术日报 (3月7日)|生态更新与内核性能讨论
数据库·postgresql·开源
赵渝强老师15 小时前
【赵渝强老师】金仓数据库的数据文件
数据库·国产数据库·kingbase·金仓数据库
随逸17718 小时前
《Milvus向量数据库从入门到实战,手把手搭建语义检索系统》
数据库
神秘的猪头19 小时前
🚀 React 开发者进阶:RAG 核心——手把手带你玩转 Milvus 向量数据库
数据库·后端·llm
0xDevNull1 天前
MySQL索引进阶用法
后端·mysql
0xDevNull1 天前
MySQL索引用法
mysql
IvorySQL2 天前
PostgreSQL 技术日报 (3月6日)|为什么 Ctrl-C 在 psql 里让人不安?
数据库·postgresql·开源
NineData2 天前
数据库管理工具NineData,一年进化成为数万+开发者的首选数据库工具?
运维·数据结构·数据库