我是否可以使用JDBC驱动程序将应用程序故障转移到正确的Oracle数据库实例(Data Guard,而不是RAC集群)

时间:2018-03-12 22:20:36

标签: database oracle failover

我是否可以使用驱动程序将应用程序故障转移到正确的Oracle数据库实例(Data Guard,而不是RAC集群)

文档似乎暗示我可以使用RAC集群,我不确定我是否可以使用Data Guard主要和备用实例。我想这样做是为了避免唱GSLB

但是我没有RAC,我有一个Data Guard主要和备用实例。我可以使用JDBC驱动程序吗?

1 个答案:

答案 0 :(得分:1)

我们在以下配置中使用DataGuard。 jdbc的连接字符串。

  (DESCRIPTION =
    (FAILOVER=ON) 
    (LOAD_BALANCE=off)  
    (ADDRESS_LIST =
      (ADDRESS = (PROTOCOL = TCP)(HOST = 10.xx.yyy.88)(PORT = 1521))
      (ADDRESS = (PROTOCOL = TCP)(HOST = 10.xx.yyy.89)(PORT = 1521))
    )
    (CONNECT_DATA =
      (SERVICE_NAME = D88.XXX.YYY.ZZZ)
      (FAILOVER_MODE=(TYPE=select)(METHOD=basic))
      (SERVER = DEDICATED)
    )
  )

当数据库以主模式启动时,触发器会创建服务。 客户端通过服务名称连接,该服务名称在数据库开头的触发器中创建,而不是由默认数据库名称或服务创建。

CREATE OR REPLACE TRIGGER sys.set_svc_name
 AFTER
  STARTUP
 ON DATABASE
DECLARE role VARCHAR(30);
BEGIN

SELECT Database_Role
INTO Role
FROM V$database;
IF Role = 'PRIMARY' THEN
EXECUTE IMMEDIATE 'alter system set service_names=''d88.XXX.YYY.ZZZ'' scope=memory'; END IF;

END;