摘 要:本文提出了異機備份的策略,它能在數據服務器崩潰或Microsoft SQL Server系統崩潰時有效的恢復數據,從而有力的保證了Microsoft SQL Server中數據的完整、安全。
關鍵詞:數據庫 備份 恢復
Abstract:This paper discusses the back-up strategy of dif ferent computers, which is used to restore data efficIEntly in case of a crash o f the data server or MS SQL Server so as to guarantee the entirety and security of data in the MS SQL Server.
KeyWords:database back-up restore▲
一、引言
信息技術的發展離不開數據庫技術的不斷發展,從DBase、Foxbase、Foxpro、Access,到Microsoft SQL Server、Sybase SQL Server、Oracle,數據庫的規模越來越大,其功能也越來越強大。Microsoft SQL Server是運行在Microsoft Windows NT上的一個高性能數據庫管理系統,它基於多線程的客戶/服務器體系結構,這一點與其他流行的多進程客戶/服務器數據庫系統不同,多線程的數據庫系統與多進程的數據庫系統相比,裝入Microsoft SQL Server時,僅僅啟動一個進程,而每個用戶有各自的線程,這種結構需要的資源比多進程系統少得多。Microsoft SQL Server的強大功能還表現在其保證數據的完整性,有了服務器維護數據的完整性,就沒有再必要依賴各個部門的程序員,他們能力各異,編寫的應用程序也很難統一,然可以在應用程序內部努力保證完整性,但是沒有必要完全寄希望於此,因為有了Microsoft SQL Server,就可以在整個LAN內部保證數據庫信息的完整性和一致性。因此Microsoft SQL Server在許多單位得以應用,然而其數據庫系統產生各種故障的可能性始終存在,更要求我們合理備份數據庫中的數據。
二、故障的產生及後果
計算機系統有許多種故障類型,諸如:
.機械損壞,計算機的各種部件(包括磁盤)都存在物理的,機械的故障可能性。
.電源故障,指一般的UPS無法保護的異常電源故障。
.自然災害,地震、水災,火災或其他原因造成的嚴重故障。
.錯誤使用,客戶應用程序以及服務程序使用中的中途故障。
.惡意破壞,在一個系統中也不排除一些惡意破壞者。
.其他還有多種形式,但大多數是以上幾種形式的變體。
假如沒有數據備份,一旦產生故障(主要是系統發生故障)那就不可能恢復丟失的數據,如果是這樣的話,不得不返回物理文件重新輸入所有數據,試想一下,輸入以前那些信息曾花費了多少個日夜,並且在重新輸入舊數據時,新數據還在不斷的到來,所以沒有理由不為服務器配置一個有效的備份設備,多投入一點資金與潛在的不可恢復的商業信息以及人們的寶貴時間相比顯得微不足道。
三、備份策略
定期備份數據庫是最穩妥的防止磁盤故障(主要是系統發生故障)的方法,它能有效的恢復數據,這是一種比較兼價的保險形式,同時也是最簡單的確保能恢復大部分信息的方法。建立一個完整的備份策略需要考慮很多因素,包括:
.備份周期。(根據數據的重要程序,可以選擇每周、每日、每時進行備份)。
.使用靜態備份還是動態備份,(動態備份也即允許數據庫運行時進行備份)。
.僅使用全備份還是共同使用全備份和增量備份。
.使用什麼介質,(磁帶還是磁盤)。
.使用人工備份還是設計好的自動備份程序。
.檢驗備份完整性的周期。
.備份存儲的空間是否防竊、防磁干擾、防火。
.是否指定其他人實行備份,他們是否享有必要的登錄號和口令。
.在負責備份和恢復的主要人員缺席的情況下,是否有其他人能代替他們。
最快的然而是最昂貴的保護是准備一個備份服務器隨時替代主服務器,備份服務器必須能支持Microsoft SQL Server運行,並能完整備份所有數據庫,系統和用戶帳戶,因為事務處理日志和數據庫的轉儲由主服務器創建,所以他們必須迅速的裝載到備份服務器,如果主服務器需要中止工作一段時間,只需投入備份服務器代替主服務器即可,備份服務器將接管事務處理日志,就好象什麼也沒有發生。
以上是服務器鏡象備份,也稱為雙機熱備份,另外還有硬盤鏡象備份,(最好有二個相同的硬盤),因出於成本或其他原因考慮,尤其是雙機熱備份(單獨專門使用一個與服務器配置一樣的計算機作為備份服務器)采用者較少,因此我們提出了異機備份的策略,這也是最好最經濟的備份方式,特別是當服務器崩潰或Microsoft SQL Sever系統崩潰時,因為此時除了雙熱備份可以啟用備份服務器直接使用外,