Skip to main content

"Seamless Conversion: Switching Oracle RAC Physical Standby to Snapshot Standby and Vice versa"

 Oracle Data Guard allows database administrators to create a physical standby database to ensure high availability and disaster recovery. However, in certain scenarios, it is necessary to temporarily convert a physical standby database to a snapshot standby database for testing or development purposes. This guide provides step-by-step instructions on how to perform this conversion and revert it back to a physical standby database.


Converting Physical Standby to Snapshot Standby

DATABASE NAME: STANDBY
INSTANCES: STANDBY1,STANDBY2

Step 1: Check the Current Standby Status

SELECT status, instance_name, database_role, open_mode FROM v$database, gv$Instance;

STATUS       INSTANCE_NAME    DATABASE_ROLE    OPEN_MODE
------------ ---------------- ------------------------------------- --------------------
OPEN                  standby1                   PHYSICAL STANDBY MOUNTED
OPEN                  standby2                   PHYSICAL STANDBY MOUNTED

Run the following queries to check the last received and applied sequence numbers, along with the managed recovery process (MRP) status:


Query 1: Query to check MRP status:

select process,sequence#,status from gv$managed_standby;

Query 2: To Check the Timing until which the DR database is in sync with primary database:

select sequence#, thread#, to_char(FIRST_TIME,'dd-mm-yyyy hh24:mi:ss') "SYNC TIME" from v$log_history where sequence# in (select max(sequence#) from gv$log_history group by thread#) order by thread#;

Step 2: Cancel Managed Recovery

Cancel the managed recovery process on the standby database:

ALTER DATABASE RECOVER MANAGED STANDBY DATABASE CANCEL;

Verify that the recovery process has stopped:

SELECT process, sequence#, thread#, status, blocks, block#, inst_id FROM gv$managed_standby WHERE process='MRP0';

Step 3: Stop the Standby Database

Check the database configuration:

srvctl config database                  ##To get the list of database running 

srvctl status database -d standby -v      ##To get to know instance status

Stop the standby database:

srvctl stop database -d standby -o immediate

Step 4: Convert to Snapshot Standby

Start the instance in mount mode:

srvctl start instance -d standby -i standby1 -o mount

connect to the instance and convert the database to snapshot standby:

ALTER DATABASE CONVERT TO SNAPSHOT STANDBY;

ALTER DATABASE OPEN;

Verify the conversion:

select name, status, instance_name, database_role, open_mode FROM v$database, gv$Instance;

STATUS     INSTANCE_NAME    DATABASE_ROLE    OPEN_MODE

------------ ---------------- ---------------- --------------------

OPEN         standby1                       SNAPSHOT STANDBY READ WRITE

Start the second instance:

srvctl start instance -d standby -i standby2 -o open

Verify the database status again:

select status, instance_name, database_role, open_mode FROM v$database, gv$Instance;

STATUS     INSTANCE_NAME    DATABASE_ROLE    OPEN_MODE

------------ ---------------- ---------------- --------------------

OPEN         standby1                       SNAPSHOT STANDBY READ WRITE

OPEN         standby2                       SNAPSHOT STANDBY READ WRITE


Converting Snapshot Standby Back to Physical Standby

Step 1: Verify Snapshot Standby Status

Check the current status of the snapshot standby database:

select status, instance_name, database_role, open_mode FROM v$database, gv$Instance;

STATUS     INSTANCE_NAME    DATABASE_ROLE    OPEN_MODE

------------ ---------------- ---------------- --------------------

OPEN         standby1                       SNAPSHOT STANDBY READ WRITE

OPEN         standby2                       SNAPSHOT STANDBY READ WRITE


Step 2: Stop the Database

Stop the snapshot standby database:

srvctl stop database -d standby


Step 3: Start in Mount Mode and Convert to Physical Standby

Start the instance in mount mode:

srvctl start instance -d standby -i standby1 -o mount

Verify that it is in the correct mode:

select status, instance_name, database_role, open_mode FROM v$database, gv$Instance;

Convert back to physical standby:

ALTER DATABASE CONVERT TO PHYSICAL STANDBY;


Step 4: Restart Standby and Resume Recovery:

Start the second standby instance:

srvctl start instance -d standby -i standby2 -o mount

Verify the status:

select status, instance_name, database_role, open_mode FROM v$database, gv$Instance;

STATUS       INSTANCE_NAME    DATABASE_ROLE    OPEN_MODE
------------ ---------------- ------------------------------------- --------------------
OPEN                  standby1                   PHYSICAL STANDBY MOUNTED
OPEN                  standby2                   PHYSICAL STANDBY MOUNTED

Start managed recovery:

ALTER DATABASE RECOVER MANAGED STANDBY DATABASE DISCONNECT FROM SESSION;


Step 5: Verify Standby Synchronization:

Check the MRP process and sequence synchronization:

select process,sequence#,status from gv$managed_standby;

select sequence#, thread#, to_char(FIRST_TIME,'dd-mm-yyyy hh24:mi:ss') "SYNC TIME" from v$log_history where sequence# in (select max(sequence#) from gv$log_history group by thread#) order by thread#;


Comments

Popular posts from this blog

🚀 Automating Oracle Database Patching with Ansible: A Complete Guide

Oracle database patching has long been the bane of DBAs everywhere. It's a critical task that requires precision, expertise, and often results in extended maintenance windows. What if I told you that you could automate this entire process, reducing both risk and downtime while ensuring consistency across your Oracle estate? 💡 In this comprehensive guide, I'll walk you through a production-ready Ansible playbook that completely automates Oracle patch application using OPatch. Whether you're managing a single Oracle instance or hundreds of databases across your enterprise, this solution will transform your patch management strategy! 🎯 🔥 The Challenge: Why Oracle Patching is Complex Before diving into the solution, let's understand why Oracle patching is so challenging: 🔗 Multiple dependencies : OPatch versions, Oracle Home configurations, running processes ⚠️ Risk of corruption : Incorrect patch application can render databases unusable ⏰ Downtime requirements : Da...

Oracle RAC Switchover & Switchback: Step-by-Step Guide

 Ensuring business continuity requires regular Disaster Recovery (DR) drills. This guide covers the Switchover and Switchback process between Primary (DC) and Standby (DR) databases . Pre-checks Before Performing Switchover Before starting the activity, ensure there are no active sessions in the database. If any are found, share the session details with the application team, get their confirmation, and terminate the sessions. Primary Database Name: PRIMARY Standby Database Name: STANDBY  Identify Active Sessions set lines 999 pages 999 col machine for a30 col username for a30 col program for a30 compute sum of count on report break on report select inst_id,username,osuser,machine,program,status,count(1) "count" from gv$session where inst_id=1 and program like 'JDBC%' group by inst_id,username,osuser,machine,program,status order by 1,2; select inst_id,username,osuser,machine,program,status,count(1) "count" from gv$session where inst_id=2 and program lik...

Mastering Oracle RAC with SRVCTL Commands

Oracle Real Application Clusters (RAC) provide high availability, scalability, and manageability for databases. One of the most powerful tools for managing RAC databases is srvctl , a command-line utility that allows administrators to control various database services. This blog explores essential srvctl commands to help you efficiently manage Oracle RAC environments. 1. Checking Database Configuration and Status  List all available databases on the host:                  srvctl config database   Check the status of a specific database and its instances:                    srvctl status database -d <database_name>   Retrieve detailed status information about a database, including its instances and states:                    srvctl status database -d <database_name> -v 2. Stopping and Starting Databases   ...