Oracle 12c R2中的ADG会话保留特性

IT科技类资讯2025-11-05 13:57:004

Oracle 12c R2中有一个不错的会话保特性,那就是留特Active Data Guard会话保留,原本的会话保叫法是Preserving Active Data Guard Application Connections

怎么理解呢,比如在Active Data Guard上的留特连接会话,在switchover的会话保过程中会话连接会始终保持不会中断。这一点听起来就很有特点,留特能够提高用户体验度,会话保而且是留特一种相对透明的方式。

到底怎么样呢,会话保我们来简单测试一下,留特先看看默认情况下的会话保ADG会话情况,切换的过程就直接使用DG Broker来做了,快。云南idc服务商留特

这是会话保一个12cR2的环境,也使用了Far Sync。留特

DGMGRL>show  configuration  Configuration - dg_test12cs   Protection Mode: MaxPerformance   Members:   test12cs  - Primary database     test_sync - Far sync instance      test12css - Physical standby database   Fast-Start Failover: DISABLED  Configuration Status:

SUCCESS (status updated 10 seconds ago)我们连接到备库,会话保备库现在是ADG模式。

SQL> select open_mode from v$database;  OPEN_MODE  ---------------------------------------- 

READ ONLY WITH APPLY如果这个时候我们就使用一条语句在备库端查询,使用TNS连接,然后DG Broker来切换,切换的情况如下,也是一气呵成。

DGMGRL> switchover to test12css  Performing switchover NOW, please wait...  Operation requires a connection to database "test12css"  Connecting ...  Connected to "test12css"  Connected as SYSDBA.  New primary database "test12css" is opening...  Operation requires start up of instance "test12cs" on database "test12cs"  Starting instance "test12cs"...  for RDBMS instance  ORACLE instance started.  Database mounted.  Database opened.  Connected to "test12cs"  Switchover succeeded, new primary is "test12css"  DGMGRL>

在客户端反复测试连接的情况如下:

SQL> select count(*) from cat;   COUNT(*)  ----------         153  SQL> /   COUNT(*)  ----------         153  SQL> /  select count(*) from cat  *  ERROR at line 1:  ORA-03113: end-of-file on communication channel  Process ID: 94489  Session ID: 419 Serial number: 62932

可以看到在切换的过程中,连接被中断了,而接下来就会彻底断开连接。

SQL> /  ERROR:  ORA-03114: not connected to ORACLE 

这里就需要说一下这个特性的情况,服务器托管其实还涉及到一个参数standby_db_preserve_states,默认是NONE

SQL> show parameter standby_db_preserve_states  NAME                                TYPE                  VALUE  ------------------------------------ ---------------------- ------  standby_db_preserve_states          string                NONE

我们设置为ALL,这个修改需要重启备库,我们设置好之后,再来做switchover

步骤和上面的类似,我们直接来看看效果,始终在这一个会话内查看数据查询的情况,整个过程相对平滑,在切换过程中会有一个大约两秒的停顿,但是连接始终是保持的。

COUNT(*) ----------        153 SQL> /  COUNT(*) ----------        153 SQL> /  COUNT(*) ----------        153       SQL> /  COUNT(*) ----------        153 SQL> /  COUNT(*) ----------        153

整体来看这个特性确实达到了预期的效果,还是蛮不错的。

本文地址:http://www.bhae.cn/news/633b28899078.html
版权声明

本文仅代表作者观点,不代表本站立场。
本文系作者授权发表,未经许可,不得转载。

全站热门

夏普海思(高性能处理器带来流畅体验,多项智能功能助力生活便捷)

​更明智的网络风险管理策略

MySQL极限测试:索引提高的效率

利用MSSQL的链接服务器将Oracle链接到MSSQL实现同步

以惠而浦空调怎么样?(品牌评测及用户体验调查)

​更明智的网络风险管理策略

​防范未授权访问攻击的十项安全措施

Fronton物联网僵尸网络能够影响舆论信息

友情链接

滇ICP备2023000592号-9