Oracle Faq(Oracle TAF的設定)_PHP教學課程
如需轉載,請註明出處! (刁饞在此先謝過了…)
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. SID_LIST_RAC1 =
(SID_LIST =
(SID_DESC =
(GLOBAL_DBNAME = ora92)
(ORACLE_HOME = /oracle/oracle9/app/oracle/product/9.2.0)> )(SID_NAME = rac1)
)
)
SID_LIST_RAC2 =
(SID_LIST =
(SID_DESC =
(GLOBAL_DBN = M>(SID_DES) /oracle9/app/oracle/product/9.2.0)
(SERVICE_NAME=ora92)(SID_NAME = rac2)
)
)
RAC1 =
(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)(ADDRESS = (PROTOCOL = TCP)(HOST = 10.1.3.2)(PORTDRESS = (PROTOCOL = TCP)(HOST = 10.1.3.2)(PORT = 152))>
)
)
三、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_movdedemode =(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)
(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=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進行連接。
http://www.bkjia.com/PHPjc/314196.html

熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

Video Face Swap
使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱門文章

熱工具

記事本++7.3.1
好用且免費的程式碼編輯器

SublimeText3漢化版
中文版,非常好用

禪工作室 13.0.1
強大的PHP整合開發環境

Dreamweaver CS6
視覺化網頁開發工具

SublimeText3 Mac版
神級程式碼編輯軟體(SublimeText3)

Oracle 打不開的解決辦法包括:1. 啟動數據庫服務;2. 啟動監聽器;3. 檢查端口衝突;4. 正確設置環境變量;5. 確保防火牆或防病毒軟件未阻止連接;6. 檢查服務器是否已關閉;7. 使用 RMAN 恢復損壞的文件;8. 檢查 TNS 服務名稱是否正確;9. 檢查網絡連接;10. 重新安裝 Oracle 軟件。

解決 Oracle 游標關閉問題的方法包括:使用 CLOSE 語句顯式關閉游標。在 FOR UPDATE 子句中聲明游標,使其在作用域結束後自動關閉。在 USING 子句中聲明游標,使其在關聯的 PL/SQL 變量關閉時自動關閉。使用異常處理確保在任何異常情況下關閉游標。使用連接池自動關閉游標。禁用自動提交,延遲游標關閉。

Oracle 中,FOR LOOP 循環可動態創建游標, 步驟為:1. 定義游標類型;2. 創建循環;3. 動態創建游標;4. 執行游標;5. 關閉游標。示例:可循環創建游標,顯示前 10 名員工姓名和工資。

Oracle 日誌文件寫滿時,可採用以下解決方案:1)清理舊日誌文件;2)增加日誌文件大小;3)增加日誌文件組;4)設置自動日誌管理;5)重新初始化數據庫。在實施任何解決方案前,建議備份數據庫以防數據丟失。

Oracle不僅是數據庫公司,還是雲計算和ERP系統的領導者。 1.Oracle提供從數據庫到雲服務和ERP系統的全面解決方案。 2.OracleCloud挑戰AWS和Azure,提供IaaS、PaaS和SaaS服務。 3.Oracle的ERP系統如E-BusinessSuite和FusionApplications幫助企業優化運營。

在CentOS系統上搭建Hadoop分佈式文件系統(HDFS)需要多個步驟,本文提供一個簡要的配置指南。一、前期準備安裝JDK:在所有節點上安裝JavaDevelopmentKit(JDK),版本需與Hadoop兼容。可從Oracle官網下載安裝包。環境變量配置:編輯/etc/profile文件,設置Java和Hadoop的環境變量,使系統能夠找到JDK和Hadoop的安裝路徑。二、安全配置:SSH免密登錄生成SSH密鑰:在每個節點上使用ssh-keygen命令

要停止 Oracle 數據庫,請執行以下步驟:1. 連接到數據庫;2. 優雅關機數據庫(shutdown immediate);3. 完全關機數據庫(shutdown abort)。

可以通過使用 Oracle 的動態 SQL 來根據運行時輸入創建和執行 SQL 語句。步驟包括:準備一個空字符串變量來存儲動態生成的 SQL 語句。使用 EXECUTE IMMEDIATE 或 PREPARE 語句編譯和執行動態 SQL 語句。使用 bind 變量傳遞用戶輸入或其他動態值給動態 SQL。使用 EXECUTE IMMEDIATE 或 EXECUTE 執行動態 SQL 語句。
