mysql备份脚本

MySQL备份脚本

Windows下备份脚本1

rem auther:www.yumi-info.com
rem date:20171222
rem ******MySQL backup start********
@echo off
forfiles /p "E:\vivachek\backup" /m backup_*.sql -d -10 /c "cmd /c del /f @path"
set "Ymd=%date:~0,4%%date:~5,2%%date:~8,2%0%time:~1,1%%time:~3,2%%time:~6,2%"
"C:\Program Files\MySQL\MySQL Server 5.6\bin\mysqldump" --opt --single-transaction=TRUE --user=root --password=Nov2014 --host=127.0.0.1 --protocol=tcp --port=3306 --default-character-set=utf8 --single-transaction=TRUE --routines --events "vivachekcloud" > "E:\vivachek\backup\backup_%Ymd%.sql"
@echo on
rem ******MySQL backup end********

改版,(加压缩)

rem auther:www.yumi-info.com
rem date:20171222
rem ******MySQL backup start********
@echo off
forfiles /p "E:\vivachek\backup" /m backup_*.sql -d -5 /c "cmd /c del /f @path"
forfiles /p "E:\vivachek\backup" /m backup_*.zip -d -10 /c "cmd /c del /f @path"
set "Ymd=%date:~0,4%%date:~5,2%%date:~8,2%0%time:~1,1%%time:~3,2%%time:~6,2%"
"C:\Program Files\MySQL\MySQL Server 5.6\bin\mysqldump" --opt --single-transaction=TRUE --user=root --password=Nov2014 --host=127.0.0.1 --protocol=tcp --port=3306 --default-character-set=utf8 --single-transaction=TRUE --routines --events "vivachekcloud" > "E:\vivachek\backup\backup_%Ymd%.sql"
"E:\vivachek\7-Zip\7z.exe" a "E:\vivachek\backup\backup_%Ymd%.sql.zip" "E:\vivachek\backup\backup_%Ymd%.sql"

@echo on
rem ******MySQL backup end********

Windows下远程备份脚本2

转载: https://blog.csdn.net/qq_38647878/article/details/104032107

本着不将鸡蛋放在一个篮子里的思想,我在远程做了数据的备份,在本地又做了一个备份

@echo off
set hour=%time:~,2%
if "%time:~,1%"==" " set hour=0%time:~1,1%

set "Ymd=%date:~0,4%%date:~5,2%%date:~8,2%%hour%%time:~3,2%%time:~6,2%"
D:\java_workspace\mysql-5.7.28\bin\mysqldump --opt -u username --password=xxx -h远程IP database > D:\java_workspace\db.bak\backup_database_%Ymd%.sql
"D:\software\7-Zip\7z.exe" a "D:\java_workspace\db.bak\backup_database_%Ymd%.sql.zip" "D:\java_workspace\db.bak\backup_database_%Ymd%.sql"
del /F "D:\java_workspace\db.bak\backup_database_%Ymd%.sql"
forfiles /p "D:\java_workspace\db.bak"  /s /m *.zip /d -30 /c "cmd /c del @path && echo %Ymd% delete @file success!" > del_bak.log
@echo on

下面的一行具体的脚本意思是备份远程数据库到D盘的db.bak文件夹下,以backup_database_20200112030000.sql的格式输出

D:\java_workspace\mysql-5.7.28\bin\mysqldump --opt -u username --password=xxx -h远程IP database > D:\java_workspace\db.bak\backup_database_%Ymd%.sql

然后是压缩.sql文件

"D:\software\7-Zip\7z.exe" a "D:\java_workspace\db.bak\backup_database_%Ymd%.sql.zip" "D:\java_workspace\db.bak\backup_database_%Ymd%.sql"

然后再将.sql文件删除掉

del /F "D:\java_workspace\db.bak\backup_database_%Ymd%.sql"

最后将30天前的文件删除

forfiles /p "D:\java_workspace\db.bak"  /s /m *.zip /d -30 /c "cmd /c del @path && echo %Ymd% delete @file success!" > del_bak.log

OK,脚本已经写好了,之后使用Windows的定时计划任务,添加一个备份计划即可。

Windows下备份脚本3

参考: https://blog.51cto.com/u_16099279/6284045

实现的特性

①,可指定多个数据库 ②,按照 年/月/日 的方式组织备份 ③,可选的使用 WinRAR 压缩备份 ④,使用计划任务实现定时备份

原理

利用windows批处理脚本(.bat文件)执行mysql 数据库备份命令 mysqldump ,若指定了winrar 安装路径,则会使用winrar 压缩备份数据。双击 .bat 文件可执行

①,备份数据库数据

标黄颜色的地方,是需要读者自行修改成你自己的配置信息的,保存以下文件内容为 backup.bat 文件

@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

②,自动备份

创建windows定时任务自动备份(其实就是创建定时任务执行上面创建的备份数据库脚本,注意脚本保存位置),保存以下文件内容为 backup_plan.bat 文件

@echo off 

:: ------- 配置项 ------- 

:: 要执行的文件名 
set FILE=.\backup.bat
:: 计划频率类型 
set FREQUENCY=DAILY 

:: 频率,与上面的计划频率类型对应 
set MODIFIER=1 

:: 该计划执行的时间(24 小时制) 
set DATETIME=00:30:00 

:: 计划的名字 
set NAME="Backup Mysql 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

评论

发表回复

您的电子邮箱地址不会被公开。 必填项已用 * 标注