歡迎光臨
每天分享高質量文章

Linux 下如何實現 MySQL 資料庫每天自動備份定時備份

(點選上方公號,快速關註我們)


來源:testcs_dn

blog.csdn.net/testcs_dn/article/details/48829785

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


備份是什麼?

為什麼要備份

容災方案建設

儲存介質


光碟 
磁帶 
硬碟 
磁碟陣列 
DAS:直接附加儲存 
NAS:網路附加儲存 
SAN:儲存區域網路 
雲儲存


這裡主要以本地磁碟為儲存介質講一下計劃任務的新增使用,基本的備份指令碼,其它儲存介質只是介質的訪問方式可能不大一樣。


1、檢視磁碟空間情況:


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


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


# df -hFilesystem


2、建立備份目錄:


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


cd /home
mkdir backupcd backup


3、建立備份Shell指令碼:


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


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


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 替換為實際的資料庫名;


4、新增可執行許可權:


chmod u+x bkDatabaseName.sh


新增可執行許可權之後先執行一下,看看指令碼有沒有錯誤,能不能正常使用;


./bkDatabaseName.sh


5、新增計劃任務


檢測或安裝 crontab


確認crontab是否安裝: 


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


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


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


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


新增計劃任務


執行命令:


crontab -e


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


輸入以下內容並儲存:


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


具體是什麼意思呢? 


意思是每一分鐘執行一次shell指令碼“/home/backup/bkDatabaseName.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)

【關於投稿】


如果大家有原創好文投稿,請直接給公號傳送留言。


① 留言格式:
【投稿】+《 文章標題》+ 文章連結

② 示例:
【投稿】
《不要自稱是程式員,我十多年的 IT 職場總結》:http://blog.jobbole.com/94148/


③ 最後請附上您的個人簡介哈~

看完本文有收穫?請轉發分享給更多人

關註「資料分析與開發」,提升資料技能

贊(0)

分享創造快樂