14 Using DBMS_ROLLING to Perform a Rolling Upgrade
The Rolling Upgrade Using Oracle Active Data Guard feature provides a streamlined method of performing rolling upgrades.
It is implemented using the DBMS_ROLLING
PL/SQL package, which enables you to upgrade the database software in an Oracle Data Guard configuration in a rolling fashion. The Rolling Upgrade Using Oracle Active Data Guard feature requires a license for the Oracle Active Data Guard option.
You can use this feature to perform database version upgrades starting with the first patchset of Oracle Database 12c. You cannot use it to upgrade from any version earlier than the first Oracle Database 12c patchset. This means that the manual Transient Logical Standby upgrade procedure must still be used when upgrading from Oracle Database 11g to Oracle Database12c, or when upgrading from the initial Oracle Database 12c release to the first patchset of Oracle Database 12c.
The DBMS_ROLLING
package performs Oracle Data Guard switchovers to minimize downtime of the primary database service. Prior to using DBMS_ROLLING
, the Oracle Data Guard environment must be properly configured to accommodate switchovers. The setup requirements differ depending on whether Oracle Data Guard broker is active during execution of DBMS_ROLLING
:
-
If the broker is going to be active during
DBMS_ROLLING
, then see Oracle Data Guard Broker for information about setting up the broker for a switchover. -
If the broker is not going to be active during
DBMS_ROLLING
, then see Role Transitions Involving Logical Standby Databases. The absence of Oracle Data Guard broker means thatLOG_ARCHIVE_DEST_
n parameters must be properly configured on the target primary database so that redo shipping resumes after the switchover.
Additionally, you can use this feature immediately for other database maintenance tasks beginning with Oracle Database 12c Release 1 (12.1). The database where maintenance is performed must be operating at a minimum of Oracle 12.1. Such maintenance tasks include:
-
Adding partitioning to non-partitioned tables
-
Changing BasicFiles LOBs to SecureFiles LOBs
-
Changing
XMLType
stored asCLOB
toXMLtype
stored as binary XML -
Altering tables to be OLTP-compressed
See the following topics:
Concepts New to Rolling Upgrades
To upgrade the database software in an Oracle Data Guard configuration in a rolling fashion, you first designate a physical standby as the future primary database.
Conceptually, the rolling upgrade process splits the Oracle Data Guard configuration into two groups: the leading group (LG) and the trailing group (TG).
Databases in the leading group are upgraded first; hence the name leading group. The leading group contains the designated future primary database, and the physical standbys that you can configure to protect the designated future primary. The future primary is first converted into a logical standby database and then the new database software is installed on it and the upgrade process is run. Other standby databases in the leading group also must have their software upgraded at this point.
The trailing group contains the original primary database and standby databases that protect the original primary during the rolling upgrade process. While the databases in the leading group are going through the upgrade process, user applications can still be connected to the original primary and making changes. The trailing group databases continue running the old database software until all the databases in the leading group are upgraded and the future primary has caught up with the original primary by applying the changes that were generated at the original primary database during the upgrade window. At this point a switchover is done to transfer the primary role to the designated future primary database, and the user applications are switched over to the new primary database. New software is then installed on the databases that are part of the trailing group, and they are reinstated into the configuration as standbys to the new primary database.
The standbys in the respective groups are called the Leading Group Standbys (LGS) and Trailing Group Standbys (TGS). Other than the designated future primary, all other standbys in the leading group can only be physical standbys. The trailing group can contain both physical and logical standbys; they are called Trailing Group Physical (TGP) and Trailing Group Logical (TGL) in cases where it is necessary to make a distinction between the standby types. The designated future primary is also called the Leading Group Master (LGM) and the original primary database is called the Trailing Group Master (TGM).
The DBMS_ROLLING
package increases the robustness of the rolling upgrade process as follows:
-
It can handle failures during the rolling upgrade process. The original primary or the TGM database can fail. You can initiate a regular failover operation to any other physical standby in the trailing group, and then designate the new primary database as the TGM.
-
It allows data protection of the LGM (the designated future primary) during the rolling upgrade process. You can set up physical standbys for the LGM database, and thus protect it during the upgrade process and also achieve Zero Data Loss after the upgrade. After the LGM has been successfully upgraded, a failure in the LGM can be accommodated by failing over to any of its physical standby databases. You can then designate the failover target database to take over the role of the LGM.
Table 14-1 compares the characteristics of TGP standbys versus LGP standbys before and after a switchover operation.
Table 14-1 Trailing Group Physicals (TGP) Versus Leading Group Physicals (LGP)
Standby Type | Before Switchover | After Switchover | Notes |
---|---|---|---|
Trailing Group Physical (TGP) |
Low apply lag Lower data loss risk |
High apply lag Higher data loss risk |
Can fail over to the primary role Must flash back like the original primary |
Leading Group Physical (LGP) |
High apply lag Higher data loss risk |
Low apply lag Lower data loss risk |
Can fail over to the transient logical standby role Does not have to flash back like the original primary |
See Also:
-
Oracle Database PL/SQL Packages and Types Reference for a description of the
DBMS_ROLLING
PL/SQL package -
Unsupported Tables During Rolling Upgrades for information about how to determine whether any of the tables involved in the upgrade contain data types that are unsupported when performing an upgrade using the
DBMS_ROLLING
PL/SQL package -
Additional PL/SQL Package Support Available Only in the Context of DBMS_ROLLING Upgrades for information about PL/SQL packages that are supported only in the context of a
DBMS_ROLLING
upgrade
DBMS_ROLLING Upgrades in a Multitenant Environment
There are additional requirements and considerations when performing rolling upgrades in a multitenant environment.
Requirements Specific to DBMS_ROLLING Upgrades
The additional requirements when you use DBMS_ROLLING
to perform a
rolling upgrade in a multitenant environment are as follows.
-
The TNS services referenced in the
LOG_ARCHIVE_DEST_n
parameters must be services that resolve to the root container of the destination database. The process assistingDBMS_ROLLING
performs numerous operations which can only execute from the root container. -
All container databases on the transient logical standby must be plugged in and opened prior to calling
DBMS_ROLLING.SWITCHOVER
. This eliminates the possibility that the logical standby apply engine will halt because it cannot apply to a given PDB.
See Example 14-6 for an example rolling upgrade using DBMS_ROLLING
.
Additional Considerations for DBMS_ROLLING Upgrades
Installing, upgrading, or patching of applications installed in application
containers is not supported while a DBMS_ROLLING
upgrade is in
progress.
-
If DDL is executed to start the install, upgrade, or patching of an application container while a
DBMS_ROLLING
upgrade is in progress, then an error is returned. (TheDBMS_ROLLING
upgrade continues.) -
If an upgrade to an application container is in progress, then an attempt to start a
DBMS_ROLLING
upgrade results in an error. (The application container upgrade continues.) -
If a
DBMS_ROLLING
upgrade is performed and database compatibility is set to 12.2 or higher, then replication of application containers is supported. Except forDBMS_ROLLING
upgrades, logical standby does not offer any support for application containers; such containers are skipped and a message is written to the alert log indicating that application containers are being skipped. -
The CDB that you are upgrading using
DBMS_ROLLING
can contain pluggable databases (PDBs) with different character sets.
Data Guard Broker Support for DBMS_ROLLING Upgrades
As of Oracle Database 12c Release 2 (12.2.0.1), Data Guard broker can remain on during a DBMS_ROLLING
rolling upgrade; there is no longer any need to disable it.
Keep the following in mind regarding Data Guard broker support for DBMS_ROLLING
upgrades:
-
Broker support is enabled by default during execution of the
DBMS_ROLLING.BUILD_PLAN
procedure if the broker is enabled at the time of the call. When broker support is enabled, the broker sets up the redo transport destinations as necessary from the original primary database as well as from the rolling upgrade target. -
The fast-start failover feature must be disabled before starting a
DBMS_ROLLING
upgrade. -
Any attempt to enable fast-start failover while a rolling upgrade is in progress is rejected.
-
While a rolling upgrade is in progress, role changes are permissible only to the standby databases that are protecting the current primary database. The broker reports the role of the rolling upgrade target as
Transient Logical Standby
during aSHOW CONFIGURATION
command as well as reporting the configuration status asROLLING DATABASE MAINTENANCE IS IN PROGRESS
. If there are standby databases protecting both the original primary and the upgrade target, then this topology is reflected when theSHOW CONFIGURATION
command is issued from the current primary as well as from the upgrade target (before it has taken over as the primary database). -
The broker prevents a role change to a standby that is not protecting the current primary. This ensures that before the switchover phase, role changes to the Trailing Group Standby are allowed, and after the switchover phase, role changes are only allowed to the Leading Group Standbys.
-
During the start of the upgrade process, if the upgrade target is an Oracle RAC database, then the broker automatically reduces the target standby to one instance and allows the upgrade to proceed. Without the broker, the start of the upgrade is rejected if it is found that the target has multiple instances running.
-
The broker notifies Oracle Clusterware and Global Data Services as appropriate during the course of the rolling upgrade.
-
Although role transitions are typically performed using the broker, the switchover step in a rolling upgrade should continue to be performed using the
DBMS_ROLLING.SWITCHOVER
procedure. -
Information about the status of a rolling upgrade being done using the PL/SQL package
DBMS_ROLLING
, is displayed in the output of the broker commandsSHOW CONFIGURATION
andSHOW DATABASE
.The
SHOW CONFIGURATION
command shows Transient logical standby database as the role of the upgrade target, andROLLING DATABASE MAINTENANCE IN PROGRESS
as the configuration status. An example of this output is as follows:Configuration - DRSolution Protection Mode: MaxPerformance Members: North_Sales - Primary database South_Sales - Transient logical standby database Fast-Start Failover: DISABLED Configuration Status: ROLLING DATABASE MAINTENANCE IN PROGRESS
The
SHOW DATABASE
command shows aWARNING
with an appropriateORA
error for the upgrade target and the trailing or leading standbys, depending on the current rolling upgrade progress. An example of this output is as follows:Database - South_Sales Role: Physical standby database Intended State: APPLY-ON Transport Lag: *** Apply Lag: *** Average Apply Rate: *** Real Time Query: OFF Instance(s): South Database Warning(s): ORA-16866: database converted to transient logical standby database for rolling database maintenance Database Status: WARNING
- Starting with Oracle Database 21c, the
JSON
data type can be used with logical standby databases in the context ofDBMS_ROLLING
. TheCOMPATIBLE
parameter must be set to 21.0 or higher.
See Also:
Overview of Using DBMS_ROLLING
There are three stages to the rolling upgrade process using the DBMS_ROLLING
PL/SQL Package: specification, compilation, and execution.
-
Specification: You first specify how you want to implement the rolling upgrade process. It is mandatory that you designate a future primary database. This act conceptually creates the leading and the trailing groups. At this point, the leading group only contains the LGM. You can optionally specify other standbys to protect the LGM.
You use the following procedures during the specification phase:
-
DBMS_ROLLING.INIT_PLAN
-
DBMS_ROLLING.SET_PARAMETER
-
-
Compilation: This is initiated by calling the
DBMS_ROLLING.BUILD_PLAN
procedure. TheBUILD_PLAN
procedure communicates with all databases participating in the rolling upgrade and assembles a rolling upgrade plan. TheBUILD_PLAN
procedure is also called to alter an existing rolling upgrade plan. Alterations are necessary after changes toDBMS_ROLLING
parameters and after changes to the topology as a result of failover. All participating databases must be reachable during execution of theBUILD_PLAN
procedure because numerous validations are required to ensure a successful rolling upgrade. -
Execution: Execution of the rolling upgrade has five stages.
Stage 1: The
DBMS_ROLLING.START_PLAN
procedure starts the execution of the rolling upgrade. This converts the LGM database to a logical standby and starts the SQL Apply process at the LGM.Stage 2: You upgrade the database software at the databases that are part of the leading group. You also run the upgrade scripts at the LGM. After this is done, you must restart SQL Apply processes at the LGM database. (See Oracle Database Upgrade Guide for information about upgrade scripts.) Leading group physical standbys are also addressed during this stage by re-mounting them using the higher version binaries. These databases are upgraded via recovery of the redo from the LGM.
Stage 3: After the apply lag reaches a given threshold (set to 10 minutes by default, but can be configured during the specification stage), the
DBMS_ROLLING.SWITCHOVER
procedure proceeds with the switchover operation. When the switchover is complete, the LGM becomes the primary database.Stage 4: The LGM is now the primary database running the new database software and the databases in the leading group are protecting it. The TGM is mounted and the databases in the trailing group are still running the older version of the database software. You must prepare the TGM and TGS databases for upgrade by upgrading the database software and re-mounting the databases on the higher version binaries. (See Oracle Database Upgrade Guide for information about upgrade scripts.)
Stage 5: Execute the
DBMS_ROLLING.FINISH_PLAN
procedure at the current primary database (originally the LGM). It reinstates all the databases in the trailing group to become the standbys of the current primary database, and restarts the apply processes. TheFINISH_PLAN
procedure waits for all databases in the trailing group to be upgraded to the new release (although the database software for the trailing group databases was changed in Stage 4, the data dictionary of the trailing group databases, except for any logical standbys in the trailing group, are updated based on media recovery of the redo generated during the upgrade at the LGM database).
After the rolling upgrade has been successfully executed, you can remove your rolling upgrade specification by calling the DBMS_ROLLING.DESTROY_PLAN
procedure.
Planning a Rolling Upgrade
Planning your rolling upgrade is essential to a successful upgrade experience. In the planning phase you specify various upgrade parameters and build an upgrade plan.
The parameters and upgrade plan forecast all the operational details unique to your environment. The upgrade plan performs site-specific validations to alert you to configuration and resource problems which could potentially disrupt the rolling upgrade.
The tasks necessary to define upgrade parameters and build an upgrade plan are as follows:
-
Initialize the upgrade parameters
-
View the current upgrade parameter values
-
Modify the upgrade parameter values, as necessary
-
Build the upgrade plan
-
View the current upgrade plan
-
Revise the upgrade plan, as necessary
The rest of this section describes each of these steps in detail. They must be performed in the order presented.
Example 14-1 Setting Switchover to Enforce Apply Lag Requirements
The following example demonstrates how to configure the plan to wait for the apply lag to fall below 60 seconds before switching over to the future primary:
DBMS_ROLLING.SET_PARAMETER('SWITCH_LGM_LAG_WAIT', '1'); DBMS_ROLLING.SET_PARAMETER('SWITCH_LGM_LAG_TIME', '60');
Example 14-2 Resetting Logging Back to Its Default Value
The following example demonstrates resetting the LOG_LEVEL
global parameter back to its default value.
DBMS_ROLLING.SET_PARAMETER ( name=>'LOG_LEVEL', value=>NULL);
Example 14-3 Designating a Database as an Optional Participant
The following example demonstrates setting the INVOLVEMENT
local parameter of database atlanta
to indicate that errors encountered on the database should not impede the overall rolling upgrade.
DBMS_ROLLING.SET_PARAMETER ( scope=>'atlanta', name=>'involvement', value=>'optional');
Example 14-4 Setting a Database to Protect the Transient Logical Standby
The following example demonstrates setting the MEMBER
local parameter of database atlanta
to indicate it should protect the transient logical standby database during the rolling upgrade.
DBMS_ROLLING.SET_PARAMETER ( scope=>'atlanta', name=>'member', value=>'leading');
Example 14-5 Blocking Operations Not Supported by Transient Logical Standbys
The following example demonstrates setting the BLOCK_UNSUPPORTED
parameter of the primary database seattle
to 1. This setting blocks
operations that are not supported by transient logical standbys from being run on the
primary database. Unsupported operations can include DMLs and DDLs to tables contained in
the DBA_ROLLING_UNSUPPORTED
view, DDLs that are not replicated by transient
logical standbys, and invocations to PL/SQL procedures that contain unsupported tables. The
COMPATIBLE
parameter must be set to 21.0 or higher to use this
parameter.
DBMS_ROLLING.SET_PARAMETER (
scope=>'seattle',
name=>'BLOCK_UNSUPPORTED',
value=>'1');
Performing a Rolling Upgrade
Follow these steps to perform a rolling upgrade using the DBMS_ROLLING
PL/SQL package.
Table 14-2 provides a summary of the steps. These steps assume that you have first successfully built an upgrade plan as described in "Planning a Rolling Upgrade".
Table 14-2 Steps to Perform Rolling Upgrade Using DBMS_ROLLING
Step | Description | PHASE |
---|---|---|
Step 1 |
Call the |
START |
Step 2 |
Manually upgrade the Oracle Database software at the future primary database and standbys that protect it. |
SWITCH PENDING |
Step 3 |
Call the |
SWITCH |
Step 4 |
Manually restart the former primary and remaining standby databases on the higher version of Oracle Database. |
FINISH PENDING |
Step 5 |
Call the |
FINISH |
Activities that take place during each step belong to a specific phase of the rolling upgrade as shown in the PHASE column of Table 14-2. A rolling upgrade operation is at a single phase at any given time. The current phase of a rolling upgrade is reported in the PHASE
column of the DBA_ROLLING_STATUS
view.
The rest of this section describes each of the upgrade steps in detail.
-
Call the
DBMS_ROLLING.START_PLAN
procedure to configure the future primary and physical standbys designated to protect the future primary.The
DBMS_ROLLING.START_PLAN
procedure is the formal start of the rolling upgrade. The goal of theSTART_PLAN
procedure is to configure the transient logical standby database and any physical standby databases that have been designated to protect it. When invoked, theSTART_PLAN
procedure executes all instructions in the upgrade plan with aPHASE
value ofSTART_PLAN
. The types of instructions that are performed include:-
Backing up the control file for each database to a trace file
-
Creating flashback database guaranteed restore points
-
Building a LogMiner dictionary at the primary database
-
Recovering the designated physical standby into a transient logical standby database
-
Loading the LogMiner dictionary into the logical standby database
-
Configuring LGS databases with the transient logical standby database
Call the
START_PLAN
procedure as follows (no arguments are required):SQL> EXECUTE DBMS_ROLLING.START_PLAN;
-
-
Manually upgrade the Oracle Database software at the future primary database and standbys that protect it.
After the
START_PLAN
procedure has completed, you must manually upgrade the Oracle Database software at the future primary database and standbys which protect the future primary database. This involves the following steps:-
Upgrade the Oracle Database software of the transient logical (LGM) and leading group standbys (LGS).
-
Start media recovery on the LGS databases.
-
Upgrade the transient logical standby database either manually or using the Database Upgrade Assistant (DBUA).
-
Re-open the transient logical standby in read/write mode.
The transient logical standby and LGS databases are a functional group. The LGS databases must be restarted on the higher version actively running media recovery before the transient logical standby is upgraded. If the LGS databases are not configured first, then the upgrade of the transient logical is not protected. At the conclusion of this step, the upgrade of the transient logical is complete, and media recovery is running on all LGS databases.
It is recommended that you wait until all LGS databases have been fully upgraded before performing the switchover. An LGS database is fully upgraded when its associated record in the
DBA_ROLLING_DATABASES
view reports a value ofYES
in theUPDATED
column. -
-
Call the
DBMS_ROLLING.SWITCHOVER
procedure to switch roles between the current and future primary database.The
SWITCHOVER
procedure switches roles between the current and future primary databases. The procedure times the switchover to occur when apply lag is minimal which minimizes outage time of the primary service. TheSWITCHOVER
procedure executes all instructions in the upgrade plan with aPHASE
value ofSWITCHOVER
. The types of instructions that are performed can include:-
Waiting for the apply lag at the Leading Group Master (LGM), which is currently the transient logical standby, to fall below a threshold value
-
Waiting for the apply lag at LGS databases to fall below a threshold value
-
Switching the primary to the logical standby role
-
Switching the Leading Group Master (LGM), which is currently a logical standby, to the primary role
-
Enabling log archive destinations at the Leading Group Master (LGM) after it has become the new primary
Call the
SWITCHOVER
procedure as follows (no arguments are required):SQL> EXECUTE DBMS_ROLLING.SWITCHOVER;
If a switchover error occurs after the switchover of the primary to the standby role but before the transient logical could be successfully converted into the primary role, then continue to execute the
SWITCHOVER
procedure at the former primary site until successful completion. -
-
At this point, you must manually restart and mount the former primary and remaining standby databases on the higher version of Oracle Database. Mounting the standby databases is especially important because the
DBMS_ROLLING
package needs to communicate with the standby database to continue the rolling upgrade. -
The overall goal of the
FINISH_PLAN
procedure is to configure the former primary and TGP standbys as physical standbys which recover through the upgrade redo. When invoked, theFINISH_PLAN
procedure executes all instructions in the upgrade plan with aPHASE
value ofFINISH
. The types of instructions that are performed include:-
Flashback of the former primary and TGP standbys
-
Conversion of the former primary into a physical standby
-
Startup of media recovery on the new redo branch
Call the
FINISH_PLAN
procedure as follows (no arguments are required):SQL> EXECUTE DBMS_ROLLING.FINISH_PLAN;
-
Monitoring a Rolling Upgrade
There are several views you can query for information about the databases involved in a rolling upgrade.
-
DBA_ROLLING_STATUS
Provides information about the overall status of the upgrade.
-
DBA_ROLLING_DATABASES
Provides information about the role, protection, and recovery state of each database involved in the rolling upgrade.
-
DBA_ROLLING_STATISTICS
Provides statistics such as start and finish times, how long services were offline, and so on.
See Also:
-
Oracle Database Reference for descriptions of these views
Rolling Back a Rolling Upgrade
To roll back a rolling upgrade procedure, you can call the DBMS_ROLLING.ROLLBACK_PLAN
procedure.
The procedure is called as follows:
DBMS_ROLLING.ROLLBACK_PLAN;
The ROLLBACK_PLAN
procedure has the following requirements:
-
The
ROLLBACK_PLAN
procedure can only be called if theDBMS_ROLLING.SWITCHOVER
procedure has not been previously called. -
Before you can use the
ROLLBACK_PLAN
procedure you must set the transient logical standby database back to a mounted state because a flashback database is imminent. -
If the Oracle Database software was already upgraded, then you must restart the resultant physical standbys on the older version, and start media recovery.
Handling Role Changes That Occur During a Rolling Upgrade
If a situation arises in which a rolling upgrade is underway and you need to perform a failover in your Oracle Data Guard configuration before the rollover completes, you can do so only in these circumstances.
-
The failover was not performed while a
DBMS_ROLLING
procedure was in progress. -
The failover was between a primary database and a physical standby database, and was a no-data-loss failover.
-
The failover was between a transient logical standby database and a physical standby of the transient logical standby database.
A role change is a significant event that inevitably invalidates instructions in the upgrade plan, which was tailored for a different configuration. To resume the rolling upgrade, a new plan must be created. You must set the FAILOVER
parameter to indicate that the configuration has changed. This parameter is detected on the next invocation of the BUILD_PLAN
procedure, and the existing plan is amended accordingly.
After the revised plan is built, you can resume the rolling upgrade.
Examples of Rolling Upgrades
These examples show a variety of rolling upgrade scenarios.
At some point in all of the scenarios, the same basic rolling upgrade steps are used. These steps are shown in Example 14-6. The rest of the examples refer back to this example where appropriate rather than reiterating the same steps.
Some of the examples in this section instruct you to resume the rolling upgrade, which means that you should continue where you left off. Resuming a rolling upgrade involves identifying the current phase of the rolling upgrade and reperforming either the PL/SQL procedure associated with the phase or the activities relevant to the phase. The current phase of the rolling upgrade is shown in the PHASE
column of the DBA_ROLLING_STATUS
view.
Note:
The scenarios provided in this section are only meant to be hypothetical examples. You can use the Rolling Upgrade Using Oracle Active Data Guard feature to perform database upgrades beginning with the first Oracle Database 12c patchset.
Example 14-6 Basic Rolling Upgrade Steps
-
Start the rolling upgrade:
SQL> EXECUTE DBMS_ROLLING.START_PLAN;
-
Upgrade the transient logical standby and its protecting standbys.
-
Mount LGP standbys using the higher Oracle Database software version.
-
Start media recovery on Leading Group Physicals (LGP).
-
Open the Leading Group Master (LGM), which is the transient logical standby, in upgrade mode using the higher Oracle Database software version.
-
Upgrade the Leading Group Master (LGM), which is the transient logical standby, either manually or using the Database Upgrade Assistant (DBUA).
-
Restart the Leading Group Master (LGM), which is the transient logical standby, in read/write mode.
-
-
Switchover to the Leading Group Master (LGM):
SQL> EXECUTE DBMS_ROLLING.SWITCHOVER;
-
Restart the databases in the trailing group. This includes the original primary database and all its protecting standbys in the trailing group (TGP).
-
Mount the former primary using the higher Oracle Database version.
-
Mount the physical standbys of the former primary using the higher Oracle Database version.
-
-
Finish the rolling upgrade:
SQL> EXECUTE DBMS_ROLLING.FINISH_PLAN;
Example 14-7 Rolling Upgrade Between Two Databases
The following example demonstrates a rolling upgrade on a two-site configuration consisting of a primary database and a physical standby database. In this example, seattle
is the current primary and boston
is the future primary. The seattle
database is automatically chosen as the Trailing Group Master (TGM) and participates in the operation. By default, there is nothing that needs to be set for seattle
.
-
Initialize the upgrade plan:
SQL> EXECUTE DBMS_ROLLING.INIT_PLAN(future_primary=>'boston');
-
Build the upgrade plan:
SQL> EXECUTE DBMS_ROLLING.BUILD_PLAN;
-
Perform the rolling upgrade as described in Example 14-6.
Example 14-8 Rolling Upgrade Between Three Databases
The following example demonstrates a rolling upgrade on a three-site configuration consisting of a primary databases and two physical standby databases. In this example, seattle
is the primary, boston
is the future primary, and oakland
is a physical standby of seattle
.
-
Initialize the upgrade plan:
SQL> EXECUTE DBMS_ROLLING.INIT_PLAN (future_primary => 'boston');
-
Build the upgrade plan:
SQL> EXECUTE DBMS_ROLLING.BUILD_PLAN;
-
Perform the rolling upgrade as described in Example 14-6.
Example 14-9 Rolling Upgrade Between Four Databases
The following example demonstrates a rolling upgrade on a four-site configuration consisting of a primary database and three physical standby databases. In this example, seattle
is the primary database, boston
is the future primary, oakland
is a physical standby of seattle
, and atlanta
is a physical standby of boston
.
-
Initialize the upgrade plan:
SQL> EXECUTE DBMS_ROLLING.INIT_PLAN (future_primary => 'boston');
-
Configure
atlanta
as a standby in the leading group:SQL> EXECUTE DBMS_ROLLING.SET_PARAMETER(scope=>'atlanta',name=>'member', value=>'leading');
-
Build the upgrade plan:
SQL> EXECUTE DBMS_ROLLING.BUILD_PLAN;
-
Perform the rolling upgrade as described in Example 14-6.
Example 14-10 Rolling Upgrade on a Reader Farm
The following example demonstrates a rolling upgrade on a reader farm configuration consisting of one primary database and nine physical standby databases. In this example, eight physical standby databases are split into two groups of four in order for physical standbys to be available as Oracle Active Data Guard standbys before and after the switchover. In this example, seattle
is the primary, boston
is the future primary, databases rf[a-d]
are physical standbys of seattle
, and databases rf[e-h]
are physical standbys of boston
. The rolling upgrade is configured so that the switchover to the new primary waits until the apply lag among the reader farm group of the future primary database is less than 60 seconds.
-
Initialize the upgrade plan:
SQL> EXECUTE DBMS_ROLLING.INIT_PLAN ( future_primary => 'boston');
-
Configure the reader farm group to protect the future primary:
SQL> EXECUTE DBMS_ROLLING.SET_PARAMETER(scope=>'rfe',name=>'member', value=>'leading');
SQL> EXECUTE DBMS_ROLLING.SET_PARAMETER(scope=>'rff',name=>'member', value=>'leading');
SQL> EXECUTE DBMS_ROLLING.SET_PARAMETER(scope=>'rfg',name=>'member', value=>'leading');
SQL> EXECUTE DBMS_ROLLING.SET_PARAMETER(scope=>'rfh',name=>'member', value=>'leading');
-
Set a maximum permitted apply lag of 60 seconds on the future primary's reader farm:
SQL> EXECUTE DBMS_ROLLING.SET_PARAMETER(name=>'SWITCH_LGS_LAG_WAIT', value=>'1');
-
Build the upgrade plan:
SQL> EXECUTE DBMS_ROLLING.BUILD_PLAN;
-
Perform the rolling upgrade as described in Example 14-6.
Example 14-11 Rolling Upgrade for Application Testing
The following example demonstrates using rolling upgrade on a four-site configuration to configure a transient logical standby and a physical of the transient logical standby in order to validate an application on the higher version database. The primary database is seattle
, boston
is the future primary, oakland
is a physical standby of seattle
, and atlanta
is physical standby of boston
. So in this example, seattle
and oakland
make up the trailing group, and boston
and atlanta
make up the leading group. At the end of testing, boston
and atlanta
are restored back to their original physical standby roles in order to resume protection of seattle
.
-
Initialize the upgrade plan:
SQL> EXECUTE DBMS_ROLLING.INIT_PLAN (future_primary => 'boston');
-
Configure
atlanta
to protect the future primary:SQL> EXECUTE DBMS_ROLLING.SET_PARAMETER(scope=>'atlanta',name=>'member', value=>'leading');
-
Build the upgrade plan:
SQL> EXECUTE DBMS_ROLLING.BUILD_PLAN;
-
Start the rolling upgrade:
SQL> EXECUTE DBMS_ROLLING.START_PLAN;
-
Upgrade
boston
andatlanta
:-
Mount
atlanta
using the higher database version. -
Start media recovery on
atlanta
. -
Open
boston
in upgrade mode using the higher database version. -
Upgrade database
boston
either manually or using the Database Upgrade Assistant (DBUA). -
Restart
boston
in read/write mode.
-
-
Test the application, as necessary.
-
Rollback the configuration:
-
Restart
boston
in mounted mode -
Roll back the upgrade:
SQL> EXECUTE DBMS_ROLLING.ROLLBACK_PLAN;
-
-
Start media recovery on
boston
andatlanta
using the older database version:-
Mount
boston
andatlanta
using the lower database version. -
Start media recovery on
boston
andatlanta
.
-
Example 14-12 Resuming a Rolling Upgrade After a Failover to a New Primary
The following example demonstrates a no-data-loss failover of a physical standby to the primary role followed by the reconfiguration of the rolling upgrade plan on a three-site configuration. In this example, seattle
is the primary, boston
is the future primary, and oakland
is a physical standby of seattle
. Database oakland
is failed over to become the new primary. (The Trailing Group is (seattle
, oakland
) and the Leading Group is boston
.)
-
Recover remaining redo on
oakland
, and fail over to the new primary role:SQL> ALTER DATABASE RECOVER MANAGED STANDBY DATABASE CANCEL; SQL> ALTER DATABASE RECOVER MANAGED STANDBY FINISH; SQL> ALTER DATABASE FAILOVER TO OAKLAND; SQL> ALTER DATABASE OPEN;
-
Configure log archive destinations on
oakland
, as necessary:SQL> ALTER SYSTEM SET LOG_ARCHIVE_DEST_2='service="boston" reopen=5 2 LGWR ASYNC NET_TIMEOUT=180 valid_for=(ONLINE_LOGFILE, PRIMARY_ROLE) 3 DB_UNIQUE_NAME="oakland"';
SQL> ALTER SYSTEM ARCHIVE LOG CURRENT;
-
Set a parameter to indicate that a failover took place:
SQL> EXECUTE DBMS_ROLLING.SET_PARAMETER(name=>'failover', value=>'1');
-
Revise the upgrade plan:
SQL> EXECUTE DBMS_ROLLING.BUILD_PLAN;
-
Resume the rolling upgrade.
Example 14-13 Resuming a Rolling Upgrade After a Failover to a New Transient Logical
The following example demonstrates a failover of a physical standby to the transient logical role, followed by the reconfiguration of the rolling upgrade plan on a five-site configuration. In this example, seattle
is the primary, boston
is the future primary, oakland
is a physical standby of seattle
, and atlanta
and miami
are physical standbys of boston
. Database atlanta
is failed over to become the new transient logical standby.
-
Recover remaining redo on
atlanta
and failover to the new transient logical role:SQL> ALTER DATABASE RECOVER MANAGED STANDBY FINISH; SQL> ALTER DATABASE ACTIVATE STANDBY DATABASE; SQL> ALTER DATABASE OPEN;
-
Configure log archive destinations on
atlanta
, as necessary:SQL> alter system set log_archive_dest_2='service="seattle" reopen=5 2 LGWR ASYNC NET_TIMEOUT=180 valid_for=(ONLINE_LOGFILE, PRIMARY_ROLE) 3 DB_UNIQUE_NAME="atlanta"'; SQL> alter system set log_archive_dest_3='service="oakland" reopen=5 2 LGWR ASYNC NET_TIMEOUT=180 valid_for=(ONLINE_LOGFILE, PRIMARY_ROLE) 3 DB_UNIQUE_NAME="atlanta"'; SQL> alter system set log_archive_dest_4='service="miami" reopen=5 2 LGWR ASYNC NET_TIMEOUT=180 valid_for=(ONLINE_LOGFILE, ALL_ROLES) 3 DB_UNIQUE_NAME="atlanta"';
-
Specify
atlanta
as the new transient logical standby database:SQL> EXECUTE DBMS_ROLLING.SET_PARAMETER(name=>'failover', value=>'1');
-
Revise the upgrade plan:
SQL> EXECUTE DBMS_ROLLING.BUILD_PLAN;
-
Resume the rolling upgrade.