MySQL定期复制备份_Windows下实现MySQL自动备份的批处理(复制目录或mysqldump备份)...

今天有个需求要在 Windows 下实现数据库自动备份,拼凑了一下解决办法。

实现的特性

可指定多个数据库

按照 年/月/日 的方式组织备份

可选的使用 WinRAR 压缩备份

使用计划任务实现定时备份

具体代码

备份

复制代码 代码如下:

@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

增加计划任务

复制代码 代码如下:

@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

其中的

:: 计划频率类型,可选项:

:: MINUTE 分钟

:: DAILY 天

:: HOURLY 小时

:: WEEKLY 周

:: MONTHLY 月

:: 频率,与上面的计划频率类型对应

:: MINUTE: 1 到 1439 分钟

:: HOURLY: 1 - 23 小时

:: DAILY: 1 到 365 天

:: WEEKLY: 1 到 52 周

:: MONTHLY: 1 到 12,或 FIRST, SECOND, THIRD, FOURTH, LAST, LASTDAY

使用方法

将上面的两段代码分别保存为 cron_backup.bat 和 cron_backup_add.bat,并根据注释修改相关参数

确定好目录之后,运行 cron_backup_add.bat 将计划任务添加到系统中。

Windows Server 2003 / XP 可以通过 开始,控制面板,计划任务进入计划任务管理界面;

Windows Vista / 7 可以通过 计算机,右键,管理,系统工具,任务计划程序,任务计划程序库,进入计划任务管理界面。

手动运行该任务,查看备份目录来确认下备份是否成功。

待改进

增加删除多少天之前备份的功能

本文标题: Windows下实现MySQL自动备份的批处理(复制目录或mysqldump备份)

本文地址: http://www.cppcns.com/shujuku/mysql/87303.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值