linux下如何?mysql資料庫每天自動備份定時備份

來源:互聯網
上載者:User

標籤:方案   span   yum命令   linu   mount   word   許可權   服務   uil   

著作權聲明:本文為 testcs_dn(微wx笑) 原創文章,非商用自由轉載-保持署名-註明出處,謝謝。

 

目錄(?)[+]

 概述

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

備份是什嗎?

為什麼要備份

容災方案建設

儲存介質

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

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

1、查看磁碟空間情況:

既然是定時備份,就要選擇一個空間充足的磁碟空間,避免出現因空間不足導致備份失敗,資料丟失的惡果! 
儲存到當前磁碟這是最簡單,卻是最不推薦的;伺服器有多塊硬碟,最好是把備份存放到另一塊硬碟上;有條件就選擇更好更安全的儲存介質;

# df -hFilesystem                    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、建立備份目錄:

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

cd /homemkdir backupcd backup
  • 1
  • 2
  • 3
  • 1
  • 2
  • 3
3、建立備份Shell指令碼:

注意把以下命令中的DatabaseName換為實際的資料庫名稱; 
當然,你也可以使用其實的命名規則!

vi bkDatabaseName.sh
  • 1
  • 1

輸入/粘貼以下內容:

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

對備份進行壓縮:

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

注意: 
把 username 替換為實際的使用者名稱; 
把 password 替換為實際的密碼; 
把 DatabaseName 替換為實際的資料庫名;

4、添加可執行許可權:
chmod u+x bkDatabaseName.sh
  • 1
  • 1

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

./bkDatabaseName.sh
  • 1
  • 1
5、添加計劃任務檢測或安裝 crontab

確認crontab是否安裝: 
執行 crontab 命令如果報 command not found,就表明沒有安裝

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

如時沒有安裝 crontab,需要先安裝它,具體步驟請參考: 
CentOS下使用yum命令安裝計劃任務程式crontab 
使用rpm命令從CentOS系統硬碟安裝計劃任務程式crontab

添加計劃任務

執行命令:

crontab -e
  • 1
  • 1

這時就像使用vi編輯器一樣,可以對計劃任務進行編輯。 
輸入以下內容並儲存:

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

具體是什麼意思呢? 
意思是每一分鐘執行一次shell指令碼“/home/backup/bkDatabaseName.sh”。

6、測試工作是否執行

很簡單,我們就執行幾次“ls”命令,看看一分鐘過後檔案有沒有被建立就可以了!

如果任務執行失敗了,可以通過以下命令查看任務日誌:

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

輸出類似如下:

Sep 30 14:01:01 bogon run-parts(/etc/cron.hourly)[2503]: starting 0anacronSep 30 14:01:01 bogon run-parts(/etc/cron.hourly)[2512]: finished 0anacronSep 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 0anacronSep 30 15:01:02 bogon run-parts(/etc/cron.hourly)[3101]: finished 0anacronSep 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 0anacronSep 30 16:01:01 bogon run-parts(/etc/cron.hourly)[3714]: finished 0anacronSep 30 16:15:29 bogon crontab[3598]: (root) END EDIT (root)

linux下如何?mysql資料庫每天自動備份定時備份

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.