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