物理Standby資料庫的檔案路徑轉換(3)
前文連結:
物理Standby資料庫的檔案路徑轉換(2)--STANDBY_FILE_MANAGEMENT 引數的值很重要
物理Standby資料庫的檔案路徑轉換(1)--*_FILE_NAME_CONVERT 引數什麼時候生效的呢
==========================================
3、 *_FILE_NAME_CONVERT 能決定一切嗎?
通過前面的示例,我們就知道*_file_name_convert並不一定有效,不過,是否除此之外其它情況下,*_file_name_convert引數就能主宰了呢?答案又是否定的。原因請看下列示例:
根據JSSPDG建立另一個物理Standby:JSSLDG,然後登陸並檢視相關資訊。
首先也是檢視路徑轉換引數的設定:
JSSLDG> show parameter db_file_
NAME TYPE VALUE
------------------------------------ ----------- ------------------------------
db_file_multiblock_read_count integer 16
db_file_name_convert string F:\oracle\oradata\jssbook, L:\
oradata\JSSLDG, L:\oradata\JSS
LDG, F:\oracle\oradata\jssbook
db_files integer 200
JSSLDG> select name from v$datafile;
NAME
------------------------------------------------------------------------------------
L:\ORADATA\JSSPDG\SYSTEM01.DBF
L:\ORADATA\JSSPDG\UNDOTBS01.DBF
L:\ORADATA\JSSLDG\SYSAUX01.DBF
L:\ORADATA\JSSPDG\USERS01.DBF
L:\ORADATA\JSSPDG\SCOTT01.DBF奇怪啊奇怪,後兩個檔案的路徑可以理解,經常第2例的測試,已知該路徑無法通過convert引數做轉換,但是前面兩個檔案並沒有顯式修改過路徑啊,為什麼convert引數對其也無效呢?仔細回憶JSSLDG的建立過程,由於JSSLDG是通過複製JSSPDG實現,複製時JSSPDG處於REDO應用狀態,難道是這個原因嗎?
停止jsspdg物理Standby的REDO應用再複製試試:
JSSPDG> alter database recover managed standby database cancel;
Database altered.Jssldg 的再建立就簡單多了,只複製資料檔案日誌檔案就好了,因為初始化引數、金鑰檔案等均不需要做改動,重新執行查詢:
JSSLDG> select name from v$datafile;
NAME
------------------------------------------------------------------------------------
L:\ORADATA\JSSPDG\SYSTEM01.DBF
L:\ORADATA\JSSPDG\UNDOTBS01.DBF
L:\ORADATA\JSSLDG\SYSAUX01.DBF
L:\ORADATA\JSSPDG\USERS01.DBF
L:\ORADATA\JSSPDG\SCOTT01.DBF路徑沒有變化,說明與複製時物理Standby是否處於應用模式無關。此時注意到一個細節問題,由於jsspdg也是剛剛建立並啟動redo應用,而從資料檔案的修改日誌來看,恰恰是修改了system01.dbf和undotbs01.dbf兩個檔案,難道是由於這兩個檔案修改過,Standby 端中的控制檔案路徑就自動做了轉換?測試一下。
正常情況下,物理Standby資料庫的控制檔案應該是通過Primary建立,前面為了省事,建立jssldg時也是直接複製的jsspdg的控制檔案,這裡我們嘗試直接通過Primary建立standby控制檔案:
JSSPRE> alter database create standby controlfile as 'l:\oradata\jssldg\jssldg01.ctl' reuse;
Database altered.啟動jssldg後重新執行查詢:
JSSLDG> select name from v$datafile;
NAME
------------------------------------------------------------------------------------
L:\ORADATA\JSSLDG\SYSTEM01.DBF
L:\ORADATA\JSSLDG\UNDOTBS01.DBF
L:\ORADATA\JSSLDG\SYSAUX01.DBF
L:\ORADATA\JSSLDG\USERS01.DBF
L:\ORADATA\JSSLDG\SCOTT01.DBFOK ,路徑已經正常顯示。接下來我們再建立一個新的物理Standby環境,以便測試當物理Standby有修改時,是否就會自動轉換自己控制檔案中的檔案路徑。
假設新建立的物理Standby叫JSSLDG2(建立步驟省略),切換回jssldg資料庫,啟動REDO應用,從作業系統中監控一個jssldg資料庫的資料檔案是否有修改,當發現system01.dbf和undotbs01.dbf檔案有修改操作(這兩個檔案太有意思了,要改一塊改。不過想想也正確,應該是巧合,當system表空間資料檔案要操作時,用到了undo表空間,因此才會導致兩個表空間的資料檔案都被修改),馬上覆制jssldg資料庫的控制檔案到jssldg2資料庫,然後重新啟動jssldg2資料庫,並檢視檔案路徑:
JSSLDG 2> select name from v$datafile;
NAME
------------------------------------------------------------------------------------
L:\ORADATA\JSSLDG\SYSTEM01.DBF
L:\ORADATA\JSSLDG\UNDOTBS01.DBF
L:\ORADATA\JSSLDG2\SYSAUX01.DBF
L:\ORADATA\JSSLDG2\USERS01.DBF
L:\ORADATA\JSSLDG2\SCOTT01.DBF可以看到,修改過的資料檔案的路徑,沒有被convert引數轉換。
基於上例,我們又可以得出一個結論,如果物理Standby在執行過程中,修改過檔案(含資料檔案和日誌檔案),那麼這部分檔案在Standby端控制檔案中的路徑,也會被自動修改成應用*_file_name_convert後的路徑。
最後,如果你發現在建立Dataguard環境時,由於Primary資料庫和物理Standby資料庫資料檔案路徑無法保持一致,雖然設定了初始化引數,並且確認引數設定無問題,但Standby端的檔案路徑仍然不對,那不妨對照前面幾個例子,看看是否符合了某些初始化引數無法控制的條件。因為Standby資料庫的路徑轉換是否好使,並不僅僅取決於convert引數是正確配置。
來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/7607759/viewspace-604199/,如需轉載,請註明出處,否則將追究法律責任。
相關文章
- 遷移資料庫的檔案到不同路徑(轉)資料庫
- 更改資料檔案路徑的方法
- CentOS修改Mariadb資料庫檔案儲存路徑CentOS資料庫
- [重慶思莊每日技術分享]-ORACLE DG物理備庫使用別名資料檔案改變路徑到OMF路徑Oracle
- Python科研武器庫 - 檔案/路徑操作 - 判斷檔案或資料夾Python
- gcc g++ 新增標頭檔案路徑和庫檔案路徑的方法GC
- Java中的獲取檔案的物理絕對路徑,和讀取檔案Java
- oracle 資料庫lsnrctl監聽的日誌路徑和trace檔案Oracle資料庫
- 修改Oracle資料檔名及資料檔案存放路徑Oracle
- 【Oracle】如何修改資料檔案和日誌檔案的路徑Oracle
- DataGuard---->物理StandBy的角色切換之switchover
- 歸檔路徑更改後,如何對資料庫進行恢復(轉)資料庫
- dedecms資料庫配置檔案所在路徑為:/data/common.inc.php資料庫PHP
- oracle11g修改資料檔案路徑Oracle
- oracle 修改資料檔案位置(路徑)(移動)Oracle
- oracle 修改資料檔案路徑(四種方式)Oracle
- 用Aspose-Java免費實現 PDF、Word、Excel、Word互相轉換並將轉換過得檔案上傳OSS,返回轉換後的檔案路徑JavaExcel
- Python科研武器庫 - 檔案/路徑操作 - 判斷路徑是否存在Python
- 資料庫轉換工具,不同資料庫之前任意轉換資料庫
- Python內建庫:pathlib(檔案路徑操作)Python
- HttpRunner3原始碼閱讀:4. loader專案路徑載入,用例檔案轉換、方法字典生成HTTP原始碼
- 【轉載】Linux查詢檔案安裝路徑Linux
- Linux檔案的路徑定位-相對路徑和絕對路徑Linux
- nodejs遞迴資料夾獲取所有檔案路徑NodeJS遞迴
- Microsoft Excel 教程「3」,如何在 Excel 中保護檔案、轉換資料型別?ROSExcel資料型別
- 1.3. 資料庫路徑整合資料庫
- 桌面檔案在c盤哪個資料夾 c盤桌面檔案路徑
- Sqlserver資料庫儲存路徑的修改SQLServer資料庫
- NodeJs 的幾種檔案路徑NodeJS
- 【物理】回首路徑積分
- oracle升級後資料檔案路徑變為大寫Oracle
- css檔案與資源路徑相關CSS
- python如何將相對路徑轉換為絕對路徑?Python
- 將DBF檔案(dBase, FoxPro等)中的資料轉換到SQLiteSQLite
- SQLite3資料庫檔案結構解析SQLite資料庫
- CMake連結庫,會檢索庫引用標頭檔案路徑
- Unity 編輯器中獲取選中的資料夾、檔案路徑Unity
- Permute 3 for mac(媒體檔案格式轉換器)Mac
- 回顧Node檔案路徑