Oracle RAC failover 測試(Server TAF方式)

來源:互聯網
上載者:User

    Oracle RAC中,除了基於用戶端的TAF方式之外,還有基於伺服器端的TAF方式,可以把服務端的TAF方式看作是用戶端TAF方式的一個升級版吧。伺服器端的TAF,當然是需要在伺服器端進行配置了,這個是通過Service來完成的。本文主要描述Oracle 10g rac 下通過service方式設定管理員端的TAF。

  下面是一些關於這方面的基礎參考連結:
  有關負監聽配置,載均衡(load balance)請參考
    ORACLE RAC 監聽配置 (listener.ora tnsnames.ora)
    ORACLE RAC 下非預設連接埠監聽配置(listener.ora tnsnames.ora)
    Oracle RAC 用戶端串連負載平衡(Load Balance)
    Oracle RAC 伺服器端串連負載平衡(Load Balance)
    Oracle RAC 負載平衡測試(結合伺服器端與用戶端)
    
  有關Oracle RAC failover 串連時容錯移轉請參考
    Oracle RAC failover 測試(串連時容錯移轉)
    Oracle RAC failover 測試(TAF方式)
    
  有關Services的建立請參考
    Services in Oracle Database 10g
    再說 Oracle RAC services

1、伺服器端、用戶端的環境  #伺服器端環境,host資訊  oracle@bo2dbp:~> cat /etc/hosts |grep vip  192.168.7.61   bo2dbp-vip.2gotrade.com    bo2dbp-vip  192.168.7.62   bo2dbs-vip.2gotrade.com    bo2dbs-vip    #伺服器端環境,叢集資訊  oracle@bo2dbp:~> ./crs_stat.sh    Resource name                                Target     State               --------------                                ------     -----               ora.GOBO4.GOBO4A.inst                         ONLINE     ONLINE on bo2dbp    ora.GOBO4.GOBO4B.inst                         ONLINE     ONLINE on bo2dbs    ora.GOBO4.db                                  ONLINE     ONLINE on bo2dbp    ora.bo2dbp.ASM1.asm                           ONLINE     ONLINE on bo2dbp    ora.bo2dbp.LISTENER_BO2DBP.lsnr               ONLINE     ONLINE on bo2dbp    ora.bo2dbp.LISTENER_ORA10G_BO2DBP.lsnr        ONLINE     ONLINE on bo2dbp    ora.bo2dbp.gsd                                ONLINE     ONLINE on bo2dbp    ora.bo2dbp.ons                                ONLINE     ONLINE on bo2dbp    ora.bo2dbp.vip                                ONLINE     ONLINE on bo2dbp    ora.bo2dbs.ASM2.asm                           ONLINE     ONLINE on bo2dbs    ora.bo2dbs.LISTENER_BO2DBS.lsnr               ONLINE     ONLINE on bo2dbs    ora.bo2dbs.LISTENER_ORA10G_BO2DBS.lsnr        ONLINE     ONLINE on bo2dbs    ora.bo2dbs.gsd                                ONLINE     ONLINE on bo2dbs    ora.bo2dbs.ons                                ONLINE     ONLINE on bo2dbs    ora.bo2dbs.vip                                ONLINE     ONLINE on bo2dbs    ora.ora10g.db                                 ONLINE     ONLINE on bo2dbp   #用戶端環境  robin@SZDB:~> cat /etc/issue    Welcome to SUSE Linux Enterprise Server 10 SP3 (x86_64) - Kernel \r (\l).    robin@SZDB:~> sqlplus -v    SQL*Plus: Release 10.2.0.3.0 - Production    #用戶端tnsnames配置  GOBO4 =    (DESCRIPTION =      (ADDRESS = (PROTOCOL = TCP)(HOST = 192.168.7.61)(PORT = 1521))      (ADDRESS = (PROTOCOL = TCP)(HOST = 192.168.7.62)(PORT = 1521))      (LOAD_BALANCE = yes)      (CONNECT_DATA =        (SERVER = DEDICATED)        (SERVICE_NAME = TAF)  #注意我們用戶端的SERVICE_NAME,我們設定為TAF       )    )2、在伺服器端配置service  配置service有多種方式,如dbca,oem,srvctl命令列。下面直接以命令列方式配置  關於什麼是service以及如何使用srvctl命令列建立service,請參考: http://blog.csdn.net/robinson_0612/article/details/8124232  oracle@bo2dbp:~> srvctl add service -d GOBO4 -s TAF -r GOBO4A -a GOBO4B -P basic  oracle@bo2dbp:~> srvctl start service -d GOBO4 -s TAF  oracle@bo2dbp:~> ./crs_stat.sh | grep TAF  ora.GOBO4.TAF.GOBO4A.srv                      ONLINE     ONLINE on bo2dbp    ora.GOBO4.TAF.cs                              ONLINE     ONLINE on bo2dbp              oracle@bo2dbp:~> srvctl config service -d GOBO4 -a  TAF PREF: GOBO4A AVAIL: GOBO4B TAF: basic  oracle@bo2dbp:~> export ORACLE_SID=GOBO4A  oracle@bo2dbp:~> sqlplus / as sysdba    SQL*Plus: Release 10.2.0.3.0 - Production on Mon Dec 17 14:55:02 2012    Copyright (c) 1982, 2006, Oracle.  All Rights Reserved.    Connected to:  Oracle Database 10g Release 10.2.0.3.0 - 64bit Production  With the Real Application Clusters option    SQL> show parameter service    NAME                                 TYPE        VALUE  ------------------------------------ ----------- ------------------------------  service_names                        string      SYS$SYS.KUPC$S_1_2012102317304                                                   4.GOBO4, SYS$SYS.KUPC$C_1_2012                                                   1023173044.GOBO4, GOBO4, TAF    SQL> begin       2  dbms_service.modify_service(       3  service_name=>'TAF',       4  failover_method =>dbms_service.failover_method_basic,       5  failover_type =>dbms_service.failover_type_select,       6  failover_retries =>180,       7  failover_delay=>5);       8  end;       9  /    PL/SQL procedure successfully completed.      SQL> select name,failover_method,failover_type,goal,clb_goal from dba_services    2  where name='TAF';    NAME                 FAILOVER_METHOD      FAILOVER_TYPE   GOAL         CLB_G  -------------------- -------------------- --------------- ------------ -----  TAF                  BASIC                SELECT                       LONG                                                       SQL> ho lsnrctl status    ..........  Service "TAF" has 1 instance(s).    Instance "GOBO4A", status READY, has 2 handler(s) for this service...  The command completed successfully3、測試伺服器端TAF  robin@SZDB:~> sqlplus fail_over/fail@gobo4  fail_over@GOBO4> get verify.sql    1  REM the following query is for TAF connection verification    2  col sid format 99999    3  col serial# format 9999999    4  col failover_type format a13    5  col failover_method format a15    6  col failed_over format a11    7  Prompt    8  Prompt Failover status for current user    9  Prompt ============================================   10  SELECT   sid,   11   serial#,   12   failover_type,   13   failover_method,   14   failed_over   15   FROM   v$session   16   WHERE   username = 'FAIL_OVER';   17  REM the following query is for load balancing verification   18  col host_name format a20   19  Prompt   20  Prompt Current instance name and host name   21  Prompt ========================================   22* SELECT   instance_name,host_name FROM v$instance;   23       #下面的串連查詢中表明用戶端當前串連到了節點bo2dbp,其執行個體名為GOBO4A   fail_over@GOBO4> @verify            Failover status for current user  ============================================       SID  SERIAL# FAILOVER_TYPE FAILOVER_METHOD FAILED_OVER  ------ -------- ------------- --------------- -----------    1073       48 SELECT        BASIC           NO      Current instance name and host name  ========================================    INSTANCE_NAME    HOST_NAME  ---------------- --------------------  GOBO4A           bo2dbp      #此時停止節點bo2dbp  oracle@bo2dbp:~> srvctl stop instance -d GOBO4 -i GOBO4A  #查看停止節點bo2dbp即執行個體GOBO4A後的結果  oracle@bo2dbp:~> ./crs_stat.sh |grep inst  ora.GOBO4.GOBO4A.inst                         OFFLINE    OFFLINE             ora.GOBO4.GOBO4B.inst                         ONLINE     ONLINE on bo2dbs      #此時回到用戶端再次執行查詢,FAILED_OVER的值已經變成YES,即表明當前的session為failover過來的  #同時執行個體名和節點名也發生了變化  fail_over@GOBO4> set timing on;  fail_over@GOBO4> @verify    Failover status for current user  ============================================       SID  SERIAL# FAILOVER_TYPE FAILOVER_METHOD FAILED_OVER  ------ -------- ------------- --------------- -----------    1082      396 SELECT        BASIC           YES    Elapsed: 00:00:04.19    Current instance name and host name  ========================================    INSTANCE_NAME    HOST_NAME  ---------------- --------------------  GOBO4B           bo2dbs    Elapsed: 00:00:00.014、小結  a、伺服器端的TAF方式的failover通過在伺服器端配置service來完成  b、伺服器端的TAF方式與用戶端的TAF方式產生同樣的效果  b、一旦在服務端配置了基於伺服器端的TAF,用戶端再無需通過在用戶端添加FAILOVER_MODE項  c、該方式簡化用戶端配置,通過集中統一管理service實現failover

更多參考

有關Oracle RAC請參考
     使用crs_setperm修改RAC資源的所有者及許可權
     使用crs_profile管理RAC資源設定檔
     RAC 資料庫的啟動與關閉
     再說 Oracle RAC services
     Services in Oracle Database 10g
     Migrate datbase from single instance to Oracle RAC
     Oracle RAC 串連到指定執行個體
     Oracle RAC 負載平衡測試(結合伺服器端與用戶端)
     Oracle RAC 伺服器端串連負載平衡(Load Balance)
     Oracle RAC 用戶端串連負載平衡(Load Balance)
     ORACLE RAC 下非預設連接埠監聽配置(listener.ora tnsnames.ora)
     ORACLE RAC 監聽配置 (listener.ora tnsnames.ora)
     配置 RAC 負載平衡與容錯移轉
     CRS-1006 , CRS-0215 故障一例 
     基於Linux (RHEL 5.5) 安裝Oracle 10g RAC
     使用 runcluvfy 校正Oracle RAC安裝環境

有關Oracle 網路設定相關基礎以及概念性的問題請參考:
     配置非預設連接埠的動態服務註冊
     配置sqlnet.ora限制IP訪問Oracle
     Oracle 監聽器日誌配置與管理
     設定 Oracle 監聽器密碼(LISTENER)
     配置ORACLE 用戶端串連到資料庫

有關基於使用者管理的備份和備份恢複的概念請參考
     Oracle 冷備份
     Oracle 熱備份
     Oracle 備份恢複概念
     Oracle 執行個體恢複
     Oracle 基於使用者管理恢複的處理
     SYSTEM 資料表空間管理及備份恢複
     SYSAUX資料表空間管理及恢複
     Oracle 基於備份控制檔案的恢複(unsing backup controlfile)

有關RMAN的備份恢複與管理請參考
     RMAN 概述及其體繫結構
     RMAN 配置、監控與管理
     RMAN 備份詳解
     RMAN 還原與恢複
     RMAN catalog 的建立和使用
     基於catalog 建立RMAN儲存指令碼
     基於catalog 的RMAN 備份與恢複
     RMAN 備份路徑困惑
     使用RMAN實現異機備份恢複(WIN平台)
     使用RMAN遷移檔案系統資料庫到ASM
     linux 下RMAN備份shell指令碼
     使用RMAN遷移資料庫到異機

有關ORACLE體繫結構請參考
     Oracle 資料表空間與資料檔案
     Oracle 密碼檔案
     Oracle 參數檔案
     Oracle 聯機重做記錄檔(ONLINE LOG FILE)
     Oracle 控制檔案(CONTROLFILE)
     Oracle 歸檔日誌
     Oracle 復原(ROLLBACK)和撤銷(UNDO)
     Oracle 資料庫執行個體啟動關閉過程
     Oracle 10g SGA 的自動化管理
     Oracle 執行個體和Oracle資料庫(Oracle體繫結構) 

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.