MySQL 8.0在Windows上如何备份
现在用MySQL的人非常多,大多数人只是使用数据库,很少涉及数据库的备份。
但是在系统部署中,用到MySQL的人肯定避免不了数据库的数据备份。网上的资料大部分都是Linux系统上MySQL的备份资料,Windows系统上的备份资料较少,即使有,也是说明的很简单,而且很多给定的脚本也不能使用,下面我就数据库的全量备份和增量备份介绍一下。
备份的时候,第一次肯定需要做一次基础备份,然后再此基础上执行增量备份。
全量备份的例子如下:
@echo off set hour=%time:~0,2% if "%time:~0,1%"==" " set hour=0%time:~1,1% set now=%Date:~0,4%%Date:~5,2%%Date:~8,2%%hour%%Time:~3,2%%Time:~6,2% echo %now% set host=127.0.0.1 set port=3306 set user=root set pass=123456 set dbname=huali-ticket-server set backupfile=D:\backup\test\vr\%dbname%-all-%now%.sql
::下面的mysqldump的路径需要是执行脚本的系统上的全路径, "C:\Program Files\MySQL\MySQL Server 8.0\bin\mysqldump" -h%host% -P%port% -u%user% -p%pass% -c --add-drop-table %dbname% > %backupfile% echo delete files before 10 days forfiles /p D:\backup\test\vr /s /m *.sql /d -10 /c "cmd /c del @file /f"
增量备份的例子如下,增量备份只是把binlog文件备份下来即可:
@echo off ::服务器数据库ip 用户名 密码 set shost=127.0.0.1 set sport=3306 set suser=root set suserpwd=123456 ::mysql 二进制日志文件存放的位置 set filePath= "C:\Program Files\MySQL\MySQL Server 8.0\data" ::当前系统日期 20160309 set now=%DATE:~0,4%%DATE:~5,2%%DATE:~8,2% ::备份文件夹 set backup=D:\backup\test\vr\data if not exist %backup% md %backup% ::以日期命名的文件夹 set nowfile=%backup%\%now%-Increase if not exist %nowfile% md %nowfile% ::前一次日志文件名 set binlog=%nowfile%\binlog.txt "C:\Program Files\MySQL\MySQL Server 8.0\bin\mysql" -h%shost% -P%sport% -u%suser% -p%suserpwd% -e "show master status"|findstr -B binlog.>%binlog% ::处理日志文件名 只取binlog.001365 复制到目标文件夹 for /f " " %%i in (%binlog%) do copy %filePath%\%%i %nowfile% ::刷新日志产生新的日志 "C:\Program Files\MySQL\MySQL Server 8.0\bin\mysqladmin" -h%shost% -P%sport% -u%suser% -p%suserpwd% flush-logs
至于自动备份就需要用到Windows的执行计划了,通过执行计划执行上面的脚本即可,具体资料可以在网上查询,在此就不介绍了。
MySQL的命令可以参考博客园的如下文章但不限于: