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

发布于:2024-06-27 ⋅ 阅读:(21) ⋅ 点赞:(0)

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
    

总结

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

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

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

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

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

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