Oracle備份及備份策略

第二章. 瞭解備份的重要性

能夠說,從計算機系統出世的那天起,就有了備份這個概念,計算機以其強大的速度處理能力,取代了不少人爲的工做,可是,每每不少時候,它又是那麼弱不由風,主板上的芯片、主板電路、內存、電源等任何一項不能正常工做,都會致使計算機系統不能正常工做。固然,這些損壞能夠修復,不會致使應用和數據的損壞。可是,若是計算機的硬盤損壞,將會致使數據丟失,此時必須用備份恢復數據。
其實,在咱們的現實世界中,已經就存在不少備份策略,如RAID技術,雙機熱備,集羣技術發展的不就是計算機系統的備份和高可用性嗎?有不少時候,系統的備份的確就能解決數據庫備份的問題,如磁盤介質的損壞,每每從鏡相上面作簡單的恢復,或簡單的切換機器就能夠了。
可是,上面所說的系統備份策略是從硬件的角度來考慮備份與恢復的問題,這是須要代價的。咱們所能選擇備份策略的依據是:丟是數據的代價與確保數據不丟失的代價之比。還有的時候,硬件的備份有時根本知足不了現實須要,假如你誤刪了一個表,可是你又想恢復的時候,數據庫的備份就變的重要了。ORACLE自己就提供了強大的備份與恢復策略,這裏咱們只討論ORACLE備份策略,如下的備份都是指ORACLE數據庫備份,恢復將放到下一講中。
所謂備份,就是把數據庫複製到轉儲設備的過程。其中,轉儲設備是指用於放置數據庫拷貝的磁帶或磁盤。
可以進行什麼樣的恢復依賴於有什麼樣的備份。做爲 DBA,有責任從如下三個方面維護數據庫的可恢復性:
·使數據庫的失效次數減到最少,從而使數據庫保持最大的可用性;
·當數據庫不可避免地失效後,要使恢復時間減到最少,從而使恢復的效率達到最高;
·當數據庫失效後,要確保儘可能少的數據丟失或根本不丟失,從而使數據具備最大的可恢復性。
災難恢復的最重要的工做是設計充足頻率的硬盤備份過程。備份過程應該知足系統要求的可恢復性。例如,若是數據庫可有較長的關機時間,則能夠每週進行一次冷備份,並歸檔重作日誌,對於24*7的系統,或許咱們考慮的只能是熱備份。若是天天都能備份固然會很理想,但要考慮其現實性。企業都在想辦法下降維護成本,現實的方案纔可能被採用。只要仔細計劃,並想辦法達到數據庫可用性的底線,花少許的錢進行成功的備份與恢復也是可能的。

第三章. 瞭解ORACLE的運行方式

ORACLE數據庫有兩種運行方式:一是歸檔方式(ARCHIVELOG),歸檔方式的目的是當數據庫發生故障時最大限度恢復數據庫,能夠保證不丟失任何已提交的數據;二是不歸檔方式(NOARCHIVELOG),只能恢復數據庫到最近的回收點(冷備份或是邏輯備份)。咱們根據數據庫的高可用性和用戶可承受丟失的工做量的多少,對於生產數據庫,強烈要求採用爲歸檔方式;那些正在開發和調試的數據庫能夠採用不歸檔方式。
如何改變數據庫的運行方式,在建立數據庫時,做爲建立數據庫的一部分,就決定了數據庫初始的存檔方式。通常狀況下爲NOARCHIVELOG方式。當數據庫建立好之後,根據咱們的須要把須要運行在歸檔方式的數據庫改爲ARCHIVELOG方式。

3.1改變不歸檔方式爲爲歸檔方式

1.關閉數據庫,備份已有的數據,改變數據庫的運行方式是對數據庫的重要改動,因此要對數據庫作備份,對可能出現的問題做出保護。
2. 修改初試化參數,使能自動存檔修改(添加)初始化文件init[SID].ora參數:
log_archive_start=true           #啓動自動歸檔
log_archive_format=ARC%T%S.arc   #歸檔文件格式
log_archive_dest=/arch12/arch        #歸檔路徑
8i中,能夠最多有五個歸檔路徑,並能夠歸檔到其它服務器,如備用數據庫(standby database)服務器
3.啓動InstanceMount狀態,即加載數據庫但不打開數據庫:
$>SVRMGRL
SVRMGRL >connect internal
SVRMGRL >startup mount
4.發出修改命令
SVRMGRL >alter database archivelog;
SVRMGRL>alter database open;

3.2 改變歸檔狀態爲不歸檔狀態

   與以上步驟相同,但有些操做不同,主要是在以上的b操做中,如今爲刪除或註釋該參數,在d操做中,命令爲
SVRMGRL >alter database noarchivelog;
    注意,從歸檔方式轉換到非歸檔方式後必定要作一次數據庫的全冷備份,防止意外事件的發生。

第四章. ORACLE備份的分類

簡單的按照備份進行的方式,能夠分爲邏輯備份、冷備份(脫機備份)、熱備份(聯機備份),其實冷備份與熱備份又能夠合稱爲物理備份
按照備份的工具,能夠分爲EXP/IMP備份、OS拷貝、RMAN、第三方工具,如VERITAS
如下咱們將從多個角度來講明以上的各類備份方式

4.1 EXP/IMP邏輯備份

導入/導出是ORACLE倖存的最古老的兩個命令行工具了,其實我歷來不認爲Exp/Imp是一種好的備份方式,正確的說法是Exp/Imp只能是一個好的轉儲工具,特別是在小型數據庫的轉儲,表空間的遷移,表的抽取,檢測邏輯和物理衝突等中有不小的功勞。固然,咱們也能夠把它做爲小型數據庫的物理備份後的一個邏輯輔助備份,也是不錯的建議。
對於愈來愈大的數據庫,特別是TB級數據庫和愈來愈多數據倉庫的出現,EXP/IMP愈來愈力不從心了,這個時候,數據庫的備份都轉向了RMAN和第三方工具。下面咱們仍是簡要介紹一下EXP/IMP的使用。

4.1.1 使用方法

Exp parameter_name=value
Or Exp parameter_name=(value1,value2……)
只要輸入參數help=y就能夠看到全部幫助
如:
C:\>set nls_lang=simplified chinese_china.zhs16gbk
C:\>exp -help
Export: Release 8.1.6.0.0 - Production on 星期四 4 10 19:09:21 2003
(c) Copyright 1999 Oracle Corporation.  All rights reserved.
 
經過輸入 EXP 命令和用戶名/口令,您能夠
在用戶 / 口令以後的命令:
 
實例: EXP SCOTT/TIGER
或者,您也能夠經過輸入跟有各類參數的 EXP 命令來控制「導出」
的運行方式。要指定參數,您可使用關鍵字:
 
格式: EXP KEYWORD=value KEYWORD=(value1,value2,...,valueN)
實例: EXP SCOTT/TIGER GRANTS=Y TABLES=(EMP,DEPT,MGR)
TABLES=(T1: P1,T1: P2),若是 T1 是分區表
USERID 必須是命令行中的第一個參數。
關鍵字  說明(默認)        關鍵字      說明(默認)
--------------------------------------------------------------------------
USERID   用戶名/口令            FULL         導出整個文件 (N)
BUFFER   數據緩衝區的大小          OWNER        全部者用戶名列表
FILE     輸出文件 (EXPDAT.DMP)    TABLES       表名列表
COMPRESS 導入一個範圍 (Y)   RECORDLENGTH  IO 記錄的長度
GRANTS  導出權限 (Y)            INCTYPE      增量導出類型
INDEXES 導出索引 (Y)           RECORD       跟蹤增量導出 (Y)
ROWS    導出數據行 (Y)         PARFILE      參數文件名
CONSTRAINTS 導出限制 (Y)    CONSISTENT   交叉表一致性
LOG      屏幕輸出的日誌文件    STATISTICS  分析對象 (ESTIMATE)
DIRECT   直接路徑 (N)              TRIGGERS     導出觸發器 (Y)
FEEDBACK 顯示每 x (0) 的進度
FILESIZE 各轉儲文件的最大尺寸
QUERY    選定導出表子集的子句
 
下列關鍵字僅用於可傳輸的表空間
TRANSPORT_TABLESPACE 導出可傳輸的表空間元數據 (N)
TABLESPACES 將傳輸的表空間列表
在沒有警告的狀況下成功終止導出。
C:\>
幫助已經很詳細的說明了參數的意義和使用方法,並列舉了幾個簡單的例子,注意的是,從8i開始,已經開始支持數據子集的方法,就是能夠指定本身的Where條件,能夠從表中導出一行或多行數據。
注意上面的set nls_lang=simplified chinese_china.zhs16gbk,經過設置環境變量,可讓exp的幫助以中文顯示,若是set nls_lang=American_america.字符集,那麼你的幫助就是英文的了。
增量和累計導出必須在全庫方式下才有效,並且,大多數狀況下,增量和累計導出並無想象中的那麼有效。ORACLE9i開始,再也不支持增量導出和累計導出。

4.1.2 表空間傳輸

表空間傳輸是8i新增長的一種快速在數據庫間移動數據的一種辦法,是把一個數據庫上的格式數據文件附加到另一個數據庫中,而不是把數據導出成Dmp文件,這在有些時候是很是管用的,由於傳輸表空間移動數據就象複製文件同樣快。
關於傳輸表空間有一些規則,即:
·源數據庫和目標數據庫必須運行在相同的硬件平臺上。
·源數據庫與目標數據庫必須使用相同的字符集。
·源數據庫與目標數據庫必定要有相同大小的數據塊
·目標數據庫不能有與遷移表空間同名的表空間
·SYS的對象不能遷移
·必須傳輸自包含的對象集
·有一些對象,如物化視圖,基於函數的索引等不能被傳輸
能夠用如下的方法來檢測一個表空間或一套表空間是否符合傳輸標準:
exec sys.dbms_tts.transport_set_check(‘tablespace_name’,true);
select * from sys.transport_set_violation;
若是沒有行選擇,表示該表空間只包含表數據,而且是自包含的。對於有些非自包含的表空間,如數據表空間和索引表空間,能夠一塊兒傳輸。
如下爲簡要使用步驟,若是想參考詳細使用方法,也能夠參考ORACLE聯機幫助。
1.設置表空間爲只讀(假定表空間名字爲APP_Data APP_Index
  alter tablespace app_data read only;
  alter tablespace app_index read only;
2.發出EXP命令
  SQL>host exp userid=」」」sys/password as sysdba」」」
transport_tablespace=y tablespace=(app_data, app_index)
以上須要注意的是
·爲了在SQL中執行EXPUSERID必須用三個引號,在UNIX中也必須注意避免「/」的使用
·在816和之後,必須使用sysdba才能操做
·這個命令在SQL中必須放置在一行(這裏是由於顯示問題放在了兩行)
3.拷貝數據文件到另外一個地點,即目標數據庫
  能夠是cp(unix)copy(windows)或經過ftp傳輸文件(必定要在bin方式)
4.把本地的表空間設置爲讀寫
5.在目標數據庫附加該數據文件
 imp file=expdat.dmp userid=」」」sys/password as sysdba」」」
       transport_tablespace=y
        「datafile=(c:\temp\app_data,c:\temp\app_index)」
6.設置目標數據庫表空間爲讀寫
  alter tablespace app_data read write;
      alter tablespace app_index read write;

4.1.3 導出/導入與字符集

明白ORACLE的多國語言設置,ORACLE多國語言設置是爲了支持世界範圍的語言與字符集,通常對語言提示,貨幣形式,排序方式和CHAR,VARCHAR2,CLOB,LONG字段的數據的顯示等有效。ORACLE的多國語言設置最主要的兩個特性就是國家語言設置與字符集設置,國家語言設置決定了界面或提示使用的語言種類,字符集決定了數據庫保存與字符集有關數據(如文本)時候的編碼規則。正如剛纔上面的一個小例子,環境變量NLS_LANG的不一樣,致使EXP幫助發生變化,這就是多國語言設置的做用(NLS_LANG包含國家語言設置與字符集設置,這裏起做用的是國家語言設置,而不是字符集)。
ORACLE字符集設定,分爲數據庫字符集和客戶端字符集環境設置。在數據庫端,字符集在建立數據庫的時候設定,並保存在數據庫props$表中,對於8i以上產品,已經能夠採用「Alter database character set 字符集」來修改數據庫的字符集,但也僅僅是從子集到超集,不要經過update props$來修改字符集,若是是不支持的轉換,可能會失去全部與字符集有關的數據,就是支持的轉換,也可能致使數據庫的不正常工做。字符集分爲單字節字符集與多字節字符集,US7ASCII就是典型的單字節字符集,在這種字符集中length=lengthb,而ZHS16GBK就是經常使用的雙字節字符集,在這裏lengthb=2*length
在客戶端的字符集環境比較簡單,主要就是環境變量或註冊表項NLS_LANG,注意NLS_LANG的優先級別爲:參數文件à註冊表à環境變量àalter sessionNLS_LANG的組成爲「國家語言設置.字符集」,如nls_lang=simplified chinese_china.zhs16gbk。客戶端的字符集最好與數據庫端同樣(國家語言設置能夠不同,如zhs16gbk的字符集,客戶端能夠是nls_lang =simplified chinese_china.zhs16gbkAmeircan_America.zhs16gbk,都不影響數據庫字符的正常顯示),若是字符集不同,並且字符集的轉換也不兼容,那麼客戶端的數據顯示與導出/導入的與字符集有關的數據將都是亂碼。
使用一點點技巧,就可使導出/導入在不一樣的字符集的數據庫上轉換數據。這裏須要一個2進制文件編輯工具便可,如uedit32。用編輯方式打開導出的dmp文件,獲取23字節的內容,如00 01,先把它轉換爲10進制數,爲1,使用函數NLS_CHARSET_NAME便可得到該字符集:
SQL> select nls_charset_name(1) from dual;
NLS_CHARSET_NAME(1)
-------------------
US7ASCII
能夠知道該dmp文件的字符集爲US7ASCII,若是須要把該dmp文件的字符集換成ZHS16GBK,則須要用NLS_CHARSET_ID獲取該字符集的編號:
SQL> select nls_charset_id('zhs16gbk') from dual;
NLS_CHARSET_ID('ZHS16GBK')
--------------------------
              852
852換成16進制數,爲354,把23字節的00 01換成03 54,即完成了把該dmp文件字符集從us7asciizhs16gbk的轉化,這樣,再把該dmp文件導入到zhs16gbk字符集的數據庫就能夠了。(注意,十進制數與十六進制之間的轉換,想明白其中的道理)

4.1.4 跨版本使用Exp/Imp

Exp/Imp不少時候,能夠跨版本使用,如在版本7與版本8之間導出導入數據,但這樣作必須選擇正確的版本,規則爲:
  ·老是使用IMP的版本匹配數據庫的版本,若是要導入到816,則使用816的導入工具。
  ·老是使用EXP的版本匹配兩個數據庫中低的那個版本,如在815816之間互導,則使用815EXP工具。

4.2 OS備份

操做系統備份有兩類,冷備份(Cold backup)與熱備份(Hot backup),操做系統備份與以上的邏輯備份有本質的區別。邏輯備份提取數據庫的數據內容,而不備份物理數據塊。而操做系統備份則是拷貝整個的數據文件。

4.2.1 冷備份

在文件級備份開始前數據庫必須完全關閉。關閉操做必須用帶有normalimmediatetransaction選項的shutdown來執行。
數據庫使用的每一個文件都被備份下來,這些文件包括:
    ☆全部數據文件
    ☆全部控制文件
    ☆全部聯機REDO LOG 文件
     INIT.ORA文件(可選)
     密碼文件(可選)
做冷備份通常步驟是:
a.       正常關閉要備份的實例(instance);
b.       備份整個數據庫到一個目錄
c.       啓動數據庫
 
    SVRMGRL>connect internal
    SVRMGRL >shutdown immediate
    SVRMGRL >! cp
   
    SVRMGRL >!tar cvf /dev/rmt/0 /u01/oradata/prod
    SVRMGRL >startup
   注意:若是利用腳本對數據庫進行冷備份,必須對關閉數據庫的命令進行邏輯檢查,若是發生關閉數據庫的命令不能正常執行而致使數據庫沒有正常關閉,那麼,全部的冷備份將回是無效的。

4.2.2熱備份

熱備份是當數據庫打開並對用戶有效是的OS級的數據備份。熱備份只能用於ARCHIVELOG方式的數據庫。在數據文件備份以前,對應的表空間必須經過使用ALTER TABLESPACE …… BEGIN BACKUP以備份方式放置。而後組成表空間的數據文件可使用相似冷備份的操做系統命令進行拷貝。在數據文件用操做系統命令拷貝後,應使用ALTER TABLESPACE …… END BACKUP命令使表空間脫離熱備份方式。
熱備份沒有必要備份聯機日誌,但必須是歸檔狀態,在實例恢復的時候,可能須要用到歸檔日誌。當前聯機日誌必定要保護好或是處於鏡相狀態,當前聯機日誌的損壞,對於數據庫的損壞是巨大的,只能以數據的丟失來進行數據庫的恢復工做。
對於臨時表空間,存放的是臨時信息,在熱備份是也能夠考慮不用備份,若是臨時文件發生故障,能夠刪除該數據文件與表空間,重建一個臨時表空間。
熱備份的優勢是顯而易見的
---- a.可在表空間或數據文件級備份,備份時間短。
---- b.備份時數據庫仍可以使用。
---- c.可達到秒級恢復(恢復到某一時間點上)。
---- d.可對幾乎全部數據庫實體做恢復。
---- e.恢復是快速的,在大多數狀況下在數據庫仍工做時恢復。
操做系統做熱備份的通常步驟爲:
1. 鏈接數據庫
SVRMGRL>connect internal;
2. 將須要備份的表空間(如User)設置爲備份方式
SVRMGRL>Alter tablespace User begin backup;
3. 拷貝數據文件
SVRMGRL>!cp /u01/oradata/prod/user01.ora /backup/prod/user01.ora
Or
$cp cp /u01/oradata/prod/user01.ora /backup/prod/user01.ora
4. 在數據文件拷貝完成後,將表空間拖體備份方式
SVRMGRL>Alter tablespace User end backup;
5. 對全部須要備份的表空間重複234
6. 使用以下的命令備份控制文件ALTER DATABSE …… BACKUP CONTROLFILE
如備份成二進制文件
alter database backup controlfile to ‘new fielname’;
備份成文本文件
alter database backup controlfile to trace;
由於熱備份的時候,用戶還在操做數據庫,因此,最好是每一個表空間處於備份狀態的時間最短,這樣就要求一個表空間一個表空間的備份,不要一塊兒使表空間處於備份狀態而同時拷貝數據文件。
注意:若是在熱備份的時候若是數據庫中斷(如斷電),那麼在從新啓動數據庫的時候,數據庫將提示有數據文件須要恢復,你須要把正在斷電時候的處於備份狀態的數據文件經過ALTER TABLESPACE …… END BACKUP結束備份方式。具體哪一個數據文件或表空間處於備份狀態,能夠經過v$backupv$datafile來得到

4.3 RMAN(備份與恢復管理器)

4.3.1 使用RMAN進行備份

4.3.1.1 瞭解RMAN

Recovery managerRMAN)是ORACLE提供的DBA工具,用於管理備份和恢復操做。RMAN只能用於ORACLE8
     支持在線熱備份
     支持多級增量備份
     支持並行備份、恢復
     減小所須要備分量
     備份、恢復使用簡單
   重要的是,使用恢復管理器容許您進行增量數據塊級的備份(這個與導出/導入的增量大相徑庭)。增量RMAN備份是時間和空間有效的,由於他們只備份自上次備份以來有變化的那些數據塊。另外一個空間有效的RMAN特性是它只備份數據文件中使用的數據塊,忽略空的,未用的數據塊,這個對於預分配空間的表空間有很大的好處。
   9i開始,還增長了RMAN的數據塊級別的恢復,能夠進一步減小數據庫恢復時間。
RMAN支持如下不一樣類型的備份
FULL                       數據庫全備份,包括全部的數據塊
INCREMENTAL              增量備份,只備份自上次增量備份以來修改過的數據塊。須要一個0級的增量做爲增量的基礎,能夠支持7級增量。
OPEN                       在數據庫打開的時候使用
CLOSED                    在數據庫安裝(MOUNT)但不打開的時候備份,關閉備份能夠是CONSISTENTIN CONSISTENT類型的。
CONSISTENT                在數據庫安裝,單不打開,而且在安裝以前數據庫被完全關閉(而不是被破壞或異常退出)時使用。CONSISTENT備份能夠簡單的進行復原(RESTORE)而不是恢復(RECOVER)
INCONSISTENT              在數據庫打開或安裝(但不打開)時使用。在該數據庫正常關閉或崩潰後,INCONSISTENT備份須要恢復。
理解BACKUPRESTORERECOVER命令,這是RMAN最基本的三個命令,能夠進行數據庫的備份,復原以及恢復操做。

4.3.1.2 瞭解恢復目錄

理解恢復目錄,RMAN能夠在沒有恢復目錄(NOCATALOG)下運行,這個時候備份信息保存在控制文件。保存在控制文件的備份信息是很危險的,若是控制文件的破壞將致使備份信息的丟失與恢復的失敗,並且,沒有恢復目錄,不少RMAN的命令將不被支持。因此對於重要的數據庫,建議建立恢復目錄,恢復目錄也是一個數據庫,只不過這個數據庫用來保存備份信息,一個恢復目錄能夠用來備份多個數據庫。
建立RMAN目錄,如下步驟說明了在一個數據庫中創建RMAN目錄的過程。
1.爲目錄建立一個單獨的表空間
SQL>Create tablespace tools datafile ‘fielname’ size 50m;
2.建立RMAN用戶
SQL>Create user RMAN identified by RMAN default tablespace tools temporary tablespace temp;
3.給RMAN授予權限
SQL>Grant connect , resource , recovery_catalog_owner to rman;
4.打開RMAN
$>RMAN
5.鏈接數據庫
RMAN>connect catalog rman/rman
6.建立恢復目錄
RMAN>Create catalog tablespace tools
註冊目標數據庫,恢復目錄建立成功後,就能夠註冊目標數據庫了,目標數據庫就是須要備份的數據庫,一個恢復目錄能夠註冊多個目標數據庫,註冊目標數據庫的命令爲:
$>RMAN target internal/password catalog rman/rman@rcdb;
RMAN>Register database;
數據庫註冊完成,就能夠用RMAN來進行備份了,更多命令請參考ORACLE聯機手冊或《ORACLE8i備份與恢復手冊》。
註銷數據庫不是簡單的在RMAN提示下反註冊就能夠了,須要運行一個程序包,過程以下:
1. 鏈接目標數據庫,得到目標數據庫ID
$> RMAN target internal/password catalog rman/rman@rcdb;
 RMAN-06005: connected to target database: RMAN (DBID=1231209694)
2. 查詢恢復目錄,獲得更詳細的信息
SQL> SELECT db_key, db_id FROM db WHERE db_id = 1231209694;
 
DB_KEY     DB_ID     
---------- ---------------
      1 1237603294
1 row selected.
3. 運行過程dbms_rcvcat.unregisterdatabase註銷數據庫,如
SQL> EXECUTE dbms_rcvcat.unregisterdatabase(1 , 1237603294)

4.3.1.3 採用RMAN進行備份

RMAN使用腳原本備份數據庫,如下是RMAN進行備份的幾個例子。
1.備份整個數據庫
 backup full tag ‘basicdb’ format ‘/bak/oradata/full_%u_%s_%p’ database;
2.備份一個表空間
 backup tag ‘tsuser’ format ‘/bak/oradata/tsuser_%u_%s_%p’ tablespace users;
3.備份歸檔日誌
 backup tag ‘alog’ format ‘/bak/archivebak/arcbak_%u_%s_%p’ archivelog all delete input;

4.3.2 維護RMAN

4.3.2.1 查看RMAN的信息

檢查現有備份
 RMAN>list backup
列出過時備份
 RMAN>report obsolete
刪除過時的備份
 RMAN>allocate channel for maintenance type disk;
 RMAN>change backupset id delete;
 RMAN>release channel;

4.3.2.2 同步或重置RMAN

若是目標數據庫物理對象發生了變化,如添加了一個數據文件,須要用以下命令同步:
RMAN>resync catalog;
若是目標數據庫reset了數據庫,須要用以下命令同步
RMAN>reset database;
當手工刪除了數據庫的歸檔文件後,要執行如下腳本同步
RMAN>allocate channel for maintenance type disk;
RMAN> change archivelog all crosscheck;
RMAN>release channel;
當手工刪除了數據庫的RMAN備份後,要執行如下腳原本同步
RMAN>allocate channel for maintenance type disk;
RMAN>crosscheck backup;
RMAN>delete expire backup;
RMAN>release channel;

第五章. 定製恰當的備份策略

5.1 定製正確的策略

正確的備份策略不只能保證數據庫服務器的24*7的高性能的運行,還能保證備份與恢復的快速性與可靠性。咱們將以RMAN的多級增量備份做爲一個備份策略的例子來討論。採用多級備份就是爲了減小天天備份所須要的時間,而又保證系統有良好的恢復性。恢復時間與備份時間要有一個權衡。好比只要進行一個數據庫的全備份,而後就只備份歸檔也能夠保證能把數據庫恢復到最新的狀態,可是這樣的恢復時間將是不可容忍的。多級備份也正是     爲了解決這種問題,如下就是一個多級備份的例子:
每半年作一個數據庫的全備份(包括全部的數據和只讀表空間)
每個月作一次零級備份(不包含只讀表空間)
每一個星期作一次一級備份
天天作一次二級備份
任何數據庫的更改須要從新同步CATALOG目錄並從新備份(如添加數據文件)或從新備份(如修改表空間爲只讀)
每次備份後均可以備份歸檔日誌或按期備份歸檔日誌。
若是可能,能夠直接備份到磁帶上。
數據庫全備份的腳本
run{
allocate channel c1 type disk;
allocate channel c2 type disk;
allocate channel c3 type disk;
backup full tag ‘dbfull’ format ‘/u01/oradata/backup/full%u_%s_%p’ database
include current controlfile;
sql ‘alter system archive log current’;
backup fileaperset 3 format ‘/u01/oradata/backup/arch%u_%s_%p’
archivelog all delete input;   #備份歸檔可選,能夠單獨按期備份
release channel c1;
release channel c2;
release channel c3;
}
零級備份的腳本
run{
allocate channel c1 type disk;
allocate channel c2 type disk;
allocate channel c3 type disk;
backup incremental level 0 tag ‘db0’ format ‘/u01/oradata/backup/db0%u_%s_%p’
database skip readonly;
sql ‘alter system archive log current’;
backup fileaperset 3 format ‘/u01/oradata/backup/arch%u_%s_%p’
archivelog all delete input;   #備份歸檔可選,能夠單獨按期備份
release channel c1;
release channel c2;
release channel c3;
}
同理,咱們能夠獲得一級備份,二級備份的腳本,如一級備份的腳本
run{
allocate channel c1 type disk;
allocate channel c2 type disk;
allocate channel c3 type disk;
backup incremental level 1 tag ‘db1’ format ‘/u01/oradata/backup/db1%u_%s_%p’
database skip readonly;
sql ‘alter system archive log current’;
backup fileaperset 3 format ‘/u01/oradata/backup/arch%u_%s_%p’
archivelog all delete input;   #備份歸檔可選,能夠單獨按期備份
release channel c1;
release channel c2;
release channel c3;
}
若是按照以上備份策略,則天天的所須要備份的數據量只有一天的改變量。而作恢復時最多要恢復當月的一個零級備份+三個一級備份+6個二級備份+當天的歸檔文件。若是不能接受這樣的恢復時間,能夠減小零級備份之間的時間間隔。
    在每次備份後,原則上在該備份點以前的歸檔日誌就能夠刪除掉了,可是爲了進一步的安全以及往後須要(如使用LOGMNR查找所需信息),建議有條件的話,歸檔日誌保存一年,能夠保存在磁帶等廉價存取設備上。

5.2 RMAN備份有關的優化

備份操做主要是完成如下三個步驟
1、從磁盤上讀取數據
2、在內存中處理數據塊
3、寫入數據到磁盤或磁帶
以上的讀寫操做能夠同步或異步的完成,在同步I/O操做中,一個時間只容許有一個IO操做,可是在異步I/O操做中,一個時間容許有多個IO操做。所以,備份與恢復的調優主要集中在如下幾個方面:
一、  提升同步或異步I/O操做能力
在支持異步操做的操做系統上,能夠經過設置TAPE_AYSNCH_IO,DISK_ASYNCH_IOBACKUP_TYPE_IO_SLAVES來支持異步操做,提升寫的能力。
二、  提升磁盤讀能力
能夠在backup命令後經過設置DISKRATIO來保證從多個磁盤上讀取數據,保證連續的數據流。
三、  正確設置緩衝區與參數值
設置LARGE_POOL_SIZE,使備份可使用連續的緩衝池,經過設置DB_FIL_DIRECT_IO_COUNT能夠提升緩衝區的利用。若是使用磁帶備份,還能夠設置BACKUP_TYPE_IO_SLAVES來提升磁帶的寫能力。
四、  採用並行備份
開闢多個通道,能夠實現並行備份與恢復

5.3 備份RMAN數據庫

RMAN本身的數據庫也須要備份,可是自己很小,並且不是常常發生變化,因此在每次RMAN備份完成後,均可以用以下腳本對RMAN數據庫備份。
EXP pafile =exprman.sql
exprman.sql
USERID=RMAN/RMAN
BUFFER=32768
OWNER=RMAN
FILE=RMAN.DMP
ROWS=Y
GRANTS=Y
COMPRESS=Y
CONSISTENT=Y

5.4 使自動備份數據庫

自動備份數據庫不外乎如下三種方式
    WINDOWS下的任務計劃(At命令)
    UNIX下的Crontab
    第三方工具如Viritas
在以上三種方式中Viritas屬於第三方工具,不少人可能都沒有接觸,主要說一下windows的任務計劃與unixcron
1. 生成腳本文件,如backup.rcv
假定文件內容以下:
$>cat backup.rcv
connect target sys/password rcvcat rman/rman@localname;
run{
allocate channel c1 type disk;
allocate channel c2 type disk;
allocate channel c3 type disk;
backup fileaperset 3 format ‘/u01/oradata/backup/arch%u_%s_%p’
archivelog all delete input;  
release channel c1;
release channel c2;
release channel c3;
}
2. 生成執行文件
windows上生成backup_archive.bat,內容包括
rman cmdfile = backup.rcv
unix下生成 backup_archive.sh,內容包括
/oracle/ramn/rman cmdfile = backup.rcv
3. 加入調度
windows中用任務計劃嚮導便可,或使用at命令。
unix中,在目標機器上編寫一個文件,用以啓動自動備份進程。假定文件名爲ORACLE,文件將放在/var/spool/cron/crontabs目錄下
$>cat oracle
0 23 * * 0 backup_archive.sh
    #表示星期天23點對數據庫備份
0 12,18 * * * backup_archive.sh
    #表示天天12點,18點備份
Crontab文件的每一行由六個域(minutes,hours,day of month,month,day of week,command)組成,域之間用空格或Tab分隔開來

第六章. 常見誤區

1、使用EXP/IMP備份
EXP/IMP不是一個良好的備份工具,在之後的發展之中,ORACLEEXP/IMP用於備份的支持會愈來愈低。ORACLE只是把EXP/IMP看成一個好的工具而不是備份工具,在對於大型數據庫,如TB級數據庫或數據倉庫,EXP/IMP確定會力不從心。
2、在應用程序中備份數據庫
在論壇上,有不少這樣的要求,「我怎麼在程序中備份與恢復數據庫?」。首先說,這個並非不能夠實現,可是實現的過程會很複雜並且意外會不少。就個人感受,提出這樣問題的人,首先一點就是對ORACLEDBA的不瞭解,若是ORACLE能夠這麼輕鬆的實現備份與恢復,那麼我能夠說,就不須要DBA了。
3、冷備份比熱備份更容易,效果會更好
有人認爲,冷備份是關閉數據庫進行的一致性備份,確定比熱備份要好,使用也容易,其實不盡然,在熱備份中,同樣能夠實現數據庫的全備份,並且不會影響到數據庫的運行。建議全部的生產機,都運行在歸檔方式下,採用熱備份方式。

第七章. 常見問題

1、我導出的數據爲何不能導入,提示不支持的字符集轉換
答:參考上面的字符集原則,導出數據時客戶端與數據庫字符集一致,導入時修改成與目標數據庫字符集一致。
2、個人歸檔日誌愈來愈多,我何時能夠刪除歸檔日誌?
答:在每一次全備份(如OS全冷備份或全熱備份)或基於全備份的增量備份(如RMAN基於0級備份上的增量備份)後均可以刪除該備份點以前的歸檔日誌,建議在磁帶上保留一年。
3、全備份時必定須要備份全部數據文件嗎?
答:不須要,起碼有兩類數據文件能夠不備份,一類就是臨時數據文件,若是丟失,能夠刪除後重建;一類是隻讀表空間數據文件,若是上次備份以來,沒有修改過表空間的只讀屬性,就能夠不須要備份。
4、聯機日誌須要備份嗎?
答:若是是歸檔方式熱備份,就沒有必要備份聯機日誌。可是對於冷備份,能夠備份聯機日誌,特別是不歸檔狀態。備份過聯機日誌後的冷備份,由於數據庫是一致的,能夠恢復到該備份點。

第八章. 小結

1、什麼是數據庫備份,數據庫備份就是把數據庫複製到轉儲設備的過程。
2、數據庫的運行方式,能夠分爲歸檔方式和非歸檔方式,建議運行在歸檔方式下運行熱備份。
3、瞭解了數據庫的備份方式,邏輯備份、冷備份、熱備份
4、瞭解數據庫的備份工具,EXP/IMP執行邏輯備份,OS腳本能夠執行冷備份或熱備份,RMAN也能夠執行冷備份或熱備份
5、瞭解ORACLE的備份策略,並怎樣選擇最佳的備份策略
6、知道怎麼樣啓動自動備份,瞭解Windowsat命令與unixcron進程。
相關文章
相關標籤/搜索