小男孩‘自慰网亚洲一区二区,亚洲一级在线播放毛片,亚洲中文字幕av每天更新,黄aⅴ永久免费无码,91成人午夜在线精品,色网站免费在线观看,亚洲欧洲wwwww在线观看

分享

linux下如何實(shí)現(xiàn)mysql數(shù)據(jù)庫每天自動備份定時(shí)備份

 野崎君noZakiKu 2017-04-16

概述

備份是容災(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ì);

# 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
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6

2、創(chuàng)建備份目錄:

上面我們使用命令看出/home下空間比較充足,所以可以考慮在/home保存?zhèn)浞菸募?/p>

cd /home
mkdir backup
cd backup
  • 1
  • 2
  • 3
  • 1
  • 2
  • 3

3、創(chuàng)建備份Shell腳本:

注意把以下命令中的DatabaseName換為實(shí)際的數(shù)據(jù)庫名稱;
當(dāng)然,你也可以使用其實(shí)的命名規(guī)則!

vi bkDatabaseName.sh
  • 1
  • 1

輸入/粘貼以下內(nèi)容:

#!/bin/bash
mysqldump -uusername -ppassword DatabaseName > /home/backup/DatabaseName_$(date +%Y%m%d_%H%M%S).sql
  • 1
  • 2
  • 1
  • 2

對備份進(jìn)行壓縮:

#!/bin/bash
mysqldump -uusername -ppassword DatabaseName | gzip > /home/backup/DatabaseName_$(date +%Y%m%d_%H%M%S).sql.gz
  • 1
  • 2
  • 1
  • 2

注意:
把 username 替換為實(shí)際的用戶名;
把 password 替換為實(shí)際的密碼;
把 DatabaseName 替換為實(shí)際的數(shù)據(jù)庫名;

4、添加可執(zhí)行權(quán)限:

chmod u+x bkDatabaseName.sh
  • 1
  • 1

添加可執(zhí)行權(quán)限之后先執(zhí)行一下,看看腳本有沒有錯(cuò)誤,能不能正常使用;

./bkDatabaseName.sh
  • 1
  • 1

5、添加計(jì)劃任務(wù)

檢測或安裝 crontab

確認(rèn)crontab是否安裝:
執(zhí)行 crontab 命令如果報(bào) command not found,就表明沒有安裝

# crontab
-bash: crontab: command not found
  • 1
  • 2
  • 1
  • 2

如時(shí)沒有安裝 crontab,需要先安裝它,具體步驟請參考:
CentOS下使用yum命令安裝計(jì)劃任務(wù)程序crontab
使用rpm命令從CentOS系統(tǒng)盤安裝計(jì)劃任務(wù)程序crontab

添加計(jì)劃任務(wù)

執(zhí)行命令:

crontab -e
  • 1
  • 1

這時(shí)就像使用vi編輯器一樣,可以對計(jì)劃任務(wù)進(jìn)行編輯。
輸入以下內(nèi)容并保存:

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

具體是什么意思呢?
意思是每一分鐘執(zhí)行一次shell腳本“/home/backup/bkDatabaseName.sh”。

6、測試任務(wù)是否執(zhí)行

很簡單,我們就執(zhí)行幾次“l(fā)s”命令,看看一分鐘過后文件有沒有被創(chuàng)建就可以了!

如果任務(wù)執(zhí)行失敗了,可以通過以下命令查看任務(wù)日志:

# tail -f /var/log/cron
  • 1
  • 1

輸出類似如下:

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)
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10

    本站是提供個(gè)人知識管理的網(wǎng)絡(luò)存儲空間,所有內(nèi)容均由用戶發(fā)布,不代表本站觀點(diǎn)。請注意甄別內(nèi)容中的聯(lián)系方式、誘導(dǎo)購買等信息,謹(jǐn)防詐騙。如發(fā)現(xiàn)有害或侵權(quán)內(nèi)容,請點(diǎn)擊一鍵舉報(bào)。
    轉(zhuǎn)藏 分享 獻(xiàn)花(0

    0條評論

    發(fā)表

    請遵守用戶 評論公約

    類似文章 更多