• 分享一个 MySQL 简单快速进行自动备份和还原的脚本和方法


    image

    前言

    数据备份和还原在信息技术领域中具有非常重要的作用,不论是人为误操作、硬件故障、病毒感染、自然灾害还是其他原因,数据丢失的风险都是存在的。如果没有备份,一旦数据丢失,可能对个人、企业甚至整个组织造成巨大的损失。

    数据是企业的核心资产,在面对突发事件或灾难时,定期备份的数据可以保护数据的完整性和保密性,确保数据的安全和可靠性,帮助组织迅速恢复数据和业务操作,减少停机时间,确保业务的持续运行。

    下面分享一个 MySQL 如何进行自动备份和还原的脚本和方法。

    自动备份

    1. 创建备份脚本批处理文件,如 mysqlbakup.bat

      echo get the current date
      set year=%date:~0,4%
      set month=%date:~5,2%
      set day=%date:~8,2%
      
      rem use the year, month and day as the file name, like 20240618
      set filename=%year%%month%%day%
      
      rem The assignment equal sign cannot have spaces on either side
      set mysqldumpPath="C:\Program Files\MySQL\MySQL Server 8.0\bin\mysqldump.exe"
      set dbName=bookmgr
      set dbUser=root
      set dbPwd=mysql
      set outpurDir=D:/dbbackup/
      
      set outputFileName=%outpurDir%%dbName%_%filename%.sql
      
      echo %outputFileName%
      
      %mysqldumpPath% -u%dbUser% -p%dbPwd% --opt --ignore-table=bookmgr.report_templete --default-character-set=utf8mb4 -E --triggers -R --hex-blob --flush-logs -x %dbName% > %outputFileName%
      
    2. 参数说明:

      1. -u: 用户名
      2. -p: 密码
      3. –opt: 提供了快速 dump 操作,默认开启
      4. –default-character-set: 使用charset_name作为默认字符集,mysqldump默认使用utf8.
      5. -E: dump 服务器事件,须有event权限
      6. –triggers: 导出表的触发器,默认启动
      7. -R: 导出存储过程和函数
      8. –hex-blob: 使用十六进制表示法转储二进制列
      9. –flush-logs: 切换一下binlog file,在开始dump前,flush 一个新的binlog file。此选项适用于为备份恢复加一个保险。
      10. -x %dbName% 数据库
    3. 以下地方需要注意:

      1. mysqldumpPath 本地 mysqldump.exe 路径
      2. dbName 需要备份的数据库
      3. dbUser 数据库用户名
      4. dbPwd 数据库密码
      5. outpurDir 备份文件输出路径
      6. –default-character-set 数据库字符集,要跟数据库一致
    4. 双击运行这个批处理文件,运行完成后在输出路径查看结果如:

      • 结果:D:\dbbackup\bookmgr_20240618.sql
    5. 测试没问题后,把它加入到 Windows 计划任务,并设置为每天自动备份

    还原

    1. CMD 脚本

      C:\Program Files\MySQL\MySQL Server 8.0\bin>mysql -uroot -pmysql --default-character-set=utf8mb4 bookmgr_restore < D:\dbbackup\bookmgr_2024.sql
      
    2. 参数说明

      1. -u: 用户名
      2. -p: 密码
      3. –default-character-set 数据库字符集,要跟备份一致
      4. bookmgr_restore 数据库,还原的目标数据库
      5. D:\dbbackup\bookmgr_20240618.sql 备份文件路径

    其他

    1. 实践中,在还原时,碰到这个错:Unknown command ‘’’

      这是因为有一个表的数据有单引号 ',备份时被转义为 ',还原的命令中 --default-character-set 跟备份文件不一致,所以无法识别,改为一致就没问题了

    2. 如果在备份时,不导出某个表的数据,可用 –ignore-table 参数,如:

      mysqldump -uroot -p --databases db_name --ignore-table=db_name.table_name
      

    总结

    总而言之,数据备份和还原对个人、企业和组织来说都至关重要。

    定期进行数据备份,并确保备份文件的可靠性和可访问性,是保障数据安全、避免风险和提高业务连续性的重要手段。

    因此,建议每个人和组织都应制定合理的数据备份策略,并定期检查和更新备份,以确保数据的安全和可靠性。

    希望这份分享可以帮助到你。

    我是老杨,一个奋斗在一线的资深研发老鸟,让我们一起聊聊技术,聊聊人生。

    都看到这了,求个点赞、关注、在看三连呗,感谢支持。

  • 相关阅读:
    有哪些常用的前端构建工具?
    win10 环境下Python 3.8按装fastapi paddlepaddle 进行图片文字识别1
    论文阅读【时间序列】TimeMixer (ICLR2024)
    Linux环境基础开发工具
    Visdrone转为YOLO格式
    如何更改eclipse的JDK版本
    深度学习网络模型——EfficientNet V1模型详解与代码复现
    代码 Revert 后再次 Merge 会丢失的问题,已解决
    启程,2022亚马逊云科技re:Invent Peter带来主题演讲
    GDB/MI 命令总结
  • 原文地址:https://blog.csdn.net/yangshuquan/article/details/140000057