首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >我是否可以使用JDBC驱动程序将应用程序故障切换到正确的Oracle DB实例(Data Guard,而不是RAC群集)

我是否可以使用JDBC驱动程序将应用程序故障切换到正确的Oracle DB实例(Data Guard,而不是RAC群集)
EN

Stack Overflow用户
提问于 2018-03-13 06:20:36
回答 1查看 851关注 0票数 2

是否可以使用驱动程序将应用程序故障切换到正确的Oracle DB实例(Data Guard,而不是RAC群集)

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

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

EN

回答 1

Stack Overflow用户

发布于 2018-03-13 11:16:10

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

代码语言:javascript
复制
  (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)
    )
  )

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

代码语言:javascript
复制
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;
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/49245308

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档