Windows下实现MySQL自动备份的批处理(复制目录或MySQLdump备份)
2022-11-12 09:21:56
内容摘要
这篇文章主要为大家详细介绍了Windows下实现MySQL自动备份的批处理(复制目录或MySQLdump备份),具有一定的参考价值,可以用来参考一下。
对此感兴趣的朋友,看看idc笔记做的技术
文章正文
这篇文章主要为大家详细介绍了Windows下实现MySQL自动备份的批处理(复制目录或MySQLdump备份),具有一定的参考价值,可以用来参考一下。
对此感兴趣的朋友,看看idc笔记做的技术笔记!
今天有个需求要在 Windows 下实现数据库自动备份,拼凑了一下解决办法。实现的特性可指定多个数据库按照 年/月/日 的方式组织备份可选的使用 WinRAR 压缩备份使用计划任务实现定时备份具体代码备份代码如下:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 | <code> @ echo off & setlocal ENABLEEXTENSIONS :: ---------- 配置项 ---------- :: 备份放置的路径,加 \ set BACKUP_PATH=D:\Backup\ :: 要备份的数据库名称,多个用空格分隔 set DATABASES=database1 database2 database3 :: MySQL 用户名 set USERNAME=root :: MySQL 密码 set PASSWORD=123456 :: MySQL Bin 目录,加 \ :: 如果可以直接使用 mysqldump(安装时添加 MySQL Bin 目录到了环境变量),此处留空即可 set MYSQL=D:\SERVER\MySQL\bin\ :: WinRAR 自带命令行工具的可执行文件路径,长文件名注意用 Dos 长文件名书写方式 set WINRAR=C:\Progra~1\WinRAR\Rar.exe :: ---------- 以下请勿修改 ---------- set YEAR=% date :~0,4% set MONTH=% date :~5,2% set DAY=% date :~8,2% :: 如果在 dos 下输入 time 返回的不是 24 小时制(没有 0 填充),请自行修改此处 set HOUR=%time:~0,2% set MINUTE=%time:~3,2% set SECOND=%time:~6,2% set DIR=%BACKUP_PATH%%YEAR%\%MONTH%\%DAY%\ set ADDON=%YEAR%%MONTH%%DAY%%HOUR%%MINUTE%%SECOND% :: create dir if not exist %DIR% ( mkdir %DIR% 2>nul ) if not exist %DIR% ( echo Backup path: %DIR% not exists, create dir failed. goto exit ) cd /d %DIR% :: backup echo Start dump databases... for %%D in (%DATABASES%) do ( echo Dumping database %%D ... %MYSQL%mysqldump -u%USERNAME% -p%PASSWORD% %%D > %%D.%ADDON%.sql 2>nul :: winrar if exist %WINRAR% ( %WINRAR% a -k -r -s -m1 -ep1 %%D.%ADDON%.rar %%D.%ADDON%.sql 2>nul del /F /S /Q %%D.%ADDON%.sql 2>nul ) ) echo Done : exit </code> |
代码如下:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 | <code> @ echo off :: ------- 配置项 ------- :: 要执行的文件名 set FILE=D:\cron\cron_backup.bat :: 计划频率类型 set FREQUENCY=DAILY :: 频率,与上面的计划频率类型对应 set MODIFIER=1 :: 该计划执行的时间(24 小时制) set DATETIME=00:30:00 :: 计划的名字 set NAME= "Backup Cron Job" :: 计划执行用户,不建议修改 set USER= "System" :: ------- 以下请勿修改 ------- schtasks /Create /RU %USER% /SC %FREQUENCY% /MO %MODIFIER% /ST %DATETIME% /TN %NAME% /TR %FILE% pause </code> |
注:关于Windows下实现MySQL自动备份的批处理(复制目录或MySQLdump备份)的内容就先介绍到这里,更多相关文章的可以留意
代码注释