標籤:tar打包 針對 識別 roc 技術 狀態 生產環境 執行 abc
Database Backup的重要性,在生產環境中,資料的安全性是至關重要的,任何資料的丟失都可能產生嚴重的後果,Database Backup,能及時的恢複重要資料。造成資料丟失的原因:
- 程式錯誤
- 人為錯誤
- 電腦失敗
- 磁碟失敗
- 災難(火災、地震)偷竊、
從物理與邏輯的角度,備份可分為物理備份和邏輯備份。
- 邏輯備份:指對資料庫邏輯組件(如表、資料庫)的備份。
- 物理備份:對資料庫作業系統的物理檔案(資料檔案、記錄檔)的備份。物理備份又可以分為冷備份和熱備份。
冷備份:在關閉資料庫時進行的備份操作,能較好的保證資料庫的完整性。熱備份:資料庫運行狀態時的備份,備份方法依賴於資料庫的記錄檔。備份又可分為完全備份、差異備份和增量備份。
- 完整備份:對整個資料庫所有對象進行備份,花費時間長。
- 差異備份:完全備份和增量備份之後的備份。(只識別完整備份,備份之後的)
- 增量備份:只針對備份後面修改的內容進行備份。(只備份完整備份之後增加的那一條。)
一.使用tar打包檔案夾備份。
1.資料庫檔案很大,可以使用壓縮率較大的XZ格式壓縮,優先安裝XZ壓縮公用程式
yum install xz -y
2.對資料庫檔案夾/usr/local/mysql/data/進行打包操作
tar Jcvf /opt/mysql-$(date +%F).tar.xz /usr/local/mysql/data
3.如果資料庫檔案損壞丟失,可以解壓壓縮備份檔案,做資料恢複工作。
tar Jxvf /opt/mysql-2018-8-30.tar.xz /usr/local/mysql/data
二、使用mysqldump工具備份。
1.對單個庫進行完整備份。
mysqldump -u 使用者名稱 -p[密碼] --database[資料庫] > /備份路徑/備份檔案名
例:
mysqldump -uroot -pabc123 --database school > /opt/school.sql
2.對某些表進行完全備份。
mysqldump -u使用者名稱 -p[密碼][資料庫名][表名]>/備份路徑/備份檔案名
3.對多個庫進行完全備份。
mysqldump -u使用者名稱 -p[密碼] --databases [庫名1][庫名2] >/備份路徑/備份檔案名
4.對所有庫進行完全備份。
mysqldump -u使用者名稱 -p[密碼] --all-databases >/備份路徑/備份檔案名
5.只備份某個表的表結構。
mysqldump -u使用者名稱 -p[密碼] -d [庫名][表名]>/備份路徑/備份檔案名
三、恢複資料庫
1.登陸資料庫後,進入資料庫用source命令直接進行整庫恢複。
source 備份指令碼路徑
例:
source /opt/school.sql
注意:建立新的資料庫,進入新資料庫中執行source命令 。
2.用mysql命令恢複。(不登入資料庫的情況下)
mysql -u使用者名稱 -p[密碼] 庫名 < /庫備份路徑/備份檔案
有2個例子說一下,第一種只備份了表,需要提前建立新庫,再恢複,第二種無需提前建立新庫。
例:
1)第一種
先備份
mysqldump -uroot -pabc123 school>/opt/school.sql
建立新庫,查看新庫的資訊。
mysql -uroot -pabc123 -e ‘create database school;show databases;‘
恢複
mysql -uroot -pabc123 school < /opt/school.sql
2)第二種
備份
mysqldump -uroot -pabc123 --databases school > school.sql
無需提前建立新庫
恢複
mysql -uroot -pabc123 school < school.sql
三、無需登入資料庫進行查看、建立資料庫、表
mysql -u 使用者名稱 -p[密碼] -e ‘[命令];[命令];‘
例:建立一個庫查看進入庫
mysql -uroot -pabc123 -e ‘create database school;show databases;‘
Mysql完全備份與恢複