linux實(shí)現(xiàn)mysql數(shù)據(jù)庫每天自動(dòng)備份定時(shí)備份
概述
備份是容災(zāi)的基礎(chǔ),是指為防止系統(tǒng)出現(xiàn)操作失誤或系統(tǒng)故障導(dǎo)致數(shù)據(jù)丟失,而將全部或部分?jǐn)?shù)據(jù)集合從應(yīng)用主機(jī)的硬盤或陣列復(fù)制到其它的存儲(chǔ)介質(zhì)的過程。而對(duì)于一些網(wǎng)站、系統(tǒng)來說,數(shù)據(jù)庫就是一切,所以做好數(shù)據(jù)庫的備份是至關(guān)重要的!
備份是什么?

為什么要備份

容災(zāi)方案建設(shè)

存儲(chǔ)介質(zhì)
光盤
磁帶
硬盤
磁盤陣列
DAS:直接附加存儲(chǔ)
NAS:網(wǎng)絡(luò)附加存儲(chǔ)
SAN:存儲(chǔ)區(qū)域網(wǎng)絡(luò)
云存儲(chǔ)
這里主要以本地磁盤為存儲(chǔ)介質(zhì)講一下計(jì)劃任務(wù)的添加使用,基本的備份腳本,其它存儲(chǔ)介質(zhì)只是介質(zhì)的訪問方式可能不大一樣。
1、查看磁盤空間情況:
既然是定時(shí)備份,就要選擇一個(gè)空間充足的磁盤空間,避免出現(xiàn)因空間不足導(dǎo)致備份失敗,數(shù)據(jù)丟失的惡果!
存儲(chǔ)到當(dāng)前磁盤這是最簡(jiǎn)單,卻是最不推薦的;服務(wù)器有多塊硬盤,最好是把備份存放到另一塊硬盤上;有條件就選擇更好更安全的存儲(chǔ)介質(zhì);
# 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
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 mysqldump -uusername -ppassword DatabaseName > /home/backup/DatabaseName_$(date +%Y%m%d_%H%M%S).sql
對(duì)備份進(jìn)行壓縮:
#!/bin/bash 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ù)
檢測(cè)或安裝 crontab
確認(rèn)crontab是否安裝:
執(zhí)行 crontab 命令如果報(bào) command not found,就表明沒有安裝
# crontab -bash: crontab: command not found
如時(shí)沒有安裝 crontab,需要先安裝它,具體步驟請(qǐng)參考:
CentOS下使用yum命令安裝計(jì)劃任務(wù)程序crontab
使用rpm命令從CentOS系統(tǒng)盤安裝計(jì)劃任務(wù)程序crontab
添加計(jì)劃任務(wù)
執(zhí)行命令:
crontab -e
這時(shí)就像使用vi編輯器一樣,可以對(duì)計(jì)劃任務(wù)進(jìn)行編輯。
輸入以下內(nèi)容并保存:
*/1 * * * * /home/backup/bkDatabaseName.sh
具體是什么意思呢?
意思是每一分鐘執(zhí)行一次shell腳本“/home/backup/bkDatabaseName.sh”。
6、測(cè)試任務(wù)是否執(zhí)行
很簡(jiǎn)單,我們就執(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)
總結(jié)
以上所述是小編給大家介紹的linux實(shí)現(xiàn)mysql數(shù)據(jù)庫每天自動(dòng)備份定時(shí)備份,希望對(duì)大家有所幫助,如果大家有任何疑問請(qǐng)給我留言,小編會(huì)及時(shí)回復(fù)大家的。在此也非常感謝大家對(duì)腳本之家網(wǎng)站的支持!
- Linux shell實(shí)現(xiàn)每天定時(shí)備份mysql數(shù)據(jù)庫
- linux實(shí)現(xiàn)定時(shí)備份mysql數(shù)據(jù)庫的簡(jiǎn)單方法
- MySQL數(shù)據(jù)庫定時(shí)備份的實(shí)現(xiàn)方法
- shell腳本實(shí)現(xiàn)mysql定時(shí)備份、刪除、恢復(fù)功能
- linux定時(shí)備份MySQL數(shù)據(jù)庫并刪除以前的備份文件(推薦)
- mysql定時(shí)自動(dòng)備份數(shù)據(jù)庫的方法步驟
- MySQL 數(shù)據(jù)庫定時(shí)備份的幾種方式(全面)
- Linux系統(tǒng)每日定時(shí)備份mysql數(shù)據(jù)的方法步驟
相關(guān)文章
mysql啟動(dòng)錯(cuò)誤之mysql啟動(dòng)報(bào)1067錯(cuò)誤解決方法
MYSQL啟動(dòng)報(bào)1067錯(cuò)誤,系統(tǒng)日志中是“服務(wù) mysql 意外停止” Mysql日志中則是:Plugin 'FEDERATED' is disabled,下面給出解決方法2014-02-02
MySQL數(shù)據(jù)庫優(yōu)化之分表分庫操作實(shí)例詳解
這篇文章主要介紹了MySQL數(shù)據(jù)庫優(yōu)化之分表分庫操作,結(jié)合實(shí)例形式詳細(xì)分析了mysql數(shù)據(jù)庫分表分庫垂直拆分、水平拆分相關(guān)原理以及應(yīng)用案例,需要的朋友可以參考下2020-01-01
MySQL按天分組統(tǒng)計(jì)一定時(shí)間內(nèi)的數(shù)據(jù)實(shí)例(沒有數(shù)據(jù)補(bǔ)0)
我們?cè)谟肕ysql制作數(shù)據(jù)可視化圖表時(shí)候,經(jīng)常需要按照天對(duì)數(shù)據(jù)進(jìn)行分組統(tǒng)計(jì),下面這篇文章主要給大家介紹了關(guān)于MySQL按天分組統(tǒng)計(jì)一定時(shí)間內(nèi)的數(shù)據(jù),沒有數(shù)據(jù)補(bǔ)0的相關(guān)資料,需要的朋友可以參考下2023-03-03
mysql 5.6.14主從復(fù)制(也稱mysql AB復(fù)制)環(huán)境配置方法
這篇文章主要介紹了mysql 5.6.14主從復(fù)制(也稱mysql AB復(fù)制)環(huán)境配置方法,需要的朋友可以參考下2016-04-04
mysql使用left?join連接出現(xiàn)重復(fù)問題的記錄
這篇文章主要介紹了mysql使用left?join連接出現(xiàn)重復(fù)問題的記錄,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-03-03
MySQL啟動(dòng)時(shí)InnoDB引擎被禁用了的解決方法
最近在工作中遇到一個(gè)問題,現(xiàn)將解決的方法分享出來供大家參考學(xué)習(xí),下面這篇文章主要給大家介紹了關(guān)于MySQL啟動(dòng)時(shí)InnoDB引擎被禁用了的解決方法,需要的朋友們下面跟著小編來一起學(xué)習(xí)學(xué)習(xí)吧。2017-08-08
Navicat配置mysql數(shù)據(jù)庫用戶權(quán)限問題
這篇文章主要介紹了Navicat配置mysql數(shù)據(jù)庫用戶權(quán)限問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-03-03

