1. 程式人生 > >【轉】Oracle 11g Dataguard 參數詳解

【轉】Oracle 11g Dataguard 參數詳解

異步模式 正常 10g enable ffi sys 過程 tnsnames async

轉自:https://www.jb51.net/article/52269.htm

這篇文章主要介紹了Oracle 11g Dataguard參數詳解,包含了獨立參數、主庫參數、備庫參數的詳細說明,需要的朋友可以參考下。

註:本文譯自《Oracle Data Guard 11g Handbook》 Page 78 – Page 88

就Data Guard(後面都寫成DG)來說,我們只關註如下三種參數:

1.獨立於數據庫角色的參數
2.數據庫角色為primary時的參數
3.數據庫角色為standby時的參數

雖然DG有著非常多的配置參數,我們實際使用的只有其中很少的部分,而且因為現在許多的DG功能被集成到了代碼中,最近的DG版本中很多配置參數已經被棄用了。需要註意的是,為了便於完成數據庫的角色轉換(Role transition),與TNS names,listener,SRL(Standby Redo log)文件有關的參數需要在所有數據庫中配置。那麽現在我們來看看這些參數吧:

一、與角色無關的參數

DB_UNIQUE_NAME 該參數定義了數據庫的唯一名稱。因為DB_NAME參數需要滿足與物理備用數據庫(Physical standby)名稱保持一致,和邏輯備用數據庫(logical standby)名稱不相同的條件,所以在10g中該參數被引入用來區分DG配置中的每一個數據庫角色。這個參數需要在所有的數據庫中配置,同時需要重啟數據庫才能生效。如果不配置這個參數,那麽默認會使用DB_NAME參數,這就意味著我們不需要關閉生產庫來完成備用數據庫的配置工作,我們可以在之後進行配置。

代碼如下: db_unique_name=‘Matrix‘

LOG_ARCHIVE_CONFIG

該參數定義了DG配置中可用的DB_UNIQUE_NAME參數值列表。與目標參數(稍後討論)DB_UNIQUE_NAME的值結合使用時,DG以它們來實現兩個數據庫之間連接的安全性檢查工作。只要不指定SEND和RECEIVE屬性,這個參數就是動態的,這兩個屬性是舊參數REMOTE_ARCHIVE_ENABLE遺留下來的,已經不再需要,因此就不要再使用了。

在實際使用時,你只需要將其他數據庫的唯一名稱添加到配置就可以了,當前數據庫的唯一名會根據場景自動添加;不過為了清晰期間,並且在所有的數據庫中保持該參數的一致性,還是會將當前數據庫的唯一名稱明確的添加上去。對於名稱的配置順序沒有要求,該參數在有RAC的環境中是必須要配置的,應該始終使用該參數。

代碼如下: log_archive_config=‘dg_config=(Matrix,Matrix_DR0)‘

CONTROL_FILES 大家都知道這個參數的用途啦(註:當前數據庫控制文件的位置),要記住對於備用數據庫,它指向的是備用控制文件(Standby Control File)的位置。這個控制文件是自動創建的,或者手動創建,取決於你創建備用數據庫的方法。(註:自動創建通常發生在使用RMAN功能產生備用數據庫過程中,如果你是用的是手工方法,控制文件需要手動的從主庫copy過來)

代碼如下: control_files=‘/Oracle/oradata/Matrix/control01.ctl‘

LOG_ARCHIVE_MAX_PROCESSES 提到這個參數是因為它的默認值仍然是2,太小了。在主庫中,歸檔進程負責歸檔已經寫滿的在線日誌文件(Online Redo Log)並作為重做流(Redo Steam)傳輸到備用數據庫來完成間隔處理(Gap);在備庫中,歸檔進程則是負責歸檔備庫日誌文件(Standby Redo Log)並且將其轉發到它的級聯備用數據庫中。(註:級聯備用數據庫是指當前備用數據庫的下一級備庫,即Standby的Standby,從這裏可以看出不管什麽數據庫角色,歸檔進程的工作的內容都是一樣的:1,歸檔日誌文件;2,轉發日誌文件到Standby)

在主庫中,有一個歸檔進程僅限於對在線日誌文件提供服務,無權與備庫進行通信,這個特殊的ARCH進程被稱為“專用ARCH進程”,而其他歸檔進程是可以完成這兩樣功能的。當歸檔進程向備庫發送歸檔日誌文件,就無法協助歸檔ORL文件了;盡管歸檔進程的主要指令是“先歸檔在線日誌文件,再處理主備庫的間隔,”但是在最壞的情況下,仍然可能只有一個歸檔進程在進行歸檔任務。如果沒有足夠的歸檔進程,在慢速網絡,主備庫間出現大的日誌間隔的時候,你可能就只有那麽一個進程在處理日誌文件。這裏就會有個非常棘手的問題,那就是如果這個時候你所有的日誌文件都已經寫滿,生產庫就停滯了,直到其中的一個文件被歸檔。在10g中引入了多線程間隔處理特性(MAX_CONNECTIONS),它允許DG使用多個歸檔進程向備用數據庫發送單個日誌文件,這就意味這我們會使用更多的歸檔日誌進程;因此,這個參數至少要設置4,最大值為30。

代碼如下: log_archive_max_processes=‘4‘

備庫專用ARCH進程

需要註意的是,備用數據庫中也有一個“備庫專用ARCH進程”,不過這僅僅意味著在備庫中少了一個可以歸檔SRL文件歸檔進程而已,在物理備用中,這個專用ARCH進程是沒有歸檔SRL文件功能的。

使用多個歸檔進程時需要註意一點,雖然增加歸檔進程可以減少生產環境中斷的可能,但是大量的歸檔進程會增加主備切換(Switchover)的時間,因為這需要喚醒所有的歸檔進程並使他們退出。我們可以通過在執行切換前將該參數調低來避免這種情況。此外,在11g中引入了新的流式功能(Streaming Capability),如果正好主備庫間的日誌間隔非常大,過多的歸檔進程傳輸會把整個網絡帶寬充滿。

DB_CREATE_FILE_DEST 雖然這不是DG特有的參數,不過還是需要介紹一下的,因為如果你在備庫中使用了ASM,這個參數是要定義的。

代碼如下: db_create_file_dest=+DATA

二、主庫角色參數

LOG_ARCHIVE_DEST_n 這個是DG重做日誌傳輸的主要參數,通常都是在主庫中起作用,當然也會有例外,比如處理級聯備庫的場景;該參數也可用來指定由在線重做日誌(ORL)或備庫重做日誌(SRL)產生的歸檔日誌文件的傳輸目的地,不過隨著10gR1版本中閃回恢復區的引入,本地歸檔的日誌文件默認會放在閃回恢復區,所以在這種情況下就不需要再設置本地歸檔了;我們將會討論一下本地歸檔和LOCATION屬性,不過應該你已經使用了閃回恢復區,所以不需要再進行LOG_ARCHIVE_DEST_n參數的設置了。

這個參數有17個屬性,所有這些屬性都是用來設置主庫到備庫的重做日誌傳輸的;其實你只需要設置其中的7個就可以讓日誌傳輸工作正常了;下面我們會先來介紹一下這7個屬性並且用一些例子來展示一下它們的用法,然後我們再探討一下其余的10個屬性以及它們的使用場景和使用原因,我們建議不要設置其中的6個屬性。

下面是必須的屬性:

SERVICE 指定已經創建的備庫的TNSNAMES描述符,早期的網絡調整就是從這裏開始的。(註:這是DG設置中會較早碰到的與網絡相關的屬性)

SYNC 指定使用同步方法傳送重做數據,即客戶端事務的提交會發生在LGWR進程收到備庫LNS發來的確認信息之後;對於”最大可用模式“和”最大保護模式“,這需要至少一個備庫(Standby)。

ASYNC 默認值;如果沒有指定日誌傳輸類型的話就會使用異步方式發生重做數據;這是”最大性能模式“下的日誌傳輸方法。

NET_TIMEOUT 指定LGWR進程等待LNS進程響應的時間,如果這期間沒有收到響應,則認為備庫發生故障(failed),默認值是30秒,不過10-15可能會是更恰當的值,這取決於你的網絡可靠性。不要將這個值設置為10一下,不然你可能會在備庫恢復正常後還是無法建立連接,這是因為重新連接備庫的操作也會耗費幾秒的時間;因此在這之前,我們需要做:

1.停止舊的LNS進程
2.啟動新的LNS進程
3.與備庫建立連接
4.檢測並停止舊的RFS進程
5.啟動新的RFS進程
6.選擇並打開新的SRL
7.初始化SR頭(註:即備庫的重做日誌數據)
8.響應LNS進程告知已經完成準備工作

所有這些操作完成後,LNS進程才會告訴LGWR進程備庫已連接成功;如果這個過程耗費的時間超過了NET_TIMEOUT的值,那麽LGWR會再次放棄備庫;每次發生日誌切換時都會進行這個重新連接動作。

REOPEN 該屬性控制主庫嘗試重新連接已經發生故障的備庫的等待時間,默認值是300(5分鐘),這通常是大家抱怨在停止備庫後主庫不重連的原因。一般來說,測試的時候都會比較快;先shutdown abort備庫,觀察主庫的alert日誌看是否與備庫斷開連接,再啟動備庫,在主庫中切換日誌觀察是否發生重連,這些操作會在5分鐘內完成,所以如果你手法快,DG不會在第一次(或者更多次)日誌切換時進行重連。這個屬性旨在避免這種情況,即如果備庫發生故障以後主庫立即切換日誌,這個時候的重連很有可能就會失敗,因此你可以考慮將這個屬性設置成30秒甚至是15秒,這樣DG會盡快的完成重連工作。

DB_UNIQUE_NAME 要在參數LOG_ARCHIVE_DEST_n參數中使用這個屬性需要同時設置LOG_ARCHIVE_CONFIG參數,否則DG將拒絕連接這個目標庫;這個SERVICE目標(遠端)名稱是你用來連接另一端的數據庫(也就是備用數據庫)的唯一名稱。

你必須同時在兩端的數據庫中將該唯一名稱添加LOG_ARCHIVE_CONFIG參數中。當主庫向備庫發起連接時,它將會發送自己的數據庫唯一名稱到備庫,同時要求備庫返回唯一名稱。在備庫中將會檢查LOG_ARCHIVE_CONFIG參數,以確保主庫的唯一名確實存在,如果不存在,連接請求將會被拒絕;如果存在,備庫會把自己的唯一名返送回主庫的LNS進程,如果返送的值和主庫中該屬性的值不匹配,連接就會被終止。

和LOG_ARCHIVE_CONFIG參數一樣,這個屬性在RAC環境下是必須要配置的。

VALID_FOR 這是最後一個必須配置的屬性了。盡管你認為不配置這個屬性DG也能正常的工作(確實是這樣),不過還是建議你使用它。該參數的主要功能是定義何時使用目標參數LOG_ARCHIVE_DEST_n以及它作用於哪種類型的日誌文件。

下面是日誌文件的合法值:

1.ONLINE_LOGFILE 僅在歸檔ORL文件時有效
2.STANDBY_LOGFILE 僅在歸檔SRL文件時有效
3.ALL_LOGFILES 無論是那種重做日誌文件類型都有效

下面是角色的合法值:

1.PRIMARY_ROLE 僅在主庫中生效
2.STANDBY_ROLE 僅在備庫中生效
3.ALL_ROLES 主備角色都有效

如果這兩個參數的答復都是TRUE,VALID_FOR就會允許使用目標參數。(註:這裏意思是目標參數會在VALID_FOR的上述兩個子項都是TRUE的時候被使用。比如設置為valid_for=(ONLINE_LOGFILES,PRIMARY_ROLE)那麽如果當前數據庫滿足是主庫並且歸檔ORL文件的條件,LOG_ARCHIVE_DEST_n內的屬性設置就會生效。)有了這個參數,我們就可以預定義DG中所有數據庫的所有目標參數了,並其它們僅在VALID_FOR屬性都是TRUE的時候生效,這樣就沒必要再在角色轉換時啟用和禁用目標了。

那麽LOG_ARCHIVE_DEST_n到底會是什麽樣子呢?最多可以設置9個目標,這就是說我們可以最多擁有9個備庫。其實可以使用10個,不過一個是保留用做默認的本地歸檔目標的,這個我們稍後會討論。這裏我們使用2號參數來添加一個位於曼徹斯特的最高可用的備庫。(為了便於顯示進行了修改)

代碼如下:
log_archive_dest_2=‘service=Matrix_DR0
SYNC REOPEN=15 NET_TIMEOUT=15
valid_for=(ONLINE_LOGFILES,PRIMARY_ROLE)
db_unique_name=Matrix_DR0‘

現在再添加一個位於紐瓦克市的備庫作為3號參數,它的網絡延遲比SYNC長,所以這裏以異步模式來傳輸:

代碼如下:
log_archive_dest_3=‘service=Matrix_DR1
ASYNC REOPEN=15
valid_for=(ONLINE_LOGFILES,PRIMARY_ROLE)
db_unique_name=Matrix_DR1‘


當然我們使用了適當的DB_UNIQUE_NAME屬性,所以我們還要配置LOG_ARCHIVE_CONFIG參數:

代碼如下:
log_archive_config=‘dg_config=(Matrix,Matrix_DR0,Matrix_DR1)‘

下面是可選屬性:

AFFIRM 這是使用SYNC方式目標的默認值。要求LNS進程等待RFS進程完成對SRL文件的直接I/O再返回成功消息,還要求是“最高可用”或”最大保護“模式;因為這個屬性是基於目標的默認值,所以不需要設置它;盡管在10g中可以為ASYNC方式的目標指定這個屬性,不過依然是沒有理由的。實際上,它會拖慢LNS進程。在11g中,AFFIRM屬性會被ASYNC目標忽略掉。

NOAFFIRM 如果沒有特別指定,它會是ASYNC目標的默認值。用於“最大性能”模式;再次聲明,因為它是ASYNC的默認值,所以沒有必要去指定它;並且如果你對SYNC目標設置NOAFFIRM屬性,你的保護模式將違反規定,被標記為“已重新同步”狀態。如果這是你唯一的SYNC備庫,並且處於最大可用模式,那麽你將無法進行零數據丟失的故障轉移(Failover);如果這是你唯一的SYNC目標,並且處於最大保護模式,那麽設置AFFIRM屬性會讓你的主庫崩潰。

COMPRESSION 這個屬性將啟用對備用目標的高級壓縮功能。默認情況下,這就意味著任何一個向該目標發送間隔日誌的歸檔進程都會在發送時壓縮歸檔。如果你設置了這個隱藏屬性,那麽它也會壓縮當前發送的重做日誌流。舉個例子,假如設置這個隱藏參數,我們來對當前的兩個目標庫來添加COMPRESSION屬性:

代碼如下:
log_archive_dest_2=‘service=Matrix_DR0
LGWR SYNC REOPEN=15 NET_TIMEOUT=15
COMPRESSION=ENABLE
valid_for=(ONLINE_LOGFILES,PRIMARY_ROLE)
db_unique_name=Matrix_DR0‘

log_archive_dest_3=‘service=Matrix_DR1
LGWR ASYNC REOPEN=15
COMPRESSION=ENABLE
valid_for=(ONLINE_LOGFILES,PRIMARY_ROLE)
db_unique_name=Matrix_DR1‘

Matrix_DR0目標庫僅在ARCH進程發送用於間隔處理的歸檔日誌的時候才會使用壓縮功能(並非用於同步SYNC的歸檔日誌),而Matrix_DR1庫自始至終都會壓縮重做日誌。這裏說明日誌並不會在磁盤也保持壓縮狀態,因為只會在傳輸過程中壓縮日誌,所以這些傳輸到備庫的數據會被解壓縮,然後再寫入到SRL文件中。

MAX_CONNECTIONS 該屬性在10gR2中被引入,它允許你指定用於備庫間隔處理的歸檔進程的數量,在11g中已經棄用。不過如果你的版本是10g,你可以為它指定值1-5(默認值1);如果你設置的值大於1時,每當備庫需要進行間隔處理的時候,主庫將分配對應數量的歸檔進程用來發送歸檔日誌文件,這些文件會被分片給這些歸檔進程,同時在網絡中以並行流的形式傳送,並在傳送到備庫時重新裝配。

代碼如下:
log_archive_dest_2=‘service=Matrix_DR0
LGWR SYNC REOPEN=15 NET_TIMEOUT=15
MAX_CONNECTIONS=5
valid_for=(ONLINE_LOGFILES,PRIMARY_ROLE)
db_unique_name=Matrix_DR0‘


現在當Matrix_DR0庫與主庫斷開連接的時候,主庫的間隔處理進程將會對每一個確實的歸檔日誌文件使用多個重做流。

註意:

不要在11g數據庫中使用?MAX_CONNECTIONS屬性,這會降低日誌傳輸的性能。

DELAY 這個屬性並不是像大多數想象的那樣延遲重做數據的傳輸,它只是用來指示備庫目標的日誌應用進程在DELAY屬性設置的時間(秒)後應用重做數據。有了閃回數據庫,這個屬性幾乎被棄用,尤其在自從我們建議在主備庫中一直啟用閃回數據庫功能後。 如果你傾向於完成一些閃回數據庫無法處理的任務量,則可能需要設置這個延遲時間。第8章將討論閃回數據庫和Data Guard。

ALTERNATE 替代(ALTERNATE)目標最初的目的是,當正在歸檔ORL日誌文件的磁盤空間已滿時,保持數據庫的持續運行。使用替代目標,你可以將歸檔日誌文件重定向到一個備用磁盤中。有了閃回恢復區(自動管理空間),這個問題基本上消失了。

如果你有多個指向備庫的網絡路徑,也可以為遠程備用目標使用該屬性。顯然,你會在RAC環境中使用多個備庫網絡路徑,但是這並不是ALTERNATE屬性設計的初衷。對於有著多網卡的單實例或者RAC的環境,在備庫的TNS描述符中使用connect-time failover會更簡便。(註:參見connect-time failover )

建議不要使用以下的屬性:

LOCATION 在10gR2之前,該屬性必須指定一個文件位置用於歸檔進程存儲歸檔日誌文件,並且這在主庫(對於ORL文件)和備庫(對於SRL文件)確實是正確的。不過隨著閃回恢復區和默認本地歸檔的使用,這個屬性已經不再需要設置了。編號為10的目標將自動設置成閃回恢復區。

代碼如下:
SQL> SELECT DESTINATION FROM V$ARCHIVE_DEST WHERE DEST_ID=10;
USE_DB_RECOVERY_FILE_DEST

SQL> ARCHIVE LOG LIST
Database log mode Archive Mode
Automatic archival Enabled
Archive destination USE_DB_RECOVERY_FILE_DEST
Oldest online log sequence 19
Next log sequence to archive 21
Current log sequence 2

如果你正在使用閃回恢復區,並且你想定義一個本地目標,那麽應該使用相同的語法:

代碼如下:
log_archive_dest_1=‘location=USE_DB_RECOVERY_FILE_DEST
valid_for=(ONLINE_LOGFILES,PRIMARY_ROLE)
db_unique_name=Matrix‘

如果你還是不使用閃回恢復區,也可以使用舊的磁盤路徑寫法:

代碼如下:
log_archive_dest_1=‘location=/u03/oradata/Matrix/arch/
valid_for=(ONLINE_LOGFILES,PRIMARY_ROLE)
db_unique_name=Matrix‘

註意在如上的兩種情況下,DB_UNIQUE_NAME都是指向你在其上定義了目標(註:也就是歸檔的存放位置)的數據庫,而並非遠程的備庫。在上面的例子中,歸檔位置目標在Matrix庫上,因此如果你要在這裏使用DB_UNIQUE_NAME屬性,就需要指定Matrix為DB_UNIQUE_NAME的值。

註意:

如果使用閃回恢復區,就不要使用LOCATION屬性來指定本地歸檔位置了。

MANDATORY 這是備庫上最危險的屬性之一。基本上,它規定ORL文件中的redo信息必須發送到該備庫。如果redo信息無法發送到備庫,那麽主庫中包含redo信息的這個ORL文件在成功發送到備庫之前將無法被重用(reuse)。試想當備庫無法訪問並且主庫中所有可用的日誌文件都被遍歷完了,那麽生產系統就會停滯。當然,有一個本地目標是MANDATORY的以使文件存放在磁盤上,不過沒有必要再設置另一個了。默認情況下,本地歸檔中的一個目標會被設置成MANDATORY。

註意:

不要設置MANDATORY屬性。

MAX_FAILURE 這個屬性是所有屬性中最遭人誤解的一個。人們都傾向與認為這個屬性表示LGWR進程在放棄發生故障的備庫並繼續產生日誌之前,重新連接備庫的次數。事實並非如此,如果你設置了該屬性,實際是定義了LGWR嘗試重連有故障的備庫時,日誌組切換的次數(註:原文寫的更加讓人容易誤解,這裏的意思就是切換一次日誌,重連一次備庫)。舉例來說,如果將MAX_FAILURE的值設置成5,那麽LGWR將會在它循環切換日誌期間對故障備庫總共發起5次連接請求,如果切換了5次還是無法連接到故障備庫,那麽LGWR將放棄重連,之後你要麽等手動重新啟用它或者等主庫重啟重新生效該屬性。

註意:

不要設置MAX_FAILURE屬性。

NOREGISTER 這是我們討論的LOG_ARCHIVE_DEST_n參數的最後一個屬性。默認情況下,DG要求任何發送到備庫的redo數據都需要在歸檔至磁盤的時候完成對備庫的註冊。對於一個物理備庫來說,意味著數據會被註冊到備庫的控制文件中;而對於邏輯備庫來說,它意味著SQL Apply會在元數據中註冊日誌文件。DG不需要這個屬性,它可以用在使用downstream特性的Streams目標庫中。

註意:

不要設置NOREGISTER屬性。

LOG_ARCHIVE_DEST_STATE_n 這是和LOG_ARCHIVE_DEST_n配套使用的參數。在過去,有兩個原因我們需要配置它。一是啟用備庫中主角色LOG_ARCHIVE_DEST_n參數的預定義,以使得該參數被啟用後歸檔進程可以使用LOG_ARCHIVE_DEST_n來工作;另一個原因是配置一個如前面所述的ALTERNATE目標。第一個原因已經沒有作用了(現在使用了VALID_FOR),並且除非你使用?ALTERNATE屬性,否則第二個原因也不成立了,因為現在這個參數默認就是ENABLE的了,你不再需要為你的目標庫設置它了。

代碼如下:
log_archive_dest_state_1=enable

三、備用角色參數

DB_FILE_NAME_CONVERT 在備庫中,該參數允許你邏輯上將數據文件從主庫遷移到備庫上,如果你使用的是基於磁盤的存儲結構並且存儲路徑在兩個系統上並不相同,那麽就有必要配置它。只有在備庫切換為主庫這期間,該轉換才會執行。一旦進行主備切換或者故障切換到備庫,這些值就會被寫入到控制文件和數據文件頭。通過簡單的字符替換就可以實現功能。

代碼如下:
db_file_name_convert=‘/Matrix/‘,‘/Matrix_DR0/‘


上面的命令會將如下數據文件名:

代碼如下:
‘/u03/oradata/Matrix/sysaux.dbf‘


轉換為:

代碼如下:
‘/u03/oradata/Matrix_DR0/sysaux.dbf‘


同理,如下配置會將數據文件指向到+RECOVERY磁盤組中而不是+DATA;

代碼如下:
db_file_name_convert=‘+DATA‘,‘+RECOVERY‘


路徑的其他部分將保持相同,在本例中,使用了ASM來創建備庫,你不需要定義這個參數了。

LOG_FILE_NAME_CONVERT 它的功能和DB_FILE_NAME_CONVERT參數相同,只不過這裏轉換的是日誌文件,包括ORL文件和任何SRL文件。

代碼如下:
log_file_name_convert=‘/Matrix/‘,‘/Matrix_DR0/‘


FAL_SERVER FAL(Fetch Archive Log)功能相比9iR1時的DG已經有了很大的進步。它只用於物理備庫,配置它能夠使得物理備庫在發現問題時,從DG配置中的一個數據庫(主庫或備庫)中獲取缺失的歸檔日誌文件,有時我們又成它為被動間隔處理(reactive gap resolution),不過FAL技術在之前的三個版本中得到了極大的增強以至於現在幾乎不需要再定義FAL參數了。伴隨著9iR2版本引入的主動間隔處理(proactive gap resolution)技術的使用,幾乎物理或邏輯備庫上任何類型的間隔請求都可以由主庫上的ping進程來處理了。

在主庫的正常工作過程中,歸檔進程(被指定為ping進程)會輪流查詢所有的備庫來尋找redo間隔,與此同時處理任何應用進程發來的未解決的間隔請求。當物理備庫需要從主庫之外的數據庫中獲得間隔文件時就可以使用FAL技術。舉個例子,比如物理備庫現在需要進行間隔處理,但是主庫無法訪問,那麽它需要去請求其他的備庫來完成間隔處理,為此,你要將FAL_SERVER參數定義為指向主庫或者任意備庫的TNS標識符列表。如在Matrix_DR0庫中加入主庫(Matrix)和其他備庫(Matrix_DR1):

代碼如下:
fal_server=‘Matrix, Matrix_DR1‘


FAL_CLIENT FAL客戶端就是發起間隔請求的數據庫的TNS名稱,間隔請求的接收方(FAL_SERVER)需要這個TNS名稱以使得FAL服務器上的數據庫可以反向連接至請求方。在備庫Matrix_DR0上,我們發送Matrix_DR0作為客戶端名稱以便Matrix和Matrix_DR1庫可以連接回Matrix_DR0庫發送缺失的歸檔日誌文件。

代碼如下:
fal_client=‘Matrix_DR0‘


‘Matrix_DR0′必須要在FAL服務器的TNS文件中定義以使得DG能夠成功連接備庫;因為我們將會在所有這些數據庫中設置redo傳輸參數,所以我們也要為它們配置TNS名稱。如果你在FAL參數中使用相同的TNS名稱,那麽這些TNS名稱就是定義好的了。如果你選擇了一個不同的名稱,你就需要在所有系統的TNS文件中添加這個名稱。和FAL_SERVER參數一樣,FAL_CLIENT參數只對物理備庫有效。

STANDBY_FILE_MANAGEMENT 這是本章節討論的最後一個參數了。這個簡單的參數只用於物理備庫。該參數設置成AUTO的時候,主庫中添加和刪除數據文件的同時,備庫中也會自動的進行相應的更改。只要備庫中頂級目錄存在或能夠借助於DB_

FILE_NAME_CONVERT參數找到,那麽DG將會執行DDL語句在備庫中創建數據文件。它甚至會盡可能的創建缺失的子目錄。默認情況下,這個參數的值為MANUAL,這意味著備庫上的應用進程不會創建新的數據文件,你需要手動創建它們。

代碼如下:
standby_file_management=‘AUTO‘


只有當需要對物理備庫上的ORL文件執行定義操作的時候,我們才可能會將該參數設置成MANUAL。SRL文件能夠在不改這個參數的情況下添加。如果你真要在物理備庫上添加或刪除在線日誌文件(比如因為主庫上發生了更改),你也可以將這個參數動態的設置成MANUAL,執行DDL操作,然後再還原成AUTO值,無需重啟備庫。

參數與屬性小結

在了解上面的所有參數和屬性之後,你應該對它們的功能和特性有了深刻的理解並且可以正確的配置使用了。

希望你不要對這些感到頭疼,因為有一點你或許會感到詫異:如果你使用Data Guard Broker(即使不用Grid Control),就沒必要親自配置這些參數了,DG Broker會為你做好一切。

-- END --

【轉】Oracle 11g Dataguard 參數詳解