Windows下實現(xiàn)MySQL自動備份的批處理(復(fù)制目錄或mysqldump備份)
更新時間:2012年05月01日 21:08:38 作者:
Windows下實現(xiàn)MySQL自動備份的批處理,新建目錄并復(fù)制壓縮,結(jié)合windows計劃任務(wù)方便實現(xiàn)每天的自動備份
今天有個需求要在 Windows 下實現(xiàn)數(shù)據(jù)庫自動備份,拼湊了一下解決辦法。
實現(xiàn)的特性
可指定多個數(shù)據(jù)庫
按照 年/月/日 的方式組織備份
可選的使用 WinRAR 壓縮備份
使用計劃任務(wù)實現(xiàn)定時備份
具體代碼
備份
@echo off & setlocal ENABLEEXTENSIONS
:: ---------- 配置項 ----------
:: 備份放置的路徑,加 \
set BACKUP_PATH=D:\Backup\
:: 要備份的數(shù)據(jù)庫名稱,多個用空格分隔
set DATABASES=database1 database2 database3
:: MySQL 用戶名
set USERNAME=root
:: MySQL 密碼
set PASSWORD=123456
:: MySQL Bin 目錄,加 \
:: 如果可以直接使用 mysqldump(安裝時添加 MySQL Bin 目錄到了環(huán)境變量),此處留空即可
set MYSQL=D:\SERVER\MySQL\bin\
:: WinRAR 自帶命令行工具的可執(zhí)行文件路徑,長文件名注意用 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
增加計劃任務(wù)
@echo off
:: ------- 配置項 -------
:: 要執(zhí)行的文件名
set FILE=D:\cron\cron_backup.bat
:: 計劃頻率類型
set FREQUENCY=DAILY
:: 頻率,與上面的計劃頻率類型對應(yīng)
set MODIFIER=1
:: 該計劃執(zhí)行的時間(24 小時制)
set DATETIME=00:30:00
:: 計劃的名字
set NAME="Backup Cron Job"
:: 計劃執(zhí)行用戶,不建議修改
set USER="System"
:: ------- 以下請勿修改 -------
schtasks /Create /RU %USER% /SC %FREQUENCY% /MO %MODIFIER% /ST %DATETIME% /TN %NAME% /TR %FILE%
pause
其中的
:: 計劃頻率類型,可選項:
:: MINUTE 分鐘
:: DAILY 天
:: HOURLY 小時
:: WEEKLY 周
:: MONTHLY 月
:: 頻率,與上面的計劃頻率類型對應(yīng)
:: 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,并根據(jù)注釋修改相關(guān)參數(shù)
確定好目錄之后,運行 cron_backup_add.bat 將計劃任務(wù)添加到系統(tǒng)中。
Windows Server 2003 / XP 可以通過 開始,控制面板,計劃任務(wù)進入計劃任務(wù)管理界面;
Windows Vista / 7 可以通過 計算機,右鍵,管理,系統(tǒng)工具,任務(wù)計劃程序,任務(wù)計劃程序庫,進入計劃任務(wù)管理界面。
手動運行該任務(wù),查看備份目錄來確認(rèn)下備份是否成功。
待改進
增加刪除多少天之前備份的功能
實現(xiàn)的特性
可指定多個數(shù)據(jù)庫
按照 年/月/日 的方式組織備份
可選的使用 WinRAR 壓縮備份
使用計劃任務(wù)實現(xiàn)定時備份
具體代碼
備份
復(fù)制代碼 代碼如下:
@echo off & setlocal ENABLEEXTENSIONS
:: ---------- 配置項 ----------
:: 備份放置的路徑,加 \
set BACKUP_PATH=D:\Backup\
:: 要備份的數(shù)據(jù)庫名稱,多個用空格分隔
set DATABASES=database1 database2 database3
:: MySQL 用戶名
set USERNAME=root
:: MySQL 密碼
set PASSWORD=123456
:: MySQL Bin 目錄,加 \
:: 如果可以直接使用 mysqldump(安裝時添加 MySQL Bin 目錄到了環(huán)境變量),此處留空即可
set MYSQL=D:\SERVER\MySQL\bin\
:: WinRAR 自帶命令行工具的可執(zhí)行文件路徑,長文件名注意用 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
增加計劃任務(wù)
復(fù)制代碼 代碼如下:
@echo off
:: ------- 配置項 -------
:: 要執(zhí)行的文件名
set FILE=D:\cron\cron_backup.bat
:: 計劃頻率類型
set FREQUENCY=DAILY
:: 頻率,與上面的計劃頻率類型對應(yīng)
set MODIFIER=1
:: 該計劃執(zhí)行的時間(24 小時制)
set DATETIME=00:30:00
:: 計劃的名字
set NAME="Backup Cron Job"
:: 計劃執(zhí)行用戶,不建議修改
set USER="System"
:: ------- 以下請勿修改 -------
schtasks /Create /RU %USER% /SC %FREQUENCY% /MO %MODIFIER% /ST %DATETIME% /TN %NAME% /TR %FILE%
pause
其中的
:: 計劃頻率類型,可選項:
:: MINUTE 分鐘
:: DAILY 天
:: HOURLY 小時
:: WEEKLY 周
:: MONTHLY 月
:: 頻率,與上面的計劃頻率類型對應(yīng)
:: 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,并根據(jù)注釋修改相關(guān)參數(shù)
確定好目錄之后,運行 cron_backup_add.bat 將計劃任務(wù)添加到系統(tǒng)中。
Windows Server 2003 / XP 可以通過 開始,控制面板,計劃任務(wù)進入計劃任務(wù)管理界面;
Windows Vista / 7 可以通過 計算機,右鍵,管理,系統(tǒng)工具,任務(wù)計劃程序,任務(wù)計劃程序庫,進入計劃任務(wù)管理界面。
手動運行該任務(wù),查看備份目錄來確認(rèn)下備份是否成功。
待改進
增加刪除多少天之前備份的功能
您可能感興趣的文章:
- MySQL數(shù)據(jù)遷移使用MySQLdump命令
- mysql備份腳本 mysqldump使用方法詳解
- 詳解 linux mysqldump 導(dǎo)出數(shù)據(jù)庫、數(shù)據(jù)、表結(jié)構(gòu)
- 詳談mysqldump數(shù)據(jù)導(dǎo)出的問題
- 淺談mysqldump使用方法(MySQL數(shù)據(jù)庫的備份與恢復(fù))
- 8種手動和自動備份MySQL數(shù)據(jù)庫的方法
- linux實現(xiàn)mysql數(shù)據(jù)庫每天自動備份定時備份
- 詳解Mysql自動備份與恢復(fù)的幾種方法(圖文教程)
- CentOS系統(tǒng)下如何設(shè)置mysql每天自動備份
- Centos7中MySQL數(shù)據(jù)庫使用mysqldump進行每日自動備份的編寫
相關(guān)文章
SQL重復(fù)記錄查詢 查詢多個字段、多表查詢、刪除重復(fù)記錄的方法
下面小編就為大家?guī)硪黄猄QL重復(fù)記錄查詢 查詢多個字段、多表查詢、刪除重復(fù)記錄的方法。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2016-09-09Myeclipse連接mysql數(shù)據(jù)庫心得體會
這篇文章主要為大家詳細(xì)介紹了MyEclipse連接MySQL數(shù)據(jù)庫圖文教程,具有一定的參考價值,感興趣的小伙伴們可以參考一下2016-10-10mysql 8.0.22壓縮包完整安裝與配置教程圖解(親測安裝有效)
這篇文章主要介紹了mysql 8.0.22壓縮包完整安裝與配置教程圖解(親測安裝有效),本文通過圖文并茂的形式給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2020-12-12