## 20.4 備份的種類、頻率與工具的選擇
講了好多口水了,還是沒有講到重點,真是的....好了,再來提到那個備份的種類,因為想要選擇什么儲存媒體與相關備份工具, 都與備份使用的方式有關!那么備份有哪些方式呢?一般可以粗略分為“累積備份”與“差異備份”這兩種 [[1]](#ps1)。當然啦,如果你在系統出錯時想要重新安裝到更新的系統時,僅備份關鍵數據也就可以了!
### 20.4.1 完整備份之累積備份 (Incremental backup)
備份不就是將重要數據復制出來即可嗎?干嘛需要完整備份 (Full backup) 呢?如果你的主機是負責相當重要的服務, 因此如果有不明原因的死機事件造成系統損毀時,你希望在最短的時間內復原系統。此時,如果僅備份關鍵數據時, 那么你得要在系統出錯后,再去找新的 Linux distribution 來安裝,安裝完畢后還得要考慮到數據新舊版本的差異問題, 還得要進行數據的移植與系統服務的重新創建等等,等到創建妥當后,還得要進行相關測試! 這種種的工作可至少得要花上一個星期以上的工作天才能夠處理妥當!所以,僅有關鍵數據是不夠的!
* 還原的考慮
但反過來講,如果是完整備份的話呢?若硬件出問題導致系統損毀時,只要將完整備份拿出來,整個給他傾倒回去硬盤, 所有事情就搞定了!有些時候 (例如使用 dd 指令) 甚至連系統都不需要重新安裝!反正整個系統都給他倒回去,連同重要的 Linux 系統文件等,所以當然也就不需要重新安裝啊!因此,很多企業用來提供重要服務的主機都會使用完整備份, 若所提供的服務真的非常重要時,甚至會再架設一部一模一樣的機器呢!如此一來, 若是原本的機器出問題,那就立刻將備份的機器拿出來接管!以使企業的網絡服務不會中斷哩!
那你知道完整備份的定義了吧?沒錯!完整備份就是將根目錄 (/) 整個系統通通備份下來的意思! 不過,在某些場合下面,完整備份也可以是備份一個文件系統 (filesystem)!例如 /dev/sda1 或 /dev/md0 或 /dev/myvg/mylv 之類的文件系統就是了。
* 累積備份的原則
雖然完整備份在還原方面有相當良好的表現,但是我們都知道系統用的越久,數據量就會越大!如此一來, 完整備份所需要花費的時間與儲存媒體的使用就會相當麻煩~所以,完整備份并不會也不太可能每天都進行的! 那你想要每天都備份數據該如何進行呢?有兩種方式啦,一種是本小節會談到的累積備份,一種則是下個小節談到的差異備份。
所謂的累積備份,指的是在系統在進行完第一次完整備份后,經過一段時間的運行, 比較系統與備份文件之間的差異,僅備份有差異的文件而已。而第二次累積備份則與第一次累積備份的數據比較, 也是僅備份有差異的數據而已。如此一來,由于僅備份有差異的數據,因此備份的數據量小且快速!備份也很有效率。 我們可以從下圖來說明:
圖20.4.1、累積備份 (incremental backup) 操作示意圖
假如我在星期一作好完整備份,則星期二的累積備份是系統與完整備份間的差異數據;星期三的備份是系統與星期二的差異數據, 星期四的備份則是系統與星期三的差異數據。那你得要注意的是,星期二的數據是完整備份加第一次累積備份, 星期三的數據是完整備份加第一次累積與第二次累積備份,星期四的數據則是星期一的完整備份加第一次加第二次加第三次累積備份。 由于每次都僅與前一次的備份數據比較而已,因此備份的數據量就會少很多!
那如何還原?經過上面的分析,我們也會知道累積備份的還原方面比較麻煩! 假設你的系統在星期五的時候掛點了!那你要如何還原?首先,你必須要還原星期一的完整備份,然后還原星期二的累積備份, 再依序還原星期三、星期四的累積備份才算完全復原!那如果你是經過了九次的累積備份,就得要還原到第九次的階段, 才是最完整的還原程序!
* 累積備份使用的備份軟件
完整備份常用的工具有 [dd](../Text/index.html#dd), [cpio](../Text/index.html#cpio), [xfsdump/xfsrestore](../Text/index.html#dump_restore) 等等。因為這些工具都能夠備份設備與特殊文件! dd 可以直接讀取磁盤的扇區 (sector) 而不理會文件系統,是相當良好的備份工具!不過缺點就是慢很多! cpio 是能夠備份所有文件名,不過,得要配合 find 或其他找文件名的指令才能夠處理妥當。以上兩個都能夠進行完整備份, 但累積備份就得要額外使用腳本程序來處理。可以直接進行累積備份的就是 xfsdump 這個指令啰!詳細的指令與參數用法, 請前往[第八章](../Text/index.html)查閱,這里僅列出幾個簡單的范例而已。
```
# 1\. 用 dd 來將 /dev/sda 備份到完全一模一樣的 /dev/sdb 硬盤上:
[root@study ~]# dd if=/dev/sda of=/dev/sdb
# 由于 dd 是讀取扇區,所以 /dev/sdb 這顆磁盤可以不必格式化!非常的方便!
# 只是你會等非常非常久!因為 dd 的速度比較慢!
# 2\. 使用 cpio 來備份與還原整個系統,假設儲存媒體為 SATA 磁帶機:
[root@study ~]# find / -print | cpio -covB > /dev/st0 <==備份到磁帶機
[root@study ~]# cpio -iduv < /dev/st0 <==還原
```
假設 /home 為一個獨立的文件系統,而 /backupdata 也是一個獨立的用來備份的文件系統,那如何使用 dump 將 /home 完整的備份到 /backupdata 上呢?可以像下面這樣進行看看:
```
# 1\. 完整備份
[root@study ~]# xfsdump -l 0 -L 'full' -M 'full' -f /backupdata/home.dump /home
# 2\. 第一次進行累積備份
[root@study ~]# xfsdump -l 1 -L 'full-1' -M 'full-1' -f /backupdata/home.dump1 /home
```
除了這些指令之外,其實 tar 也可以用來進行完整備份啦!舉例來說,/backupdata 是個獨立的文件系統, 你想要將整個系統通通備份起來時,可以這樣考慮:將不必要的 /proc, /mnt, /tmp 等目錄不備份,其他的數據則予以備份:
```
[root@study ~]# tar --exclude /proc --exclude /mnt --exclude /tmp \
> --exclude /backupdata -jcvp -f /backupdata/system.tar.bz2 /
```
### 20.4.2 完整備份之差異備份 (Differential backup)
差異備份與累積備份有點類似,也是需要進行第一次的完整備份后才能夠進行。只是差異備份指的是:每次的備份都是與原始的完整備份比較的結果。所以系統運行的越久,離完整備份時間越長, 那么該次的差異備份數據可能就會越大!差異備份的示意圖如下所示:
圖20.4.2、差異備份 (differential backup) 操作示意圖
差異備份常用的工具與累積備份差不多!因為都需要完整備份嘛!如果使用 xfsdump 來備份的話,那么每次備份的等級 (level) 就都會是 level 1 的意思啦!當然啦,你也可以通過 tar 的 -N 選項來備份喔!如下所示:
```
[root@study ~]# tar -N '2015-09-01' -jpcv -f /backupdata/home.tar.bz2 /home
# 只有在比 2015-09-01 還要新的文件,在 /home 下面的文件才會被打包進 home.bz2 中!
# 有點奇怪的是,目錄還是會被記錄下來,只是目錄內的舊文件就不會備份。
```
此外,你也可以通過 [rsync](http://linux.vbird.org/linux_server/0310telnetssh.php#rsync) 來進行鏡像備份喔! 這個 rsync 可以對兩個目錄進行鏡像 (mirror) ,算是一個非常快速的備份工具!簡單的指令語法為:
```
[root@study ~]# rsync -av 來源目錄 目標目錄
# 1\. 將 /home/ 鏡像到 /backupdata/home/ 去
[root@study ~]# rsync -av /home /backupdata/
# 此時會在 /backupdata 下面產生 home 這個目錄來!
[root@study ~]# rsync -av /home /backupdata/
# 再次進行會快很多!如果數據沒有更動,幾乎不會進行任何動作!
```
根據分析 [[2]](#ps2) ,差異備份所使用的磁盤容量可能會比累積備份來的大,但是差異備份的還原較快, 因為只需要還原完整備份與最近一次的差異備份即可。無論如何,請依據你自己的喜好來選擇備份的方式吧!
### 20.4.3 關鍵數據備份
完整備份雖然有許多好處,但就是需要花費很多時間!所以,如果在主機提供的服務并不是一定要 24 小時提供的前提下, 我們可以僅備份重要的關鍵數據即可。由于主機即使死機個一兩天可能也不會影響到你的正常生活時, 僅備份關鍵數據就好啦!不需要整個系統都備份。僅備份關鍵數據是有許多好處的! 由于完整備份可能是在系統運行期間進行,不但會花費非常多時間,而且如果備份當時系統已經被攻破, 那你備份的數據是有問題的,那還原回去也是有問題的系統啊!
如果僅是備份關鍵數據而已,那么由于系統的絕大部分可執行文件都可以后來重新安裝,因此若你的系統不是因為硬件問題, 而是因為軟件問題而導致系統被攻破或損毀時,直接捉取最新的 Linux distribution ,然后重新安裝, 然后再將系統數據 (如帳號/密碼與主文件夾等等) 與服務數據 (如 www/email/crontab/ftp 等等) 一個一個的填回去! 那你的系統不但保持在最新的狀態,同時也可以趁機處理一下與重新溫習一下系統設置!是很不錯的呦!
不過,備份關鍵數據最麻煩的地方其實就是在還原啦!上述的還原方式是你必須要很熟悉系統運行, 否則還原得要花費很多時間的!尤其近來的 Linux 強調安全性,所以加入 SELinux 了,你如果要從舊版的 Linux 升級到新版時, 原本若沒有 SELinux 而換成新版則需要啟動 SELinux 時,那個除錯的時間會花很長一段日子哩! 鳥哥認為這是僅備份關鍵數據的一些優缺點啦~
備份關鍵數據鳥哥最愛使用 tar 來處理了!如果想要分門別類的將各種不同的服務在不同的時間備份使用不同文件名, 配合 date 指令是非常好用的工具!例如下面的案例是依據日期來備份 mariadb 的數據庫喔!
```
[root@study ~]# tar -jpcvf mysql.`date +%Y-%m-%d`.tar.bz2 /var/lib/mysql
```
備份是非常重要的工作,你可不希望想到才進行吧?交給系統自動處理就對啦!請自己撰寫 script , 配合 crontab 去執行吧!這樣子,備份會很輕松喔!

**Tips** 事實上除了這些基本的 Linux 備份還原工具之外,如果你還想要嘗試裸機復原的功能,那可以使用臺灣國家高速網絡中心開發的再生龍軟件! 這個軟件相當棒!鳥哥目前服務的單位也是通過這個軟件來處理整間計算機教室的復原工作喔!這個軟件也有單機版, 也挺好用的!有興趣的朋友得要自行處理軟件的使用喔:
* [http://clonezilla.nchc.org.tw/](http://clonezilla.nchc.org.tw/)
- 鳥哥的Linux私房菜:基礎學習篇 第四版
- 目錄及概述
- 第零章、計算機概論
- 0.1 電腦:輔助人腦的好工具
- 0.2 個人電腦架構與相關設備元件
- 0.3 數據表示方式
- 0.4 軟件程序運行
- 0.5 重點回顧
- 0.6 本章習題
- 0.7 參考資料與延伸閱讀
- 第一章、Linux是什么與如何學習
- 1.1 Linux是什么
- 1.2 Torvalds的Linux發展
- 1.3 Linux當前應用的角色
- 1.4 Linux 該如何學習
- 1.5 重點回顧
- 1.6 本章習題
- 1.7 參考資料與延伸閱讀
- 第二章、主機規劃與磁盤分區
- 2.1 Linux與硬件的搭配
- 2.2 磁盤分區
- 2.3 安裝Linux前的規劃
- 2.4 重點回顧
- 2.5 本章習題
- 2.6 參考資料與延伸閱讀
- 第三章、安裝 CentOS7.x
- 3.1 本練習機的規劃--尤其是分區參數
- 3.2 開始安裝CentOS 7
- 3.3 多重開機安裝流程與管理(Option)
- 3.4 重點回顧
- 3.5 本章習題
- 3.6 參考資料與延伸閱讀
- 第四章、首次登陸與線上求助
- 4.1 首次登陸系統
- 4.2 文字模式下指令的下達
- 4.3 Linux系統的線上求助man page與info page
- 4.4 超簡單文書編輯器: nano
- 4.5 正確的關機方法
- 4.6 重點回顧
- 4.7 本章習題
- 4.8 參考資料與延伸閱讀
- 第五章、Linux 的文件權限與目錄配置
- 5.1 使用者與群組
- 5.2 Linux 文件權限概念
- 5.3 Linux目錄配置
- 5.4 重點回顧
- 5.5 本章練習
- 5.6 參考資料與延伸閱讀
- 第六章、Linux 文件與目錄管理
- 6.1 目錄與路徑
- 6.2 文件與目錄管理
- 6.3 文件內容查閱
- 6.4 文件與目錄的默認權限與隱藏權限
- 6.5 指令與文件的搜尋
- 6.6 極重要的復習!權限與指令間的關系
- 6.7 重點回顧
- 6.8 本章習題:
- 6.9 參考資料與延伸閱讀
- 第七章、Linux 磁盤與文件系統管理
- 7.1 認識 Linux 文件系統
- 7.2 文件系統的簡單操作
- 7.3 磁盤的分區、格式化、檢驗與掛載
- 7.4 設置開機掛載
- 7.5 內存交換空間(swap)之創建
- 7.6 文件系統的特殊觀察與操作
- 7.7 重點回顧
- 7.8 本章習題 - 第一題一定要做
- 7.9 參考資料與延伸閱讀
- 第八章、文件與文件系統的壓縮,打包與備份
- 8.1 壓縮文件的用途與技術
- 8.2 Linux 系統常見的壓縮指令
- 8.3 打包指令: tar
- 8.4 XFS 文件系統的備份與還原
- 8.5 光盤寫入工具
- 8.6 其他常見的壓縮與備份工具
- 8.7 重點回顧
- 8.8 本章習題
- 8.9 參考資料與延伸閱讀
- 第九章、vim 程序編輯器
- 9.1 vi 與 vim
- 9.2 vi 的使用
- 9.3 vim 的額外功能
- 9.4 其他 vim 使用注意事項
- 9.5 重點回顧
- 9.6 本章練習
- 9.7 參考資料與延伸閱讀
- 第十章、認識與學習BASH
- 10.1 認識 BASH 這個 Shell
- 10.2 Shell 的變量功能
- 10.3 命令別名與歷史命令
- 10.4 Bash Shell 的操作環境:
- 10.5 數據流重導向
- 10.6 管線命令 (pipe)
- 10.7 重點回顧
- 10.8 本章習題
- 10.9 參考資料與延伸閱讀
- 第十一章、正則表達式與文件格式化處理
- 11.1 開始之前:什么是正則表達式
- 11.2 基礎正則表達式
- 11.3 延伸正則表達式
- 11.4 文件的格式化與相關處理
- 11.5 重點回顧
- 11.6 本章習題
- 11.7 參考資料與延伸閱讀
- 第十二章、學習 Shell Scripts
- 12.1 什么是 Shell scripts
- 12.2 簡單的 shell script 練習
- 12.3 善用判斷式
- 12.4 條件判斷式
- 12.5 循環 (loop)
- 12.6 shell script 的追蹤與 debug
- 12.7 重點回顧
- 12.8 本章習題
- 第十三章、Linux 帳號管理與 ACL 權限設置
- 13.1 Linux 的帳號與群組
- 13.2 帳號管理
- 13.3 主機的細部權限規劃:ACL 的使用
- 13.4 使用者身份切換
- 13.5 使用者的特殊 shell 與 PAM 模塊
- 13.6 Linux 主機上的使用者訊息傳遞
- 13.7 CentOS 7 環境下大量創建帳號的方法
- 13.8 重點回顧
- 13.9 本章習題
- 13.10 參考資料與延伸閱讀
- 第十四章、磁盤配額(Quota)與進階文件系統管理
- 14.1 磁盤配額 (Quota) 的應用與實作
- 14.2 軟件磁盤陣列 (Software RAID)
- 14.3 邏輯卷軸管理員 (Logical Volume Manager)
- 14.4 重點回顧
- 14.5 本章習題
- 14.6 參考資料與延伸閱讀
- 第十五章、例行性工作調度(crontab)
- 15.1 什么是例行性工作調度
- 15.2 僅執行一次的工作調度
- 15.3 循環執行的例行性工作調度
- 15.4 可喚醒停機期間的工作任務
- 15.5 重點回顧
- 15.6 本章習題
- 第十六章、程序管理與 SELinux 初探
- 16.1 什么是程序 (process)
- 16.2 工作管理 (job control)
- 16.3 程序管理
- 16.4 特殊文件與程序
- 16.5 SELinux 初探
- 16.6 重點回顧
- 16.7 本章習題
- 16.8 參考資料與延伸閱讀
- 第十七章、認識系統服務 (daemons)
- 17.1 什么是 daemon 與服務 (service)
- 17.2 通過 systemctl 管理服務
- 17.3 systemctl 針對 service 類型的配置文件
- 17.4 systemctl 針對 timer 的配置文件
- 17.5 CentOS 7.x 默認啟動的服務簡易說明
- 17.6 重點回顧
- 17.7 本章習題
- 17.8 參考資料與延伸閱讀
- 第十八章、認識與分析登錄文件
- 18.1 什么是登錄文件
- 18.2 rsyslog.service :記錄登錄文件的服務
- 18.3 登錄文件的輪替(logrotate)
- 18.4 systemd-journald.service 簡介
- 18.5 分析登錄文件
- 18.6 重點回顧
- 18.7 本章習題
- 18.8 參考資料與延伸閱讀
- 第十九章、開機流程、模塊管理與 Loader
- 19.1 Linux 的開機流程分析
- 19.2 核心與核心模塊
- 19.3 Boot Loader: Grub2
- 19.4 開機過程的問題解決
- 19.5 重點回顧
- 19.6 本章習題
- 19.7 參考資料與延伸閱讀
- 第二十章、基礎系統設置與備份策略
- 20.1 系統基本設置
- 20.2 服務器硬件數據的收集
- 20.3 備份要點
- 20.4 備份的種類、頻率與工具的選擇
- 20.5 鳥哥的備份策略
- 20.6 災難復原的考慮
- 20.7 重點回顧
- 20.8 本章習題
- 20.9 參考資料與延伸閱讀
- 第二十一章、軟件安裝:源代碼與 Tarball
- 20.1 開放源碼的軟件安裝與升級簡介
- 21.2 使用傳統程序語言進行編譯的簡單范例
- 21.3 用 make 進行宏編譯
- 21.4 Tarball 的管理與建議
- 21.5 函數庫管理
- 21.6 檢驗軟件正確性
- 21.7 重點回顧
- 21.8 本章習題
- 21.9 參考資料與延伸閱讀
- 第二十二章、軟件安裝 RPM, SRPM 與 YUM
- 22.1 軟件管理員簡介
- 22.2 RPM 軟件管理程序: rpm
- 22.3 YUM 線上升級機制
- 22.4 SRPM 的使用 : rpmbuild (Optional)
- 22.5 重點回顧
- 22.6 本章習題
- 22.7 參考資料與延伸閱讀
- 第二十三章、X Window 設置介紹
- 23.1 什么是 X Window System
- 23.2 X Server 配置文件解析與設置
- 23.3 顯卡驅動程序安裝范例
- 23.4 重點回顧
- 23.5 本章習題
- 23.6 參考資料與延伸閱讀
- 第二十四章、Linux 核心編譯與管理
- 24.1 編譯前的任務:認識核心與取得核心源代碼
- 24.2 核心編譯的前處理與核心功能選擇
- 24.3 核心的編譯與安裝
- 24.4 額外(單一)核心模塊編譯
- 24.5 以最新核心版本編譯 CentOS 7.x 的核心
- 24.6 重點回顧
- 24.7 本章習題
- 24.8 參考資料與延伸閱讀