1. 程式人生 > >Linux下實現 MySQL 數據庫定時自動備份

Linux下實現 MySQL 數據庫定時自動備份

用戶 itl 安裝 centos fin nta 腳本 apach 例子

Linux 下如何實現 MySQL 數據庫定時自動備份?

概述:備份是容災的基礎,是指為防止系統出現操作失誤或系統故障導致數據丟失,而將全部或部分數據集合從應用主機的硬盤或陣列復制到其它的存儲介質的過程。而對於一些網站、系統來說,數據庫就是一切,所以做好數據庫的備份是至關重要的!

備份是什麽?

技術分享圖片

為什麽要備份?

技術分享圖片

容災方案建設

技術分享圖片

存儲介質

光盤

磁帶

硬盤

磁盤陣列

DAS:直接附加存儲

NAS:網絡附加存儲

SAN:存儲區域網絡

雲存儲

這裏主要以本地磁盤為存儲介質講一下計劃任務的添加使用,基本的備份腳本,其它存儲介質只是介質的訪問方式可能不大一樣。

1、查看磁盤空間情況:

既然是定時備份,就要選擇一個空間充足的磁盤空間,避免出現因空間不足導致備份失敗,數據丟失的惡果!

存儲到當前磁盤這是最簡單,卻是最不推薦的;服務器有多塊硬盤,最好是把備份存放到另一塊硬盤上;有條件就選擇更好更安全的存儲介質;

技術分享圖片

2、創建備份目錄:

上面我們使用命令看出 / home 下空間比較充足,所以可以考慮在 / home 保存備份文件;

cd /home

mkdir backup

cd backup

3、創建備份 Shell 腳本:

註意把以下命令中的 DatabaseName 換為實際的數據庫名稱;

當然,你也可以使用其實的命名規則!

vi bkDatabaseName.sh

輸入 / 粘貼以下內容:

#!/bin/bash

/usr/local/mysql/bin/mysqldump -uusername -ppassword DatabaseName > /home/backup/DatabaseName_$(date +%Y%m%d_%H%M%S).sql

對備份進行壓縮:

#!/bin/bash

/usr/local/mysql/bin/mysqldump -uusername -ppassword DatabaseName | gzip > /home/backup/DatabaseName_$(date +%Y%m%d_%H%M%S).sql.gz

註意:

把 username 替換為實際的用戶名;

把 password 替換為實際的密碼;

把 DatabaseName 替換為實際的數據庫名;

4、添加可執行權限:

chmod u+x bkDatabaseName.sh

添加可執行權限之後先執行一下,看看腳本有沒有錯誤,能不能正常使用;

./bkDatabaseName.sh

5、添加計劃任務

檢測或安裝 crontab

確認 crontab 是否安裝:

執行 crontab 命令如果報 command not found,就表明沒有安裝

# crontab

-bash: crontab: command not found

如時沒有安裝 crontab,需要先安裝它,具體步驟請參考:

CentOS 下使用 yum 命令安裝計劃任務程序 crontab

使用 rpm 命令從 CentOS 系統盤安裝計劃任務程序 crontab

添加計劃任務

執行命令:

crontab -e

這時就像使用 vi 編輯器一樣,可以對計劃任務進行編輯。

輸入以下內容並保存:

*/1 * * * * /home/backup/bkDatabaseName.sh

具體是什麽意思呢?

意思是每一分鐘執行一次 shell 腳本 “/home/backup/bkDatabaseName.sh”。

例如:

修改 /etc/crontab

#vi /etc/crontab

01 3 * * * root/home/backup/bkDatabaseName.sh

表示每天 3 點鐘執行備份

退出編輯頁:點擊 ESC 推出,然後點擊 ":wq"w 寫入 write q 推出 quit

例如:在每周一中午 12 點運行一次

vi /etc/crontab 然後: 在最後一行, 0 12 * 1 * root run-parts /home/abckup.sh

6、測試任務是否執行

很簡單,我們就執行幾次 “ls” 命令,看看一分鐘過後文件有沒有被創建就可以了!

如果任務執行失敗了,可以通過以下命令查看任務日誌:

# tail -f /var/log/cron

輸出類似如下:

Sep 30 14:01:01 bogon run-parts(/etc/cron.hourly)[2503]: starting 0anacron

Sep 30 14:01:01 bogon run-parts(/etc/cron.hourly)[2512]: finished 0anacron

Sep 30 15:01:01 bogon CROND[3092]: (root) CMD (run-parts /etc/cron.hourly)

Sep 30 15:01:01 bogon run-parts(/etc/cron.hourly)[3092]: starting 0anacron

Sep 30 15:01:02 bogon run-parts(/etc/cron.hourly)[3101]: finished 0anacron

Sep 30 15:50:44 bogon crontab[3598]: (root) BEGIN EDIT (root)

Sep 30 16:01:01 bogon CROND[3705]: (root) CMD (run-parts /etc/cron.hourly)

Sep 30 16:01:01 bogon run-parts(/etc/cron.hourly)[3705]: starting 0anacron

Sep 30 16:01:01 bogon run-parts(/etc/cron.hourly)[3714]: finished 0anacron

Sep 30 16:15:29 bogon crontab[3598]: (root) END EDIT (root)

Crontab 的格式

第 1 列分鐘 1~59

第 2 列小時 1~23(0 表示子夜)

第 3 列日 1~31

第 4 列月 1~12

第 5 列星期 0~6(0 表示星期天)

第 6 列要運行的命令

下面是 crontab 的格式:

分 時 日 月 星期 要運行的命令

這裏有 crontab 文件條目的一些例子:

30 21 * * * /usr/local/apache/bin/apachectl restart

上面的例子表示每晚的 21:30 重啟 apache。

45 4 1,10,22 * * /usr/local/apache/bin/apachectl restart

上面的例子表示每月 1、10、22 日的 4 : 45 重啟 apache。

10 1 * * 6,0 /usr/local/apache/bin/apachectl restart

上面的例子表示每周六、周日的 1 : 10 重啟 apache。

0,30 18-23 * * * /usr/local/apache/bin/apachectl restart

上面的例子表示在每天 18 : 00 至 23 : 00 之間每隔 30 分鐘重啟 apache。

0 23 * * 6 /usr/local/apache/bin/apachectl restart

上面的例子表示每星期六的 11 : 00 pm 重啟 apache。

0 */1 * * * /usr/local/apache/bin/apachectl restart

每一小時重啟 apache

#20160912 修正,感謝 @張瓊的指正,之前寫錯了,*/1 和 * 表示的同樣的意思,對於 / 的用法,可以參考另一篇文章 Crontab 中的除號到底怎麽用?

0 23-7/1 * * * /usr/local/apache/bin/apachectl restart

晚上 11 點到早上 7 點之間,每隔一小時重啟 apache

0 11 4 * mon-wed /usr/local/apache/bin/apachectl restart

每月的 4 號與每周一到周三的 11 點重啟 apache

0 4 1 jan * /usr/local/apache/bin/apachectl restart

一月一號的 4 點重啟 apache

Linux下實現 MySQL 數據庫定時自動備份