是否可以使用驱动程序将应用程序故障切换到正确的Oracle DB实例(Data Guard,而不是RAC群集)
文档似乎建议我可以使用RAC集群,但我不确定是否可以使用Data Guard主实例和备用实例。我想这样做是为了避免唱GSLB
但是我没有RAC,我有一个Data Guard主实例和备用实例。我可以为此使用JDBC驱动程序吗?
发布于 2018-03-13 11:16:10
我们在以下配置中使用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;https://stackoverflow.com/questions/49245308
复制相似问题