備份是容災的基礎,是指爲防止系統出現操做失誤或系統故障致使數據丟失,而將所有或部分數據集合從應用主機的硬盤或陣列複製到其它的存儲介質的過程。而對於一些網站、系統來講,數據庫就是一切,因此作好數據庫的備份是相當重要的!mysql
光盤
磁帶
硬盤
磁盤陣列
DAS:直接附加存儲
NAS:網絡附加存儲
SAN:存儲區域網絡
雲存儲sql
這裏主要以本地磁盤爲存儲介質講一下計劃任務的添加使用,基本的備份腳本,其它存儲介質只是介質的訪問方式可能不大同樣。shell
既然是定時備份,就要選擇一個空間充足的磁盤空間,避免出現因空間不足致使備份失敗,數據丟失的惡果!
存儲到當前磁盤這是最簡單,倒是最不推薦的;服務器有多塊硬盤,最好是把備份存放到另外一塊硬盤上;有條件就選擇更好更安全的存儲介質;數據庫
# df -h Filesystem Size Used Avail Use% Mounted on /dev/mapper/VolGroup-lv_root 50G 46G 1.6G 97% / tmpfs 1.9G 92K 1.9G 1% /dev/shm /dev/sda1 485M 39M 421M 9% /boot /dev/mapper/VolGroup-lv_home 534G 3.6G 503G 1% /home
上面咱們使用命令看出/home下空間比較充足,因此能夠考慮在/home保存備份文件;安全
cd /home mkdir backup cd backup
注意把如下命令中的DatabaseName換爲實際的數據庫名稱;
固然,你也可使用其實的命名規則!bash
vi bkDatabaseName.sh
輸入/粘貼如下內容:服務器
#!/bin/bash mysqldump -uusername -ppassword DatabaseName > /home/backup/DatabaseName_$(date +%Y%m%d_%H%M%S).sql
對備份進行壓縮:網絡
#!/bin/bash mysqldump -uusername -ppassword DatabaseName | gzip > /home/backup/DatabaseName_$(date +%Y%m%d_%H%M%S).sql.gz
注意:
把 username 替換爲實際的用戶名;
把 password 替換爲實際的密碼;
把 DatabaseName 替換爲實際的數據庫名;app
chmod u+x bkDatabaseName.sh
添加可執行權限以後先執行一下,看看腳本有沒有錯誤,能不能正常使用;編輯器
./bkDatabaseName.sh
確認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」。
很簡單,咱們就執行幾回「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)