Oracle 10g R2 主备自动切换之客户端Failover配置

为了达到实例宕掉但监听不宕的情况下也行, 监听需要全部是动态注册的, 不允许静态配置的服务名. 因为动态注册的话,当实例宕掉后

1. 主库检查和设置

假设新增的服务名为ORCL_TAF.LK.

SQL> exec dbms_service.create_service(service_name=>’ORCL_TAF.LK’, network_name=>’ORCL_TAF.LK’);
SQL> exec dbms_service.start_service(service_name=>’ORCL_TAF.LK’);
SQL> CREATE OR REPLACE TRIGGER trg_oci_service
after startup on database
DECLARE
role VARCHAR(30);
BEGIN
SELECT DATABASE_ROLE INTO role FROM V$DATABASE;
IF role=’PRIMARY’ THEN
DBMS_SERVICE.START_SERVICE(‘ORCL_TAF.LK’);
END IF;
END;
/
SQL> show parameter service_names
NAME                                 TYPE            VALUE
———————————— ————— ——————————
service_names                        string          ORCL_TAF.LK

若备库非实时应用,则手工归档确保触发器传到备库:
SQL> ALTER SYSTEM ARCHIVE LOG CURRENT;

确认可以显示新增的服务:
$ lsnrctl status

Service “ORCL_TAF.LK” has 1 instance(s).
Instance “ORCL”, status READY, has 1 handler(s) for this service…

2. 配置OCI客户端(包括纯OCI/OCCI客户端和JDBC-OCI客户端)

为了达到实例宕掉但监听不宕的情况下也行, 监听需要全部是动态注册的, 不允许静态配置的服务名. 因为动态注册的话,,当实例宕掉后,其服务名就会从监听中消失, 此时应用才会去偿试第二个IP地址. 如果有静态配置的话, 则由于监听是可以接受客户端的请求, 将不会去偿试第二个IP地址, 而是报出Oracle not available的错误.

$ vi $ORACLE_HOME/network/admin/tnsnames.ora
——————————————————————————–
DB_ORCL=
(DESCRIPTION=
(ADDRESS_LIST=
(ADDRESS=(PROTOCOL=TCP)(HOST=primary_host)(PORT=1521))
(ADDRESS=(PROTOCOL=TCP)(HOST=standby_host)(PORT=1521))
)
(CONNECT_DATA=
(SERVER=DEDICATED)
(SERVICE_NAME=ORCL_TAF.LK)
)
)
——————————————————————————–
注意: ADDRESS_LIST中包含主备库服务器和端口信息, 其中SERVICE_NAME为新增的服务名ORCL_TAF.LK.

对于JDBC-OCI客户端配置方法为”jdbc:oracle:oci8:@DB_ORCL”.

–End–

linux

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至253000106@qq.com举报,一经查实,本站将立刻删除。

发布者:PHP中文网,转转请注明出处:https://www.chuangxiangniao.com/p/1951411.html

(0)
上一篇 2025年2月23日 02:42:26
下一篇 2025年2月23日 02:42:43

AD推荐 黄金广告位招租... 更多推荐

相关推荐

发表回复

登录后才能评论