如需轉載,請註明出處!(刁饞在此先謝過瞭……) Oracle TAF的配置 TAF為Transparent Application FailOver的縮寫,一般應用TAF都是在OPS/RAC環境中。從8i開始有的這一功能,目的和想法都是很好的,但目前應用還很有限,本文將針對TAF相關問題作個詳細探討。 本文的測試環境是Tru64 V5.1+ Oracle9.2.0.1 RAC。 一、相關參數的說明 說實話oracle關於網絡的幾個配置參數真的是太亂瞭,很多人都弄不清到底是怎麼回事,常見的錯誤為: "ORA-12514 :TNS:listener could not resolve SERVICE_NAME given in connect descriptor" 和 "ORA-12154 :TNS: Could not resolve service name" 實質都是一樣的,要解決這樣的問題需要我們弄情幾個參數: initsid.ora中的幾個參數: DB_NAME — database name,即建數據庫時所提供的名稱。 GLOBAL_NAMES — True/false,設定是否使用數據庫域名。 DB_DOMAIN — 數據庫域名,如果GLOBAL_NAMES=True則要求提供這個參數。 SERVICE_NAMES — service names list,服務名稱,可以有多個。 INSTANCE_NAME — instance name,和SERVICE_NAMES一樣從817開始支持,即從817開始可以將數據庫、實例和服務名稱分開。默認instance_name的值為instance的SID,即環境變量ORACLE_SID所對應的值。在817以前沒有instance_name參數時,不同的instance是以SID來區分的。按照oracle817以後的文檔解釋:SID是為瞭區別同一主機上各instance的共享內存,並不是instance的唯一區別標示,而instance_name則是區別各個instance的。 環境變量: ORACLE_SID — 在817以前沒有instance_name參數時,不同的instance是以SID來區分的(詳細說明見上面的initsid.ora參數解釋)。 listener.ora中的幾個參數: GLOBAL_DBNAME — 全局數據庫名稱,在分佈式環境中唯一確定不同的數據庫。它的值為initsid.ora中DB_NAME和DB_DOMAIN的組合,即GLOBAL_DBNAME=DB_NAME.DB_DOMAIN,其中DB_DOMAIN如果沒有設此處也就不需要瞭。這個參數在分佈式環境中建議明確指定。 SERVICE_NAME — 服務名稱,取initsid.ora中service_names list至一即可。 SID_NAME — 對應環境變量ORACLE_SID的值。 INSTANCE_NAME —對應初始化參數instance_name。 tnsnames.ora中的幾個參數: service_name — 服務名稱,取initsid.ora中service_names list至一即可。 sid_name — 可以簡寫成:sid,對應ORACLE_SID,也可以是初始化參數instance_name,當等於instance_name且instance_name不等於ORACLE_SID時,oracle會自動註冊一個監聽進程,此用以區分不同的instance。 instance_name — 從817開始有瞭這個新的參數可以使用,對應初始化參數instance_name。 這樣一來,參數就很復雜瞭,不過我們實際使用並不會用當然十月簡單越好瞭。 二、相關參數設置 下面我將舉例說明相關參數的設置: 1、環境變量:ORACLE_SID=rac1/2 2、initsid.ora: db_name=ora92 service_names = ora92 instance_name=rac1/2 global_names=false db_domain="" 3、listener.ora: SID_LIST_RAC1 = (SID_LIST = (SID_DESC = (GLOBAL_DBNAME = ora92) (ORACLE_HOME = /oracle/oracle9/app/oracle/product/9.2.0) (SERVICE_NAME=ora92)(SID_NAME = rac1) ) ) SID_LIST_RAC2 = (SID_LIST = (SID_DESC = (GLOBAL_DBNAME = ora92) (ORACLE_HOME = /oracle/oracle9/app/oracle/product/9.2.0) (SERVICE_NAME=ora92)(SID_NAME = rac2) ) ) RAC1 = (DESCRIPTION_LIST = (DESCRIPTION = (ADDRESS_LIST = (ADDRESS = (PROTOCOL = TCP)(HOST = 10.1.3.1)(PORT = 1522)) ) ) ) RAC2 = (DESCRIPTION_LIST = (DESCRIPTION = (ADDRESS_LIST = (ADDRESS = (PROTOCOL = TCP)(HOST = 10.1.3.2)(PORT = 1522)) ) ) ) 三、TAF的設置 其實TAF設置很簡單,在tnsnames.ora中添加failover=on即可,有兩種不同的設置方法: 1、公用一個tns name方式:================================================== myrac = (description= (load_balance=on) (failover=on) (address= (protocol=tcp)(host=10.1.3.1)(port=1522)) (address= (protocol=tcp)(host=10.1.3.2)(port=1522)) (connect_data= (service_name=ora92) (failover_mode=(type=select)(method=basic)(retries=20)(delay=20)) ) ) ========================================================================== 2、指明instance backup方式:=============================================== rac1 = (description= (load_balance=on) (failover=on) (address= (protocol=tcp)(host=10.1.3.1)(port=1522)) (connect_data= (service_name=ora92) (failover_mode=(type=select)(method=basic) (backup=rac2)(retries=20)(delay=20)) ) ) rac2 = (description= (load_balance=on) (failover=on) (address= (protocol=tcp)(host=10.1.3.2)(port=1522)) (connect_data= (service_name=ora92) (failover_mode=(type=select)(method=basic) (backup=rac1)(retries=20)(delay=20)) ) ) ========================================================================== 四、TAF測試方法 一般可以將當前連接的instance down下來,client端將不會斷開,並自動切換到backup節點上。相反也會自動切換回來。 當然也有人提出用post_transaction的方式來測試TAF,其實這樣有時是得不到預期結果的,原因在於Oracle連接到一個instance上後,此後它會優先嘗試對該instance的連接,當你disconnect後,client端一有新的請求就會自動嘗試對最近連接的instance進行連接,如果不成功才會嘗試對backup instance進行連接。