前言
数据备份和还原在信息技术领域中具有非常重要的作用,不论是人为误操作、硬件故障、病毒感染、自然灾害还是其他原因,数据丢失的风险都是存在的。如果没有备份,一旦数据丢失,可能对个人、企业甚至整个组织造成巨大的损失。
数据是企业的核心资产,在面对突发事件或灾难时,定期备份的数据可以保护数据的完整性和保密性,确保数据的安全和可靠性,帮助组织迅速恢复数据和业务操作,减少停机时间,确保业务的持续运行。
下面分享一个 MySQL 如何进行自动备份和还原的脚本和方法。
自动备份
-
创建备份脚本批处理文件,如 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%
-
参数说明:
- -u: 用户名
- -p: 密码
- –opt: 提供了快速 dump 操作,默认开启
- –default-character-set: 使用charset_name作为默认字符集,mysqldump默认使用utf8.
- -E: dump 服务器事件,须有event权限
- –triggers: 导出表的触发器,默认启动
- -R: 导出存储过程和函数
- –hex-blob: 使用十六进制表示法转储二进制列
- –flush-logs: 切换一下binlog file,在开始dump前,flush 一个新的binlog file。此选项适用于为备份恢复加一个保险。
- -x %dbName% 数据库
-
以下地方需要注意:
- mysqldumpPath 本地 mysqldump.exe 路径
- dbName 需要备份的数据库
- dbUser 数据库用户名
- dbPwd 数据库密码
- outpurDir 备份文件输出路径
- –default-character-set 数据库字符集,要跟数据库一致
-
双击运行这个批处理文件,运行完成后在输出路径查看结果如:
- 结果:D:\dbbackup\bookmgr_20240618.sql
-
测试没问题后,把它加入到 Windows 计划任务,并设置为每天自动备份
还原
-
CMD 脚本
C:\Program Files\MySQL\MySQL Server 8.0\bin>mysql -uroot -pmysql --default-character-set=utf8mb4 bookmgr_restore < D:\dbbackup\bookmgr_2024.sql
-
参数说明
- -u: 用户名
- -p: 密码
- –default-character-set 数据库字符集,要跟备份一致
- bookmgr_restore 数据库,还原的目标数据库
- D:\dbbackup\bookmgr_20240618.sql 备份文件路径
其他
-
实践中,在还原时,碰到这个错:Unknown command ‘’’
这是因为有一个表的数据有单引号 ',备份时被转义为 ',还原的命令中 --default-character-set 跟备份文件不一致,所以无法识别,改为一致就没问题了
-
如果在备份时,不导出某个表的数据,可用
–ignore-table
参数,如:mysqldump -uroot -p --databases db_name --ignore-table=db_name.table_name
总结
总而言之,数据备份和还原对个人、企业和组织来说都至关重要。
定期进行数据备份,并确保备份文件的可靠性和可访问性,是保障数据安全、避免风险和提高业务连续性的重要手段。
因此,建议每个人和组织都应制定合理的数据备份策略,并定期检查和更新备份,以确保数据的安全和可靠性。
希望这份分享可以帮助到你。
我是老杨,一个奋斗在一线的资深研发老鸟,让我们一起聊聊技术,聊聊人生。
都看到这了,求个点赞、关注、在看三连呗,感谢支持。