備份是容災(zāi)的基礎(chǔ),是指為防止系統(tǒng)出現(xiàn)操作失誤或系統(tǒng)故障導(dǎo)致數(shù)據(jù)丟失,而將全部或部分?jǐn)?shù)據(jù)集合從應(yīng)用主機(jī)的硬盤或陣列復(fù)制到其它的存儲介質(zhì)的過程。而對于一些網(wǎng)站、系統(tǒng)來說,數(shù)據(jù)庫就是一切,所以做好數(shù)據(jù)庫的備份是至關(guān)重要的!
備份是什么?
為什么要備份?
容災(zāi)方案建設(shè)
存儲介質(zhì)
光盤
磁帶
硬盤
磁盤陣列
DAS:直接附加存儲
NAS:網(wǎng)絡(luò)附加存儲
SAN:存儲區(qū)域網(wǎng)絡(luò)
云存儲
這里主要以本地磁盤為存儲介質(zhì)講一下計(jì)劃任務(wù)的添加使用,基本的備份腳本,其它存儲介質(zhì)只是介質(zhì)的訪問方式可能不大一樣。
1、查看磁盤空間情況:
既然是定時(shí)備份,就要選擇一個(gè)空間充足的磁盤空間,避免出現(xiàn)因空間不足導(dǎo)致備份失敗,數(shù)據(jù)丟失的惡果!
存儲到當(dāng)前磁盤這是最簡單,卻是最不推薦的;服務(wù)器有多塊硬盤,最好是把備份存放到另一塊硬盤上;有條件就選擇更好更安全的存儲介質(zhì);
2、創(chuàng)建備份目錄:
上面我們使用命令看出 / home 下空間比較充足,所以可以考慮在 / home 保存?zhèn)浞菸募?/p>
cd /home
mkdir backup
cd backup
3、創(chuàng)建備份 Shell 腳本:
注意把以下命令中的 DatabaseName 換為實(shí)際的數(shù)據(jù)庫名稱;
當(dāng)然,你也可以使用其實(shí)的命名規(guī)則!
vi bkDatabaseName.sh
輸入 / 粘貼以下內(nèi)容:
#!/bin/bash
/usr/local/mysql/bin/mysqldump -uusername -ppassword DatabaseName > /home/backup/DatabaseName_$(date +%Y%m%d_%H%M%S).sql
對備份進(jìn)行壓縮:
#!/bin/bash
/usr/local/mysql/bin/mysqldump -uusername -ppassword DatabaseName | gzip > /home/backup/DatabaseName_$(date +%Y%m%d_%H%M%S).sql.gz
注意:
把 username 替換為實(shí)際的用戶名;
把 password 替換為實(shí)際的密碼;
把 DatabaseName 替換為實(shí)際的數(shù)據(jù)庫名;
4、添加可執(zhí)行權(quán)限:
chmod u+x bkDatabaseName.sh
添加可執(zhí)行權(quán)限之后先執(zhí)行一下,看看腳本有沒有錯(cuò)誤,能不能正常使用;
./bkDatabaseName.sh
5、添加計(jì)劃任務(wù)
檢測或安裝 crontab
確認(rèn) crontab 是否安裝:
執(zhí)行 crontab 命令如果報(bào) command not found,就表明沒有安裝
# crontab
-bash: crontab: command not found
如時(shí)沒有安裝 crontab,需要先安裝它,具體步驟請參考:
CentOS 下使用 yum 命令安裝計(jì)劃任務(wù)程序 crontab
使用 rpm 命令從 CentOS 系統(tǒng)盤安裝計(jì)劃任務(wù)程序 crontab
添加計(jì)劃任務(wù)
執(zhí)行命令:
crontab -e
這時(shí)就像使用 vi 編輯器一樣,可以對計(jì)劃任務(wù)進(jìn)行編輯。
輸入以下內(nèi)容并保存:
*/1 * * * * /home/backup/bkDatabaseName.sh
具體是什么意思呢?
意思是每一分鐘執(zhí)行一次 shell 腳本 “/home/backup/bkDatabaseName.sh”。
例如:
修改 /etc/crontab
#vi /etc/crontab
01 3 * * * root/home/backup/bkDatabaseName.sh
表示每天 3 點(diǎn)鐘執(zhí)行備份
退出編輯頁:點(diǎn)擊 ESC 推出,然后點(diǎn)擊 ":wq"w 寫入 write q 推出 quit
例如:在每周一中午 12 點(diǎn)運(yùn)行一次
vi /etc/crontab 然后: 在最后一行, 0 12 * 1 * root run-parts /home/abckup.sh
6、測試任務(wù)是否執(zhí)行
很簡單,我們就執(zhí)行幾次 “l(fā)s” 命令,看看一分鐘過后文件有沒有被創(chuàng)建就可以了!
如果任務(wù)執(zhí)行失敗了,可以通過以下命令查看任務(wù)日志:
# 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 列小時(shí) 1~23(0 表示子夜)
第 3 列日 1~31
第 4 列月 1~12
第 5 列星期 0~6(0 表示星期天)
第 6 列要運(yùn)行的命令
-
Linux
+關(guān)注
關(guān)注
87文章
11292瀏覽量
209331 -
數(shù)據(jù)庫
+關(guān)注
關(guān)注
7文章
3794瀏覽量
64362 -
MySQL
+關(guān)注
關(guān)注
1文章
804瀏覽量
26531
原文標(biāo)題:Linux 下如何實(shí)現(xiàn) MySQL 數(shù)據(jù)庫定時(shí)自動(dòng)備份?
文章出處:【微信號:magedu-Linux,微信公眾號:馬哥Linux運(yùn)維】歡迎添加關(guān)注!文章轉(zhuǎn)載請注明出處。
發(fā)布評論請先 登錄
相關(guān)推薦
評論