我是否可以使用驱动程序将应用程序故障转移到正确的Oracle数据库实例(Data Guard,而不是RAC集群)
文档似乎暗示我可以使用RAC集群,我不确定我是否可以使用Data Guard主要和备用实例。我想这样做是为了避免唱GSLB
但是我没有RAC,我有一个Data Guard主要和备用实例。我可以使用JDBC驱动程序吗?
答案 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;