数据备份和还原在信息技术领域中具有非常重要的作用,不论是人为误操作、硬件故障、病毒感染、自然灾害还是其他原因,数据丢失的风险都是存在的。如果没有备份,一旦数据丢失,可能对个人、企业甚至整个组织造成巨大的损失。
数据是企业的核心资产,在面对突发事件或灾难时,定期备份的数据可以保护数据的完整性和保密性,确保数据的安全和可靠性,帮助组织迅速恢复数据和业务操作,减少停机时间,确保业务的持续运行。
下面分享一个 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%
参数说明:
以下地方需要注意:
双击运行这个批处理文件,运行完成后在输出路径查看结果如:
测试没问题后,把它加入到 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
参数说明
实践中,在还原时,碰到这个错:Unknown command ‘’’
这是因为有一个表的数据有单引号 ',备份时被转义为 ',还原的命令中 --default-character-set 跟备份文件不一致,所以无法识别,改为一致就没问题了
如果在备份时,不导出某个表的数据,可用 –ignore-table
参数,如:
mysqldump -uroot -p --databases db_name --ignore-table=db_name.table_name
总而言之,数据备份和还原对个人、企业和组织来说都至关重要。
定期进行数据备份,并确保备份文件的可靠性和可访问性,是保障数据安全、避免风险和提高业务连续性的重要手段。
因此,建议每个人和组织都应制定合理的数据备份策略,并定期检查和更新备份,以确保数据的安全和可靠性。
希望这份分享可以帮助到你。
我是老杨,一个奋斗在一线的资深研发老鸟,让我们一起聊聊技术,聊聊人生。
都看到这了,求个点赞、关注、在看三连呗,感谢支持。