Windows下實現MySQL自動備份的批處理(複製目錄或mysqldump備份)_Mysql

來源:互聯網
上載者:User
今天有個需求要在 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 可以通過 電腦,右鍵,管理,系統工具,工作排程器,工作排程器庫,進入計劃任務管理介面。
手動運行該任務,查看備份目錄來確認下備份是否成功。

待改進
增加刪除多少天之前備份的功能
相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.