Data Guard 11g
Data Guard 11g
Preface
1-1
<Course title here>
Preface
1-2
<Course title here>
Preface
1-3
<Course title here>
Preface
1-4
<Course title here>
Preface
1-5
<Course title here>
Preface
1-6
Oracle Database 11g: Data Guard Administration   1 - 2
What Is Oracle Data Guard?
Oracle Data Guard is a central component of an integrated Oracle Database High Availability (HA) 
solution set that helps organizations ensure business continuity by minimizing the various kinds of 
planned and unplanned down time that can affect their businesses.
Oracle Data Guard is a management, monitoring, and automation software infrastructure that works 
with a production database and one or more standby databases to protect your data against failures, 
errors, and corruptions that might otherwise destroy your database. It protects critical data by providing 
facilities to automate the creation, management, and monitoring of the databases and other 
components in a Data Guard configuration. It automates the process of maintaining a copy of an Oracle 
production database (called a standby database) that can be used if the production database is taken 
offline for routine maintenance or becomes damaged.
In a Data Guard configuration, a production database is referred to as a primary database. 
A standby database is a synchronized copy of the primary database. Using a backup copy of the 
primary database, you can create from one to 30 standby databases. The standby databases, together 
with the primary database, make up a Data Guard configuration. 
All Data Guard standby databases can enable up-to-date read access to the standby database while 
redo being received from the primary database is applied. This makes all standby databases excellent 
candidates for relieving the primary database of the overhead of supporting read-only queries and 
reporting.
Oracle Database 11g: Data Guard Administration   1 - 3
Types of Standby Databases
Physical Standby Database
A physical standby database is physically identical to the primary database, with on-disk 
database structures that are identical to the primary database on a block-for-block basis. The 
physical standby database is updated by performing recovery using redo data that is received 
from the primary database. Oracle Database 11g enables a physical standby database to 
receive and apply redo while it is open in read-only mode.
Logical Standby Database
A logical standby database contains the same logical information (unless configured to skip 
certain objects) as the production database, although the physical organization and structure 
of the data can be different. The logical standby database is kept synchronized with the 
primary database by transforming the data in the redo received from the primary database 
into SQL statements and then executing the SQL statements on the standby database. This is 
done with the use of LogMiner technology on the redo data received from the primary 
database. The tables in a logical standby database can be used simultaneously for recovery 
and for other tasks such as reporting, summations, and queries.
Note: For more information about LogMiner, see Oracle Database Utilities in the Oracle 
Database 11g documentation.
Oracle Database 11g: Data Guard Administration   1 - 4
Types of Standby Databases (continued)
Snapshot Standby Database
A snapshot standby database is a database that is created by converting a physical standby 
database into a snapshot standby database. The snapshot standby database receives redo 
from the primary database, but does not apply the redo data until it is converted back into a 
physical standby database. The snapshot standby database can be used for updates, but 
those updates are discarded before the snapshot standby database is converted back into a 
physical standby database. The snapshot standby database is appropriate when you require 
a temporary, updatable version of a physical standby database. 
Oracle Database 11g: Data Guard Administration   1 - 5
Types of Data Guard Services
The following types of services are available with Data Guard:
 Redo transport services: Control the automated transmittal of redo information from 
the primary database to one or more standby databases or archival destinations.
 Apply services: Control when and how data is applied to the standby database.
- Redo Apply: Technology used for physical standby databases. Redo data is 
applied on the standby database by using Oracle media recovery.
- SQL Apply: Technology used for logical standby databases. The received redo 
data is first transformed into SQL statements, and then the generated SQL 
statements are executed on the logical standby database.
 Role management services: A database operates in one of two mutually exclusive 
roles: primary or standby. Role management services operate in conjunction with redo 
transport services and apply services to change these roles dynamically as a planned 
transition (called a switchover operation) or as a result of database failure due to a 
failover operation.
Oracle Database 11g: Data Guard Administration   1 - 6
Role Transitions: Switchover and Failover
Data Guard enables you to change the role of a database dynamically by issuing SQL 
statements or by using either of the Data Guard brokers interfaces. Data Guard supports two 
role-transition operations:
 Switchover: The switchover feature enables you to switch the role of the primary 
database to one of the available standby databases. The chosen standby database 
becomes the primary database, and the original primary database then becomes a 
standby database. 
 Failover: You invoke a failover operation when a catastrophic failure occurs on the 
primary database. During a failover operation, the failed primary database is removed 
from the Data Guard environment, and a standby database assumes the primary 
database role. You invoke the failover operation on the standby database that you want 
to fail over to the primary role. You can also enable fast-start failover, which allows Data 
Guard to automatically and quickly fail over to a previously chosen synchronized 
standby database. 
Note: Fast-start failover is discussed in detail in the lesson titled Enabling Fast-Start 
Failover.
Oracle Database 11g: Data Guard Administration   1 - 7
Oracle Data Guard Broker
The Oracle Data Guard broker is a distributed management framework that automates and 
centralizes the creation, maintenance, and monitoring of Data Guard configurations. After 
creating the Data Guard configuration, the broker monitors the activity, health, and availability 
of all systems in the configuration.
Oracle Database 11g: Data Guard Administration   1 - 9
Choosing an Interface for Administering a Data Guard Configuration
You can use Oracle Enterprise Manager Grid Control or the Data Guard brokers own 
specialized command-line interface (DGMGRL) to take advantage of the brokers 
management capabilities.
Enterprise Manager Grid Control provides a Web-based interface that combines with the 
brokers centralized management and monitoring capabilities so that you can easily view, 
monitor, and administer primary and standby databases in a Data Guard configuration.
You can also use DGMGRL to control and monitor a Data Guard configuration. You can 
perform most of the activities that are required to manage and monitor the databases in the 
configuration from the DGMGRL prompt or in scripts.
If you do not create a Data Guard broker configuration, you can manage your standby 
databases by using SQL commands.
Oracle Database 11g: Data Guard Administration   1 - 10
Oracle Data Guard: Architecture (Overview)
Oracle Data Guard leverages the existing database redo-generation architecture to keep the 
standby databases in the configuration synchronized with the primary database. By using the 
existing architecture, Oracle Data Guard minimizes its impact on the primary database.
Oracle Data Guard uses several processes to achieve the automation that is necessary for 
disaster recovery and high availability. Some of these processes existed before the 
introduction of Data Guard; others were created specifically to support Oracle Data Guard. 
These processes are discussed in more detail on the next few pages.
Oracle Database 11g: Data Guard Administration   1 - 11
Primary Database Processes
On the primary database, Data Guard uses the following processes:
 Log writer (LGWR): LGWR collects transaction redo information and updates the online 
redo logs. For each synchronous (SYNC) standby database, LGWR passes the redo to 
an LNS (Log Writer Network Server) process, which ships the redo directly to the remote 
file server (RFS) process on the standby database. LGWR waits for confirmation from 
the LNS process before acknowledging the commit. For asynchronous (ASYNC) 
standby databases, independent LNS processes read the redo from either the redo log 
buffer in memory or the online redo log file, and then ship the redo to its standby 
database. Other than starting the asynchronous LNS processes, LGWR has no 
interaction with any asynchronous standby destination.
 Archiver (ARCn): The ARCn process creates a copy of the online redo log files locally 
for use in a primary database recovery operation. ARCn is also responsible for shipping 
redo data to an RFS process at a standby database and for proactively detecting and 
resolving gaps on all standby databases. For Oracle Database 11g Release 2 (11.2), 
there can now be 30 archiver processes. The default value is four.
Oracle Database 11g: Data Guard Administration   1 - 12
Standby Database Processes
On the standby database, Data Guard uses the following processes:
 Remote file server (RFS): RFS receives redo information from the primary database 
and can write the redo into standby redo logs or directly to archived redo logs. Each 
LNSn and ARCn process from the primary database has its own RFS process. 
Note: The use of standby redo logs is discussed in more detail in the lesson titled 
Creating a Physical Standby Database by Using SQL and RMAN Commands.
 Archiver (ARCn): The ARCn process archives the standby redo logs. 
 Managed recovery (MRP): For physical standby databases only, MRP applies archived 
redo log information to the physical standby database. If you start the managed recovery 
with the ALTER DATABASE RECOVER MANAGED STANDBY DATABASE SQL statement, 
this foreground session performs the recovery. If you use the optional DISCONNECT
[FROM SESSION] clause, the MRP background process starts. If you use the Data 
Guard broker to manage your standby databases, the broker always starts the MRP 
background process for a physical standby database.
 Logical standby (LSP): For logical standby databases only, LSP controls the 
application of archived redo log information to the logical standby database.
Oracle Database 11g: Data Guard Administration   1 - 13
Physical Standby Database: Redo Apply Architecture
The Data Guard physical standby Redo Apply architecture consists of:
 A production (primary) database, which is linked to one or more standby databases (up 
to 30) that are identical copies of the production database. The limit of 30 standby 
databases is imposed by the LOG_ARCHIVE_DEST_n parameter. For Oracle Database 
11g Release 2 (11.2), the maximum number of destinations is 31. One is used as the 
local archive destination, leaving the other 30 for uses such as the standby database. 
Note: You can use the Cascaded Redo Log Destinations feature to incorporate more 
than 30 standby databases in your configuration.
 The standby database, which is updated by redo that is automatically shipped from the 
primary database. The redo can be shipped as it is generated or archived on the primary 
database. Redo is applied to each standby database by using Oracle media recovery. 
During planned down time, you can perform a switchover to a standby database. When 
a failure occurs, you can perform a failover to one of the standby databases. The 
physical standby database can also be used to back up the primary database.
Oracle Database 11g: Data Guard Administration   1 - 14
Logical Standby Database: SQL Apply Architecture
In a logical standby database configuration, Data Guard SQL Apply uses redo information 
shipped from the primary system. However, instead of using media recovery to apply changes 
(as in the physical standby database configuration), the redo data is transformed into 
equivalent SQL statements by using LogMiner technology. These SQL statements are then 
applied to the logical standby database. The logical standby database is open in read/write 
mode and is available for reporting capabilities. By opening the logical standby database in 
read/write mode, additional reporting structures such as indexes or materialized views can be 
created that do not exist in the primary database.
A logical standby database can be used to perform rolling database upgrades, thereby 
minimizing down time when upgrading to new database patch sets or full database releases.
Oracle Database 11g: Data Guard Administration   1 - 15
Automatic Gap Detection and Resolution
If connectivity is lost between the primary database and one or more standby databases, redo 
data that is being generated on the primary database cannot be sent to those standby 
databases. When a connection is reestablished, Data Guard automatically detects that there 
are missing archived redo log files (referred to as a gap), and then automatically transmits the 
missing archived redo log files to the standby databases by using the ARCn processes. The 
standby databases are synchronized with the primary database without manual intervention 
by the DBA.
Oracle Database 11g: Data Guard Administration   1 - 16
Data Protection Modes
Data Guard provides three high-level modes of data protection that you can configure to 
balance cost, availability, performance, and transaction protection. You can configure the 
Data Guard environment to maximize data protection, availability, or performance.
Maximum Protection
This protection mode guarantees that no data loss occurs if the primary database fails. For 
this level of protection, the redo data that is needed to recover each transaction must be 
written to both the local online redo log and the standby redo log (used to store redo data 
received from another database) on at least one standby database before the transaction 
commits. To ensure that data loss does not occur, the primary database shuts down if a fault 
prevents it from writing its redo stream to at least one remote standby redo log.
Oracle Database 11g: Data Guard Administration   1 - 17
Hardware and Operating System Requirements
These are the requirements for Data Guard:
 The hardware for the primary and standby database systems can be different. For 
example, the number of CPUs, the memory size, and the storage configuration can 
differ.
 The operating systems for both databases and operating system binaries can be 
different such as Linux and Windows.
If the primary and standby databases are both on the same server, you must ensure that the 
operating system enables you to mount two databases with the same name on the same 
system simultaneously. Certain parameters must be specified to support this configuration, as 
discussed in the lesson titled Creating a Physical Standby Database by Using SQL.
Refer to My Oracle Support notes 413484.1, 395982.1, and 414043.1 for additional 
information.
Oracle Database 11g: Data Guard Administration   1 - 19
Data Guard Operational Requirements: Oracle Database Software
 You must install the same release of Oracle Database Enterprise Edition for the primary 
database and all standby databases in your Data Guard configuration. Oracle Data 
Guard is available only as a feature of Oracle Database Enterprise Edition; it is not 
available with Oracle Database Standard Edition. 
Note: See the course titled Oracle Data Guard Concepts and Administration for 
information about simulating a standby database environment when using Oracle 
Database Standard Edition.
 If you use Oracle Automatic Storage Management (ASM) and Oracle Managed Files 
(OMF) in a Data Guard configuration, you should use ASM and OMF symmetrically on 
the primary and standby database. If any database in your Data Guard configuration 
uses ASM, OMF, or both, then every database in the configuration should use the same 
combination (that is, ASM, OMF, or both).
Note: An exception to this guideline is if you are using Data Guard as a technique to 
migrate to ASM and/or OMF.
Oracle Database 11g: Data Guard Administration   1 - 20
Benefits of Implementing Oracle Data Guard
 Continuous service: With the use of switchover and failover between systems, your 
business does not need to halt because of a disaster at one location.
 Complete data protection: Data Guard guarantees that there is no data loss and 
provides a safeguard against data corruption and user errors. Redo data is validated 
when applied to the standby database. 
 Elimination of idle standby systems: Standby databases can be used for reporting 
and 
ad hoc queries in addition to providing a safeguard for disaster recovery. You can also 
use the physical standby database to off-load backups of the primary database.
 Flexible configurations: You can use Data Guard to configure the system to your 
needs by using the protection modes and several tunable parameters.
 Centralized management: You can use Enterprise Manager Grid Control to manage all 
configurations in your enterprise.
Oracle Database 11g: Data Guard Administration   1 - 21
Answer: a, c, d
Oracle Database 11g: Data Guard Administration   1 - 22
Answer: c
Oracle Database 11g: Data Guard Administration   1 - 23
Oracle Database 11g: Data Guard Administration   1 - 24
Oracle Database 11g: Data Guard Administration   2 - 2
Steps to Create a Physical Standby Database
You perform the steps listed in the slide to use SQL and RMAN commands to create a 
physical standby database. Detailed information about each step is provided in the remaining 
slides of the lesson.
Note: See Oracle Data Guard Concepts and Administration for detailed information about 
creating a physical standby database by using only SQL commands. 
Oracle Database 11g: Data Guard Administration   2 - 3
Preparing the Primary Database
The FORCE LOGGING mode determines whether the Oracle database server logs all changes in the 
database (except for changes to temporary tablespaces and temporary segments). 
Note: Additional information about enabling FORCE LOGGING follows in this lesson.
Unless you have configured Oracle Advanced Security and public key infrastructure (PKI) certificates, 
every database in a Data Guard configuration must use a password file, and the password for the SYS
user must be identical on every system for redo data transmission to succeed. For details about 
creating a password file, see the Oracle Database Administrators Guide.
A standby redo log is used to store redo received from another Oracle database.
Note: Additional information about creating standby redo log files is provided in this lesson.
On the primary database, you define initialization parameters that control redo transport services while 
the database is in the primary role. There are other parameters that you need to add that control the 
receipt of the redo data and log apply services when the primary database is transitioned to the standby 
role. Additional information about setting initialization parameters is provided in this lesson. 
Note: The Data Guard broker requires the use of a server parameter file.
If archiving is not enabled, issue the ALTER DATABASE ARCHIVELOG command to put the primary 
database in ARCHIVELOG mode and enable automatic archiving. See the Oracle Database 
Administrators Guide for additional information about archiving.
Oracle Database 11g: Data Guard Administration   2 - 4
FORCE LOGGING Mode
FORCE LOGGING mode determines whether the Oracle database server logs all changes in 
the database (except for changes to temporary tablespaces and temporary segments). The 
[NO]FORCE LOGGING clause of the ALTER DATABASE command contains the following 
settings:
   FORCE LOGGING: This setting takes precedence over (and is independent of) any 
NOLOGGING or FORCE LOGGING settings that you specify for individual tablespaces and 
any NOLOGGING setting that you specify for individual database objects. All ongoing, 
unlogged operations must finish before forced logging can begin.
   NOFORCE LOGGING: Places the database in NOFORCE LOGGING mode. This is the 
default.
The FORCE_LOGGING column in V$DATABASE contains a value of YES if the database is in 
FORCE LOGGING mode.
Oracle Database 11g: Data Guard Administration   2 - 5
Configuring Standby Redo Logs
A standby redo log is used only when the database is in the standby role to store redo data 
received from the primary database. Standby redo logs form a separate pool of log file 
groups.
Configuring standby redo log files is highly recommended for all databases in a Data Guard 
configuration to aid in role reversal.
A standby redo log is required to implement:
 Synchronous transport mode
 Real-time apply 
 Cascaded redo log destinations
Note: By configuring the standby redo log on the primary database, the standby redo log is 
created automatically on the standby database when you execute the DUPLICATE TARGET
DATABASE FOR STANDBY FROM ACTIVE DATABASE RMAN command.
Oracle Database 11g: Data Guard Administration   2 - 7
Creating Standby Redo Logs
You must create at least one more standby redo log group than you have online redo log 
groups as the primary database. In addition, each standby redo log file must be at least as 
large as the largest redo log file in the redo log of the redo source database. 
The RFS process writes to an archive redo log file if any of the following conditions are met:
 There are no standby redo logs.
 It cannot find a standby redo log that is the same size as or larger than the incoming 
online redo log file.
 All standby redo logs of the correct size have not yet been archived.
Oracle Database 11g: Data Guard Administration   2 - 8
Using SQL to Create Standby Redo Logs
You can create standby redo logs by using the ADD STANDBY LOGFILE clause of the ALTER
DATABASE statement. Although standby redo logs are used only when the database is 
operating in the standby role, you should create standby redo logs on the primary database 
so that switching roles does not require additional DBA intervention.
You should create standby redo log files on the primary database prior to using the 
DUPLICATE TARGET DATABASE FOR STANDBY FROM ACTIVE DATABASE RMAN command 
so that RMAN creates standby redo log files automatically on the standby database. 
Create standby redo log file groups by using the following guidelines:
 Each standby redo log file must be at least as large as the largest redo log file in the 
redo source database. For administrative ease, Oracle recommends that all redo log 
files in the redo source database and the redo transport destination be of the same size.
 The standby redo log must have at least one more redo log group than the redo log on 
the redo source database.
Oracle Database 11g: Data Guard Administration   2 - 9
Viewing Standby Redo Log Information
To verify that standby redo logs were created, query V$STANDBY_LOG or V$LOGFILE. An 
example output using Automatic Storage Management (ASM) is shown below:
SQL> SELECT group#, type, member FROM v$logfile WHERE type = 
'STANDBY;
GROUP# TYPE    MEMBER
---------- ------- ------------------------------------------------
4 STANDBY +SBDAT/pc01sby1/onlinelog/group_4.266.711624939
5 STANDBY +SBDAT/pc01sby1/onlinelog/group_5.267.711624945
6 STANDBY +SBDAT/pc01sby1/onlinelog/group_6.268.711624951
7 STANDBY +SBDAT/pc01sby1/onlinelog/group_7.269.711624957
4 STANDBY +SBFRA/pc01sby1/onlinelog/group_4.259.711624941
5 STANDBY +SBFRA/pc01sby1/onlinelog/group_5.260.711624947
6 STANDBY +SBFRA/pc01sby1/onlinelog/group_6.261.711624955
7 STANDBY +SBFRA/pc01sby1/onlinelog/group_7.262.711624963
8 rows selected.
Oracle Database 11g: Data Guard Administration   2 - 10
Setting Initialization Parameters on the Primary Database
On the primary database, you define initialization parameters that control redo transport 
services while the database is in the primary role. These parameters are described in more 
detail in the following slides.
Oracle Database 11g: Data Guard Administration   2 - 11
Setting LOG_ARCHIVE_CONFIG
Specify the DG_CONFIG attribute of the LOG_ARCHIVE_CONFIG parameter to list the 
DB_UNIQUE_NAME of the primary and standby databases in the Data Guard configuration. By 
default, the LOG_ARCHIVE_CONFIG parameter enables the database to send and receive 
redo. The LOG_ARCHIVE_CONFIG parameter can be used to disable the sending of redo logs 
to remote destinations or disable the receipt of remote redo logs. The complete syntax for the 
LOG_ARCHIVE_CONFIG parameter is as follows:
LOG_ARCHIVE_CONFIG = { 
[ SEND | NOSEND ][ RECEIVE | NORECEIVE ]
[ DG_CONFIG=(remote_db_unique_name1 
[, ... remote_db_unique_name9) | NODG_CONFIG ] }
Use the V$DATAGUARD_CONFIG view to see the unique database names defined with the 
DB_UNIQUE_NAME and LOG_ARCHIVE_CONFIG initialization parameters; you can thus view 
the Data Guard environment from any database in the configuration. The first row of the view 
lists the unique database name of the current database that was specified with the 
DB_UNIQUE_NAME initialization parameter. Additional rows reflect the unique database 
names of the other databases in the configuration that were specified with the DG_CONFIG
keyword of the LOG_ARCHIVE_CONFIG initialization parameter.
Oracle Database 11g: Data Guard Administration   2 - 12
Setting LOG_ARCHIVE_DEST_n
By using the various LOG_ARCHIVE_DEST_n attributes, you define most of the settings for 
the Data Guard configuration. The Redo Transport Service is directly controlled by these 
settings. There are a number of different attributes that can be set for each 
LOG_ARCHIVE_DEST_n parameter. Most have defaults that are adequate for most 
configurations. See Oracle Data Guard Concepts and Administration for a complete list and a 
description of each. 
You should specify a LOG_ARCHIVE_DEST_n parameter (where n is an integer from 1 to 31) 
for the local archiving destination and one for the standby location. In previous versions of the 
Oracle Database, LOG_ARCHIVE_DEST_10 was set to USE_DB_RECOVERY_FILE_DEST
when the fast recovery area was being used. For Oracle Database 11g Release 2, this will 
now have to be manually set. Query the V$ARCHIVE_DEST view to see current settings of the 
LOG_ARCHIVE_DEST_n initialization parameter.
All defined LOG_ARCHIVE_DEST_n parameters must contain, at a minimum, either a 
LOCATION attribute or a SERVICE attribute. 
In addition, you must have a LOG_ARCHIVE_DEST_STATE_n parameter for each defined 
destination. LOG_ARCHIVE_DEST_STATE_n defaults to ENABLE.
Oracle Database 11g: Data Guard Administration   2 - 14
Specifying Role-Based Destinations
The VALID_FOR attribute of the LOG_ARCHIVE_DEST_n initialization parameter enables you 
to identify exactly when the archive destination is to be used, as well as which type of log file it 
is used for. The attribute uses a keyword pair to identify the redo log type as well as the 
database role. Using this attribute enables you to set up parameters in anticipation of 
switchover and failover operations.
In the example in the slide, there is a destination on the standby database and the primary 
database defined with the VALID_FOR setting shown. This destination is to be used on the 
standby database only after a switchover, when the standby becomes a primary. The 
destination on the old primary is ignored when it becomes a standby.
You supply two values for the VALID_FOR attribute: redo_log_type and database_role.
The redo_log_type keywords are:
   ONLINE_LOGFILE: This destination is used only when archiving online redo log files.
   STANDBY_LOGFILE: This destination is used only when archiving standby redo log files 
or receiving archive logs from another database. 
   ALL_LOGFILES: This destination is used when archiving either online or standby redo 
log files.
Oracle Database 11g: Data Guard Administration   2 - 15
Combinations for VALID_FOR
In the table in the slide, Valid indicates that the archive log destination is used in a database 
that is in the role defined by the column heading. Ignored means that the archive log 
destination is not appropriate and that a destination of this type is ignored. An ignored 
destination does not generate an error.
There is only one invalid combination: STANDBY_LOGFILE, PRIMARY_ROLE. Specifying this 
combination causes an error for all database roles. If it is set, you receive the following error 
at startup: 
ORA-16026: The parameter LOG_ARCHIVE_DEST_n contains an 
invalid attribute value 
Note: Both single and plural forms of the keywords are valid. For example, you can specify 
either PRIMARY_ROLE or PRIMARY_ROLES, as well as ONLINE_LOGFILE or 
ONLINE_LOGFILES.
Oracle Database 11g: Data Guard Administration   2 - 17
Defining the Redo Transport Mode
The following attributes of the LOG_ARCHIVE_DEST_n initialization parameter define the redo 
transport mode that is used by the primary database to send redo to the standby database.
   SYNC: Specifies that redo data generated by a transaction must have been received at a 
destination that has this attribute before the transaction can commit; otherwise, the 
destination is deemed to have failed. In a configuration with multiple SYNC destinations, 
the redo must be processed as described here for every SYNC destination.
   ASYNC (default): Specifies that redo data generated by a transaction need not have 
been received at a destination that has this attribute before the transaction can commit
   AFFIRM: Specifies that a redo transport destination acknowledges received redo data 
after writing it to the standby redo log
   NOAFFIRM: Specifies that a redo transport destination acknowledges received redo data 
before writing it to the standby redo log
If neither the AFFIRM nor the NOAFFIRM attribute is specified, the default is AFFIRM when the 
SYNC attribute is specified and NOAFFIRM when the ASYNC attribute is specified.
Note: Specifying the AFFIRM attribute with the SYNC attribute is deprecated and will not be 
supported in future releases.
Oracle Database 11g: Data Guard Administration   2 - 18
Setting Initialization Parameters on the Primary Database 
The parameters listed in the slide are required if the disk configuration is not the same for the 
primary and standby databases. The parameters are also applicable when the primary 
database is transitioned to a standby database.
Oracle Database 11g: Data Guard Administration   2 - 19
Specifying Values for DB_FILE_NAME_CONVERT
When files are added to the standby database, the DB_FILE_NAME_CONVERT parameter is 
used to convert the data file name on the primary database to a data file name on the standby 
database. The file must exist and be writable on the physical standby database; if it is not, the 
recovery process halts with an error.
You specify the path name and file name location of the primary database data files followed 
by the standby location by setting the value of this parameter to two strings. The first string is 
the pattern found in the data file names on the primary database. The second string is the 
pattern found in the data file names on the physical standby database. You can use as many 
pairs of primary and standby replacement strings as required. You can use single or double 
quotation marks. Parentheses are optional. 
In the example in the slide, /oracle1/dba/ and /oracle2/dba/ are used to match file 
names coming from the primary database. /ora1/stby_dba/ and /ora2/stby_dba/ are 
the corresponding strings for the physical standby database. A file on the primary database 
named /oracle1/dba/system01.dbf is converted to 
/ora1/stby_dba/system01.dbf on the standby database.
Multiple pairs can be specified such as ('a','b','1','2').
Note: If the standby database uses Oracle Managed Files (OMF), do not set the 
DB_FILE_NAME_CONVERT parameter. There is a 255-character limit on this parameter.
Oracle Database 11g: Data Guard Administration   2 - 20
Specifying Values for LOG_FILE_NAME_CONVERT
The LOG_FILE_NAME_CONVERT parameter is used to convert the name of a redo log file on 
the primary database to the name of a redo log file on the standby database. Adding a redo 
log file to the primary database requires adding a corresponding file to the standby database. 
When the standby database is updated, this parameter is used to convert the log file name 
from the primary database to the log file name on the standby database. This parameter is 
required if the standby database is on the same system as the primary database or on a 
separate system that uses different path names.
Specify the location of the primary database online redo log files followed by the standby 
location. The use of parentheses is optional.
Both DB_FILE_NAME_CONVERT and LOG_FILE_NAME_CONVERT parameters perform simple 
string substitutions. For example, ('a','b') will transform the following:
/disk1/primary/mya/a.dbf into 
/disk1/primbry/myb/b.dbf
Multiple pairs can be specified such as ('a','b','1','2').
Note: If the standby database uses OMF, do not set the LOG_FILE_NAME_CONVERT
parameter. There is a 255-character limit on this parameter.
Oracle Database 11g: Data Guard Administration   2 - 21
Specifying a Value for STANDBY_FILE_MANAGEMENT
When STANDBY_FILE_MANAGEMENT is set to AUTO, you cannot execute the following 
commands on the standby database:
   ALTER DATABASE RENAME
   ALTER DATABASE ADD/DROP LOGFILE [MEMBER]
   ALTER DATABASE ADD/DROP STANDBY LOGFILE MEMBER
   ALTER DATABASE CREATE DATAFILE AS ...
When you add a log file to the primary database and want to add it to the physical standby 
database as well (or when you drop a log file from the primary and want to drop it from the 
physical), you must do the following:
1.  Set STANDBY_FILE_MANAGEMENT to MANUAL on the physical standby database.
2.  Add the redo log files to (or drop them from) the primary database.
3.  Add them to (or drop them from) the standby database.
4.  Reset to AUTO afterward on the standby database.
Oracle Database 11g: Data Guard Administration   2 - 22
Setting Initialization Parameters on the Primary Database
In the example in the slide, assume that the primary database is named pc01prmy and the 
standby is named pc01sby1. For each, there is an Oracle Net Services name defined. 
There are additional parameters you need to add that control the receipt of the redo data and 
log apply services when the primary database is transitioned to the standby role:
DB_FILE_NAME_CONVERT='/u01/app/oracle/oradata/pc01sby1/',
'/u01/app/oracle/oradata/pc01prmy/'
LOG_FILE_NAME_CONVERT='/u01/app/oracle/oradata/pc01sby1/',
'/u01/app/oracle/oradata/pc01prmy/'
STANDBY_FILE_MANAGEMENT=AUTO
Specifying these initialization parameters configures the primary database to resolve gaps, 
converts new data file and log file path names from a new primary database, and archives the 
incoming redo data when this database is in the standby role.
Note: The convert parameters can also be used to change ASM disk groups, for example:
DB_FILE_NAME_CONVERT=('+DATA','+SBDAT')
Oracle Database 11g: Data Guard Administration   2 - 23
Creating an Oracle Net Service Name for Your Physical Standby Database
Use Oracle Net Manager to define a network service name for your physical standby 
database. 
The slide shows the entry in the tnsnames.ora file that was generated by Oracle Net 
Manager.
Note: This entry is used to connect to the standby database when invoking RMAN and 
executing the DUPLICATE TARGET DATABASE FOR STANDBY FROM ACTIVE DATABASE
command. It is also used in the LOG_ARCHIVE_DEST_2 parameter for the SERVICE value to 
define the redo transport to the standby database.
Oracle Database 11g: Data Guard Administration   2 - 24
Creating an Entry for Your Standby Database for the Listener
Use Oracle Net Manager to configure a new listener (if necessary) or to update the 
listener.ora file with an entry for your physical standby database. The slide shows the 
entry in the listener.ora file that was generated by Oracle Net Manager.
Note: This entry is needed because you start the instance in NOMOUNT mode. The labs for 
this course use ASM, which runs from the /u01/app/oracle/product/11.2.0/grid  
software home location. This location is different from the database software home location 
defined as /u01/app/oracle/product/11.2.0/dbhome_1.  Both software home 
locations contain network configuration files. The ASM software home runs the listener on 
port 1521 by the default installation. A second listener on port 12001 is created using the 
network configuration files found in the database software home location.
Oracle Database 11g: Data Guard Administration   2 - 25
Copying Your Primary Database Password File to the Physical Standby Database 
Host
You must create a password file for your physical standby database by copying the primary 
database password file to the physical standby database host and renaming it.
Oracle Database 11g: Data Guard Administration   2 - 26
Creating an Initialization Parameter File for the Physical Standby Database
Create a text initialization parameter file containing only the DB_NAME initialization parameter. 
This initialization parameter file is used to start the physical standby database in NOMOUNT
mode prior to the execution of the DUPLICATE TARGET DATABASE FOR STANDBY FROM
ACTIVE DATABASE RMAN command. When you execute this command, RMAN creates a 
server parameter file for the standby database.
Oracle Database 11g: Data Guard Administration   2 - 27
Creating Directories for the Physical Standby Database
Create a directory for the physical standby database in the $ORACLE_BASE/admin directory. 
Create the audit trail directory named adump under the database directory in 
$ORACLE_BASE/admin.
Create a directory for the physical standby database data files in the 
$ORACLE_BASE/oradata directory.
Oracle Database 11g: Data Guard Administration   2 - 28
Starting the Physical Standby Database
Set the ORACLE_SID environment variable to your physical standby database. Start the 
physical standby database in NOMOUNT mode by using the text initialization parameter file. 
With ASM installed, there will be multiple software home locations on each machine. This will 
require that the ORACLE_HOME and PATH location change accordingly. Oracle recommends 
the oraenv utility to change environment variables provided entries exist in the 
/etc/oratab file. The oraenv utility will adjust ORACLE_SID, ORACLE_BASE, 
ORACLE_HOME, PATH and LD_LIBRARY_PATH environment variables. For example:
[oracle@EDBVR6P2-+ASM ~]$ . oraenv
ORACLE_SID = [+ASM] ? pc01sby1
The Oracle base for 
ORACLE_HOME=/u01/app/oracle/product/11.2.0/grid is 
/u01/app/oracle
Note: Since the initialization parameter file contains an entry only for DB_NAME, memory sizes 
for the System Global Area will use default values. Later the DUPLICATE TARGET DATABASE
FOR STANDBY FROM ACTIVE DATABASE RMAN command will copy the initialization 
parameter values for memory sizing from the primary database configuration.
Oracle Database 11g: Data Guard Administration   2 - 29
Setting FAL_CLIENT and FAL_SERVER Initialization Parameters
On physical standby databases, fetch archive log (FAL) provides a client/server mechanism 
for resolving gaps detected in the range of archived redo logs that are generated at the 
primary database and received at the standby database. The FAL process is started only 
when needed, and shuts down as soon as it is finished. It is very likely you will not see this 
process running.
The FAL_CLIENT initialization parameter specifies the FAL client name (Oracle Net service 
name) that is used by the FAL service, configured through the FAL_SERVER parameter, to 
refer to the FAL client. This parameter is no longer required for Oracle Database 11g Release 
2 (11.2). If it is not set, the fetch archive log (FAL) server will obtain the clients network 
address from the LOG_ARCHIVE_DEST_n parameter that corresponds to the clients 
DB_UNIQUE_NAME.
The FAL_SERVER initialization parameter specifies the FAL server (Oracle Net service name) 
for a standby database.
Oracle Database 11g: Data Guard Administration   2 - 30
Creating an RMAN Script to Create the Physical Standby Database
Create an RMAN script containing the DUPLICATE TARGET DATABASE FOR STANDBY FROM
ACTIVE DATABASE command.
Note: You can use the CONFIGURE  PARALLELISM integer command to configure 
automatic channels for the specified device type. For additional information, see the Oracle 
Database Backup and Recovery Reference.
Oracle Database 11g: Data Guard Administration   2 - 31
Creating an RMAN Script to Create the Physical Standby Database (continued)
In the RMAN script, specify the settings for the physical standby initialization parameters.
Oracle Database 11g: Data Guard Administration   2 - 32
Creating the Physical Standby Database
Connect to the primary database instance (target) and physical standby database instance 
(auxiliary). Execute the script that you created.
Oracle Database 11g: Data Guard Administration   2 - 33
Enabling Real-Time Apply
When you enable the optional real-time apply feature, log apply services apply the redo data 
from standby redo log files in real time (at the same time the log files are being written to) as 
opposed to recovering redo from archived redo log files when a log switch occurs. If for some 
reason the apply service is unable to keep up (for example, if you have a physical standby in 
read-only mode for a period of time), then the apply service automatically goes to the archived 
redo log files as needed. The apply service also tries to catch up and go back to reading the 
standby redo log files as soon as possible.
Real-time application of redo information provides a number of benefits, including faster 
switchover and failover operations, up-to-date results after you change a physical standby 
database to read-only, up-to-date reporting from a logical standby database, and the ability to 
leverage larger log files on the primary database resulting in larger standby redo logs on the 
standby database.
Having larger log files with real-time apply is desirable because the apply service stays with a 
log longer and the overhead of switching has less impact on the real-time apply processing.
The RECOVERY_MODE column of the V$ARCHIVE_DEST_STATUS view contains the value 
MANAGED REAL TIME APPLY when log apply services are running in real-time apply mode.
Oracle Database 11g: Data Guard Administration   2 - 34
Starting Redo Apply
On the standby database, issue the ALTER DATABASE RECOVER MANAGED STANDBY
DATABASE USING CURRENT LOGFILE SQL command to start Redo Apply. This statement 
automatically mounts the database. In addition, include the DISCONNECT FROM SESSION
option so that Redo Apply runs in a background session.
The transmission of redo data to the remote standby location does not occur until after a log 
switch. Issue the following command on the primary database to force a log switch:
SQL> ALTER SYSTEM SWITCH LOGFILE;
Oracle Database 11g: Data Guard Administration   2 - 36
Special Note: Standby Database on the Same System
If you have a standby database on the same system as the primary database, you must use the 
following guidelines:
 The data files must be renamed. The actual file names can be the same, but at least the directory 
path must be different. This means that you must use the DB_FILE_NAME_CONVERT and 
LOG_FILE_NAME_CONVERT parameters. 
Note: If the standby database uses Oracle Managed Files (OMF), do not set the 
DB_FILE_NAME_CONVERT or LOG_FILE_NAME_CONVERT parameters.
 If a standby database is located on the same system as the primary database, the archival 
directories for the standby database must use a different directory structure than the primary 
database. Otherwise, the standby database may overwrite the primary database files.
 If you do not explicitly specify unique service names and if the primary and standby databases 
are located on the same system, the same default global name (consisting of the database name 
and domain name from the DB_NAME and DB_DOMAIN parameters) will be in effect for both the 
databases.
 If the standby database is on the same system as the primary database, it does not protect 
against disaster. A disaster is defined as total loss of the primary database system. If the standby 
database is on the same system, it will be lost as well. This configuration should be used only for 
testing and training purposes.
Oracle Database 11g: Data Guard Administration   2 - 37
Preventing Primary Database Data Corruption from Affecting the Standby 
Database
Data Guard uses Oracle processes to validate redo data before it is applied to the standby 
database.
Corruption-detection checks occur at the following key interfaces:
 On the primary database during redo transport by the LGWR, LNS, and ARCn
processes
 On the standby database during redo apply by the RFS, ARCn, MRP, and DBWn
processes
If redo corruption is detected by Redo Apply at the standby database, Data Guard will re-fetch 
valid logs as part of archive log gap handling.
A lost write occurs when an I/O subsystem acknowledges the completion of a write but the 
write did not occur in persistent storage. On a subsequent block read, the I/O subsystem 
returns the stale version of the data block, which is used to update other blocks of the 
database, thereby corrupting the database.
Set the DB_LOST_WRITE_PROTECT initialization parameter on the primary and standby 
databases to enable the database server to record buffer cache block reads in the redo log so 
that lost writes can be detected. 
Oracle Database 11g: Data Guard Administration   2 - 38
Answer: b
Oracle Database 11g: Data Guard Administration   2 - 40
Answer: b
Oracle Database 11g: Data Guard Administration   2 - 41
Oracle Database 11g: Data Guard Administration   2 - 42
Oracle Database 11g: Data Guard Administration   2 - 43
Oracle Database 11g: Data Guard Administration   3 - 2
Oracle Data Guard Broker: Features
The following are some of the operations that the broker automates and simplifies:
 Automated creation of Data Guard configurations incorporating a primary database, a 
new or existing standby database, redo transport services, and log apply services
Note: Any of the databases in the configuration can be a Real Application Clusters 
(RAC) database.
 Adding new or existing standby databases to each existing Data Guard configuration, 
for a total of one primary database and from one to 30 standby databases in the same 
configuration
 Managing an entire Data Guard configuration (including all databases, redo transport 
services, and log apply services) through a client connection to any database in the 
configuration
 Invoking switchover or failover with a single command to initiate and control complex 
role changes across all databases in the configuration
 Monitoring the status of the entire configuration, capturing diagnostic information, 
reporting statistics (such as the log apply rate and the redo generation rate), and 
detecting problems quickly with centralized monitoring, testing, and performance tools
Oracle Database 11g: Data Guard Administration   3 - 3
Data Guard Broker: Components
The Oracle Data Guard broker consists of both client-side and server-side components.
On the client, you can use the following Data Guard components to define and manage a 
configuration:
 Oracle Enterprise Manager
 DGMGRL, which is the Data Guard command-line interface (CLI)
On the server, the Data Guard monitor is a broker component that is integrated with the 
Oracle database. The Data Guard monitor comprises the Data Guard monitor (DMON) process 
and broker configuration files, with which you can control the databases of that configuration, 
modify their behavior at run time, monitor the overall health of the configuration, and provide 
notification of other operational characteristics.
The configuration file contains profiles that describe the current state and properties of each 
database in the configuration. Associated with each database are various properties that the 
DMON process uses to control the databases behavior. The properties are recorded in the 
configuration file as a part of the databases object profile that is stored there. Many database 
properties are used to control database initialization parameters related to the Data Guard 
environment.
Oracle Database 11g: Data Guard Administration   3 - 4
Data Guard Broker: Configurations
A Data Guard configuration consists of one primary database and up to 30 standby 
databases. The databases in a Data Guard configuration are typically dispersed 
geographically and are connected by Oracle Net.
A Data Guard broker configuration is a logical grouping of the primary and standby databases 
in a Data Guard configuration. The brokers DMON process configures and maintains the 
broker configuration components as a unified group of resource objects that you can manage 
and monitor as a single unit.
Oracle Database 11g: Data Guard Administration   3 - 5
Data Guard Broker: Management Model
The Data Guard broker performs operations on the following logical objects:
 Configuration of databases
 Single database
A broker configuration consists of:
 Configuration object
A named collection of database profiles. A database profile is a description of a 
database object, including its current state, current status, and properties. 
 Database objects
Objects corresponding to primary or standby databases 
 Instance objects
A database object may comprise one or more instance objects if it is a RAC database.
The broker supports one or more Data Guard configurations, each of which includes a profile 
for one primary database as well as profiles for up to 30 physical, logical, RAC or non-RAC 
standby databases.
Oracle Database 11g: Data Guard Administration   3 - 6
Data Guard Broker: Architecture
The Data Guard broker helps you create, control, and monitor a Data Guard configuration. 
This configuration consists of a primary database that is protected by one or more standby 
databases. After the broker has created the Data Guard configuration, the broker monitors the 
activity, health, and availability of all systems in that configuration.
The Data Guard monitor process (DMON) is an Oracle background process that runs on every 
instance that is managed by the broker. When you start the Data Guard broker, a DMON
process is created.
When you use Enterprise Manager or the Data Guard command-line interface (CLI), the DMON
process is the server-side component that interacts with the local instance and the DMON
processes that are running on other sites to perform the requested function. The DMON
process is also responsible for monitoring the health of the broker configuration and for 
ensuring that every instance has a consistent copy of the configuration files in which the DMON
process stores its configuration data. There are two multiplexed versions of the configuration 
file on each instance.
Oracle Database 11g: Data Guard Administration   3 - 7
Data Guard Monitor: DMON Process
The Data Guard monitor comprises two components: the DMON process and the configuration 
file.
The DMON process is an Oracle background process that is part of each database instance 
managed by the broker. When you start the Data Guard broker, a portion of the SGA is 
allocated and a DMON process is created. The amount of memory allocated is typically less 
than 50 KB per site; the actual amount on your system varies.
When you use Enterprise Manager or the CLI, the DMON process is the server-side 
component that interacts with the local instance and the DMON processes running on other 
sites to perform the requested function.
The DMON process is also responsible for monitoring the health of the broker configuration 
and for ensuring that every database has a consistent copy of the broker configuration files in 
which the DMON process stores its configuration data.
The DIAGNOSTIC_DEST parameter defines the location for diagnostic files such as trace files 
and core files. The structure of the directory specified by DIAGNOSTIC_DEST is as follows:
<diagnostic_dest>/diag/rdbms/<dbname>/<instance_name>/
This location is known as the Automatic Diagnostic Repository (ADR) Home. The DMON 
trace files are located in the <adr-home>/trace subdirectory.
Oracle Database 11g: Data Guard Administration   3 - 8
Benefits of Using the Data Guard Broker
By automating the tasks required to configure and monitor a Data Guard configuration, the 
broker enhances the high-availability, data protection, and disaster protection capabilities that 
are inherent in Oracle Data Guard. If the primary database fails, the broker streamlines the 
process for any one of the standby databases to replace the primary database and take over 
production processing.
The broker enables easy configuration of additional standby databases. After creating a Data 
Guard configuration consisting of two databasesa primary and standbyyou can add up to 
29 additional standby databases to the existing two for each Data Guard configuration.
Oracle Database 11g: Data Guard Administration   3 - 9
Comparing Configuration Management With and Without the Data Guard Broker
The table in the slide provides an overview of configuration management with and without the 
Data Guard broker (source: Table 1-1, Configuration Management With and Without the 
Broker, in Oracle Data Guard Broker).
Oracle Database 11g: Data Guard Administration   3 - 10
Data Guard Broker Interfaces
The DGMGRL command-line interface includes:
 Configuration and setup tasks
 Management and control of the configuration
 Commands to check the status and health of the configuration
 Commands to execute role changes
Oracle Enterprise Manager Grid Control includes the following Data Guard features:
 Wizard-driven creation of standby databases
 Wizard-driven creation of a broker configuration based on an existing databases
 Complete monitoring and proactive event reporting through email or pagers
 Simplified control of the databases through their potential states. For example, with 
Enterprise Manager you can start or stop the redo transport services, start or stop the 
log apply services, and place a standby database in read-only mode.
 Pushbutton switchover and failover. Grid Control enables you to execute a switchover 
or failover between a primary and a standby database by simply clicking a button.
Note: After defining a Data Guard broker configuration, you should use DGMGRL or 
Enterprise Manager Grid Control to manage your configuration. You should not use SQL 
commands to manage the databases because you could cause a conflict with the broker.
Oracle Database 11g: Data Guard Administration   3 - 11
DGMGRL Commands
The following commands are available in DGMGRL (the Data Guard CLI). Many of these 
commands have additional arguments that are not described here. See Oracle Data Guard 
Broker for detailed information.
   ADD: Adds a standby database to the broker configuration
   CONNECT: Connects a given username to the specified instance
   CREATE: Enables you to create broker configurations
   DISABLE: Enables you to disable broker control of a configuration or database so that 
the object is no longer managed by the broker
   EDIT: Used to edit a configuration, database, or instance
   ENABLE: Enables you to enable broker control of a configuration or database
   EXIT/QUIT: Exits DGMGRL
   FAILOVER: Performs a database failover operation in which one of the standby 
databases changes to the role of primary database (This is an unplanned transition that 
may result in the loss of application data.)
Oracle Database 11g: Data Guard Administration   3 - 12
Using Oracle Enterprise Manager 10g Grid Control
To access the Data Guard features in Grid Control:
1. Click the Targets tab to go to the Targets page.
2. Click Databases to go to the Databases page, where you can see a list of all discovered 
databases, including the primary database.
3. Click the primary database to go to the primary database home page.
4. Click Availability.
5. Click Setup and Manage in the Data Guard section of the Availability page to open the 
Data Guard Overview page.
Oracle Database 11g: Data Guard Administration   3 - 14
Data Guard Overview Page
On the Data Guard Overview page, you can:
 View the protection mode and access the page to edit the protection mode
 View a summary showing the amount of data that the standby database has not 
received
 View information about the primary database
 View or access pages to change information for the standby databases:
- Add a standby database to the broker configuration
- Change the state or properties
- Discontinue Data Guard broker control
- Switch the role from standby to primary
- Transition the standby database to the role of the primary database
 Access pages to view performance information for the configuration and status of online 
redo log files for each standby database
 Perform a verification process on the Data Guard configuration
Note: You access the Data Guard Overview page by clicking Setup and Manage in the Data 
Guard section of the database Availability page.
Oracle Database 11g: Data Guard Administration   3 - 15
Benefits of Using Enterprise Manager
Managing your Data Guard configuration with Oracle Enterprise Manager Grid Control 
provides the following benefits:
 Enables you to manage your configuration using the familiar Enterprise Manager 
interface and event-management system
 Provides a wizard that automates the complex tasks involved in creating a broker 
configuration
 Provides the Add Standby Database Wizard to guide you through the process of adding 
more databases 
 Performs all Oracle Net Services configuration changes that are necessary to support 
redo transport services and log apply services across the configuration
 Provides a verify operation to ensure that redo transport services and log apply services 
are configured and functioning properly
 Enables you to select a new primary database from a set of viable standby databases 
when you need to initiate a role change for a switchover or failover operation
Oracle Database 11g: Data Guard Administration   3 - 16
Answer: a, c
Oracle Database 11g: Data Guard Administration   3 - 17
Answer: b
Oracle Database 11g: Data Guard Administration   3 - 18
Oracle Database 11g: Data Guard Administration   3 - 19
Oracle Database 11g: Data Guard Administration   4 - 2
Data Guard Broker: Requirements
To use the Data Guard broker, you must comply with the following requirements:
 Use the Enterprise Edition of Oracle Database.
 Use a single-instance or multi-instance environment.
 Set the COMPATIBLE initialization parameter to 11.2.0 to take advantage of new 
Oracle Database 11g Release 2 (11.2) features.
 Enterprise Manager automatically configures the Oracle Net network files when it 
creates a standby database. If you configure an existing standby database in the broker 
configuration, you must configure the network files. You must use TCP/IP. 
 To enable the Data Guard broker to restart instances during the course of broker 
operations, a service with a specific name must be statically registered with the local 
listener of each instance. The value of the GLOBAL_DBNAME attribute must be set to a 
concatenation of db_unique_name_DGMGRL.db_domain.
Oracle Database 11g: Data Guard Administration   4 - 3
Data Guard Broker: Requirements (continued)
 Set the DG_BROKER_START initialization parameter to TRUE. This starts the DMON
process. 
Note: When you use Enterprise Manager to create your configuration, this parameter is 
automatically set to TRUE.
 The primary database must be in ARCHIVELOG mode.
 Any database that is managed by the broker (including, for a RAC database, all 
instances of the database) must be mounted or open. The broker cannot start an 
instance.
 If any database in your configuration is a RAC database, you must configure the 
DG_BROKER_CONFIG_FILEn initialization parameters for that database so that they 
point to the same shared files for all instances of that database. You cannot use the 
default values for these parameters. 
Note: The shared files could be files on a cluster file system or on raw devices, or the 
files could be stored using Automatic Storage Management (ASM). For details, see the 
section titled Managing Broker Configuration Files in an Oracle RAC Environment in 
Oracle Data Guard Broker.
Oracle Database 11g: Data Guard Administration   4 - 4
Data Guard Broker and the SPFILE
To ensure that the broker can update the values of parameters in both the database instance 
and the configuration file, you must use the persistent server parameter file (SPFILE) to 
control static and dynamic initialization parameters. Use of the SPFILE gives the broker a 
mechanism that enables it to reconcile property values that you have selected when using the 
broker with any related initialization parameter values that are recorded in the SPFILE. In 
addition, the SPFILE permits persistent Data Guard settings so that Data Guard continues to 
work even after the broker is disabled.
When you set definitions or values for database properties in the broker configuration, the 
broker records the changes in the configuration file and also propagates the changes to the 
related initialization parameters in the server parameter file in the Data Guard configuration.
When the configuration is enabled, the broker keeps the database property values in the Data 
Guard configuration file consistent with the values of the database initialization parameters in 
the SPFILE.
Even when the configuration is disabled, you can update database property values through 
the broker. The broker retains the property settings (without validating the values) and 
updates the database initialization parameters in the SPFILE and the in-memory settings the 
next time you enable the broker configuration.
Oracle Database 11g: Data Guard Administration   4 - 5
Data Guard Monitor: Configuration File
The DMON process maintains persistent configuration data about all the databases in the broker 
configuration in a broker configuration file. Every database that is part of the Data Guard broker 
configuration has two broker configuration files that are maintained and synchronized for each database 
in the broker configuration. One of the files is in use and the other acts as a backup. The configuration 
files are binary files and cannot be edited.
When the broker is started for the first time, the configuration files are created and named automatically 
by using a default name. You can override this default name by setting the 
DG_BROKER_CONFIG_FILEn initialization parameters. You can also change the configuration file 
names dynamically by issuing the ALTER SYSTEM SQL statement. You must disable the broker 
configuration and stop the DMON process before changing the names.
The configuration files contain entries that describe the state and properties of the databases in the 
configuration. For example, the files record the databases that are part of the configuration, the roles 
and properties of each of the databases, and the state of each of the databases in the configuration. 
Two files are maintained so that there is always a record of the last-known valid state of the 
configuration. The broker uses the data in the configuration file to configure and start the databases, 
control each databases behavior, and provide information to DGMGRL and Enterprise Manager.
Note: For Oracle Database 11g Release 2, the broker config files can reside on disks having any sector 
size up to 4KB.
Oracle Database 11g: Data Guard Administration   4 - 7
Data Guard Broker Log Files
The DMON process records operational and status information in the broker log file for each 
instance in the Data Guard broker configuration.
Oracle Database 11g: Data Guard Administration   4 - 8
Creating a Broker Configuration
To create a broker configuration by using DGMGRL, you first define the configuration, and 
then add each database to the configuration and enable the configuration. Each step is 
discussed in detail in the following slides.
Note: The databases must exist before you add them to the configuration 9
Oracle Database 11g: Data Guard Administration   4 - 9
Defining the Broker Configuration and the Primary Database Profile
Execute the CREATE CONFIGURATION command to define the broker creation and create a 
profile for the primary database. The following parameters must be specified:
   configuration-name: User-specified name for the configuration.
   database-name: Used by the broker to reference the primary database. You must use 
the value of the DB_UNIQUE_NAME initialization parameter for the database name. 
   connect-identifier: The value you specify for the connect identifier is a fully 
specified connect descriptor or a name to be resolved by an Oracle Net Services 
naming method. The broker uses this value to communicate with the other databases 
defined in the configuration. The DGConnectIdentifier database property is set to 
the connect identifier value.
Oracle Database 11g: Data Guard Administration   4 - 10
Adding a Standby Database to the Configuration
Use the ADD DATABASE DGMGRL command to define the standby database and create a 
broker configuration profile. The database name specified must be the same as the value of 
the DB_UNIQUE_NAME initialization parameter. The connect identifier is used by Oracle Net 
Services to access the database from all other databases in the configuration.
The AS CONNECT IDENTIFIER clause is optional. If you do not specify this clause, the 
broker will search the LOG_ARCHIVE_DEST_n initialization parameters on the primary 
database for an entry that corresponds to the database being added.
The broker uses the specified connect-identifier to communicate with the specified 
database from other databases. Therefore, you must ensure that the connect-identifier
can be used to address the specified database from all databases in your configuration. For 
example, if TNS is used as the naming method, you must ensure that the tnsnames.ora file 
on every database and instance that is part of the configuration contains an entry for the 
connect identifier. The connect identifier must resolve to the same connect descriptor.
Note: The broker will determine the standby type whenever you add an existing standby. In 
Oracle database version 10.2, you had to specify "MAINTAINED AS [ PHYSICAL | 
LOGICAL ]" when you added an existing standby.
Oracle Database 11g: Data Guard Administration   4 - 11
Enabling the Configuration
After defining the databases in the configuration, you enable the configuration and its 
databases by executing the ENABLE CONFIGURATION DGMGRL command.
Oracle Database 11g: Data Guard Administration   4 - 12
Changing Database Properties and States
Configurable database properties can be viewed and dynamically updated by using the EDIT
DATABASE SET PROPERTY DGMGRL command. Use the SHOW DATABASE VERBOSE
command to obtain a complete list of database properties.
The EDIT DATABASE SET STATE DGMGRL command is used to change the state of the 
primary database and standby databases. When the broker configuration is enabled, the 
databases are in one of four states:
   TRANSPORT-ON (applicable only to the primary database): Redo transport services 
transmit redo data to the standby databases when the primary database is open in 
read/write mode.
   TRANSPORT-OFF (applicable only to the primary database): Redo transport services are 
stopped on the primary database.
   APPLY-ON (applicable only to a physical or logical standby database): Redo Apply is 
started on the physical standby database when it is mounted or in open read-only mode. 
SQL Apply is started on a logical standby database when it is opened and the logical 
standby database guard is on.
   APPLY-OFF (applicable only to a physical or logical standby database): Redo Apply is 
stopped on a physical standby database. SQL Apply is not running on a logical standby 
database.
Oracle Database 11g: Data Guard Administration   4 - 13
Managing Redo Transport Services by Using DGMGRL
Use the DGConnectIdentifier, LogXptMode, and LogShipping configurable database 
properties to manage redo transport services. Details about each database property are 
provided in the next few slides.
Note: See Oracle Data Guard Broker for information about additional properties that are used 
to manage redo transport services.
Oracle Database 11g: Data Guard Administration   4 - 14
Specifying the Connection Identifier by Using the DGConnectIdentifier
Property
The DGConnectIdentifier property is set when a database is added to the broker 
configuration. Its initial value is the connect identifier that is specified in the CONNECT
IDENTIFIER IS clause of the ADD DATABASE command. If the optional CONNECT
IDENTIFIER IS clause is not specified, the initial value of the DGConnectIdentifier
property is obtained from the SERVICE attribute of the LOG_ARCHIVE_DEST_n initialization 
parameter for the database specified in the ADD DATABASE command. If the 
DGConnectIdentifier property is changed, the SERVICE attribute of the 
LOG_ARCHIVE_DEST_n initialization parameter for that database is also changed. 
The DGConnectIdentifier property value is also used to set the FAL_SERVER and 
FAL_CLIENT initialization parameters. If the DGConnectIdentifier property is changed, 
the FAL_SERVER and FAL_CLIENT initialization parameters are also updated.
Oracle Database 11g: Data Guard Administration   4 - 15
Managing the Redo Transport Service by Using the LogXptMode Property
Use the Data Guard broker LogXptMode property to set redo transport services.
   ASYNC: Configures redo transport services by setting the ASYNC and NOAFFIRM
attributes of the LOG_ARCHIVE_DEST_n initialization parameter.
   SYNC: Configures redo transport services by setting the SYNC and AFFIRM attributes of 
the LOG_ARCHIVE_DEST_n initialization parameter.
Definitions of LOG_ARCHIVE_DEST_n Attributes
   ASYNC: Redo data that is generated by a transaction need not have been received at a 
destination that has this attribute before the transaction can commit.
   SYNC: Redo data that is generated by a transaction must have been received by every 
enabled destination that has this attribute before the transaction can commit.
   AFFIRM and NOAFFIRM: Control whether redo transport services use synchronous or 
asynchronous disk I/O to write redo data to the archived redo log files
-   AFFIRM: Specifies that a redo transport destination acknowledges received redo 
data after writing it to the standby redo log
-   NOAFFIRM: Specifies that a redo transport destination acknowledges received 
redo data before writing it to the standby redo log 
Oracle Database 11g: Data Guard Administration   4 - 16
Setting LogXptMode to ASYNC
When you set the LogXptMode property to ASYNC, the broker configures redo transport 
services for this standby database by using the ASYNC and NOAFFIRM attributes of the 
LOG_ARCHIVE_DEST_n initialization parameter. ASYNC mode enables a moderate level of 
data protection for the primary database with a lower performance impact than SYNC mode.
Standby redo log files are required for ASYNC mode.
In the diagram in the slide, the solid line represents a synchronous operation (writing locally to 
the primary database online redo log files). The broken lines represent asynchronous 
operations with respect to the transaction commit on the primary database.
Oracle Database 11g: Data Guard Administration   4 - 17
Setting LogXptMode to SYNC
When you set the LogXptMode database property to SYNC, the broker configures redo 
transport services for this standby database by using the SYNC and AFFIRM attributes of the 
LOG_ARCHIVE_DEST_n initialization parameter. SYNC mode is required for maximum 
protection and maximum availability data protection modes. This mode enables the highest 
level of data protection to the primary database but also incurs the highest performance 
overhead.
Standby redo log files are required for SYNC mode.
In the diagram in the slide, the solid line represents a synchronous operation (writing locally to 
the primary database online redo log files). The broken lines represent asynchronous 
operations with respect to the transaction commit on the primary database.
Oracle Database 11g: Data Guard Administration   4 - 18
Controlling the Shipping of Redo Data by Using the LogShipping Property
Use the LogShipping configurable database property to specify whether redo transport 
services can send redo data to a particular standby database. The value specified for the 
LogShipping property is applicable only when the primary database is in the TRANSPORT-
ON state. If the value of the LogShipping property is ON, redo transport services are enabled 
for that standby database. If the LogShipping property is set to OFF, redo transport services 
are disabled for that standby database.
Oracle Database 11g: Data Guard Administration   4 - 19
Disabling Broker Management of the Configuration or Standby Database
You can disable broker management of a configuration or a specific standby database. You 
may want to disable broker management to perform maintenance or to temporarily prevent 
automated actions for testing.
Disabling broker management does not affect the underlying Data Guard configuration. 
Rather, it removes the ability for you to manage the configuration by using DGMGRL or 
Enterprise Manager Grid Control.
Use the DISABLE CONFIGURATION DGMGRL command to disable broker management of 
the configuration. Use the DISABLE DATABASE DGMGRL command to disable broker 
management of the named standby database.
Note: You must use the DISABLE CONFIGURATION command to disable broker 
management of a primary database.
Oracle Database 11g: Data Guard Administration   4 - 20
Removing the Configuration or Standby Database
Use the REMOVE DATABASE command to delete the named standby database from the broker 
configuration.
Use the REMOVE CONFIGURATION command to delete the configuration. When you execute 
the REMOVE CONFIGURATION command, the broker configuration is removed, all database 
profiles are removed, the Data Guard broker configuration files is removed, and broker 
management of all databases in the configuration is terminated. Execution of this command 
does not affect the underlying databases. You cannot remove the configuration when fast-
start failover is enabled.
The PRESERVE DESTINATIONS syntax is available for both the REMOVE DATABASE and 
REMOVE CONFIGURATIONS commands. By default, broker settings for 
LOG_ARCHIVE_DEST_n and LOG_ARCHIVE_CONFIG initialization parameters are removed 
when the REMOVE commands are issued, but PRESERVE DESTINATIONS maintains these 
initialization parameters.  A common usage for this is to allow the Data Guard broker to 
perform all of the setup for the LOG_ARCHIVE_DEST_n initialization parameters and then 
remove the broker when it has finished.
Oracle Database 11g: Data Guard Administration   4 - 21
Answer: b
Oracle Database 11g: Data Guard Administration   4 - 22
Answer: d
Oracle Database 11g: Data Guard Administration   4 - 23
Oracle Database 11g: Data Guard Administration   4 - 24
Oracle Database 11g: Data Guard Administration   4 - 25
Oracle Database 11g: Data Guard Administration   5 - 2
Using Enterprise Manager to Create a Broker Configuration
Oracle Enterprise Manager (Enterprise Manager) automates the process of creating a 
standby database. The Add Standby Database Wizard is used to create a new broker 
configuration (including standby databases) and to add databases to an existing 
configuration. 
Before you invoke the Add Standby Database Wizard, verify that the primary database 
instance was started with a server parameter file (SPFILE). If the instance was not started 
with an SPFILE, the wizard notifies you.
Oracle Database 11g: Data Guard Administration   5 - 3
Creating a Configuration
You can access the Data Guard features in Enterprise Manager Grid Control by clicking 
Setup and Manage in the Data Guard section on the Availability page.
Click the Add Standby Database link to invoke the Add Standby Database Wizard.
Oracle Database 11g: Data Guard Administration   5 - 4
Creating a New Configuration
Using the Add Standby Database Wizard, perform the following steps:
1. Specify the backup type to use for the standby database creation.
2. Specify the backup options.
3. Select the Oracle home in which to create the standby database.
4. Specify the location for standby database files.
5. Specify standby database configuration parameters.
6. Review the configuration information.
During the standby creation process, the following operations are performed (for online 
backup types):
 RMAN automatically copies the server parameter file to the standby host
 The auxiliary instance is started with the parameter file
 A backup control file is restored
 All necessary database files and archive redo logs are copied over the network to the 
standby host
 RMAN recovers the standby database, but does not place it in manual or managed 
recovery mode
Oracle Database 11g: Data Guard Administration   5 - 5
Adding a Standby Database to an Existing Configuration
Click the Add Standby Database button to invoke the Add Standby Database Wizard.
Oracle Database 11g: Data Guard Administration   5 - 6
Using the Add Standby Database Wizard
With the Add Standby Database Wizard, you first select the type of standby database that you 
want to create. You can create a physical or logical standby database, or you can add an 
existing database, including a RAC database, to the configuration to serve as a standby 
database.
Note: You must be connected to the primary database with SYSDBA credentials to invoke the 
Add Standby Database Wizard.
If you choose to create a new standby database, the following conditions are verified when 
you click Continue:
 All databases in the configuration are using an SPFILE.
 The primary database is in ARCHIVELOG mode.
If any of these conditions are not met, the wizard returns a message indicating that you must 
cancel the wizard and perform the appropriate action to meet the condition.
In addition, the wizard verifies that the primary database is in FORCE LOGGING mode. If it is 
not, a warning message appears. You can then cancel the configuration and enable FORCE
LOGGING.
The following slides describe the wizard steps in detail.
Oracle Database 11g: Data Guard Administration   5 - 7
Step 1: Specify the Backup Type
You can use the Backup Type page of the wizard to select the type of backup for the creation 
of the standby database. There are two options:
 Perform an online backup of the primary database: Creates a backup using the 
Recovery Manager utility (RMAN)
 Use a backup from a previous standby database creation: Uses an existing backup 
of the primary database that was created by Data Guard during a previous creation of a 
standby database
Oracle Database 11g: Data Guard Administration   5 - 8
Step 2: Specify the Backup Options (RMAN Direct Copy)
If you selected the Perform a live backup of the primary database option on the Backup 
Type page with the option to Use Recovery Manager (RMAN) to copy database files,  then 
staging areas are not required. RMAN will copy files directly to destination locations.  
In the Primary Host Credentials section, specify the operating system credentials of the user 
who owns the primary database Oracle server installation. The credentials are preset to the 
host-preferred credentials that are stored with the primary database-preferred credentials by 
default.
Oracle Database 11g: Data Guard Administration   5 - 9
Step 2: Specify the Backup Options (Staging Areas Example)
If you selected the Perform an online backup of the primary database option on the Backup 
Type page with the option to Copy database files via staging areas, you can specify a location 
on the primary database host to store the backup files. A default location is specified in the 
Backup Files Directory Location field, or you can provide your own location. A unique 
subdirectory to store the backup files is created in the specified directory.
If you intend to create additional standby databases, you can save the backup by selecting 
the Retain directory for a future standby database creation option. Otherwise, you should 
select the Delete directory after standby database creation option. If you choose to retain the 
backup, additional space is required (as indicated on the Backup Options page).
If you selected the Use a backup from a previous standby database creation option on the 
Backup Type page, specify the location of the backup in the Backup Files Directory Location 
field. This backup must have been taken by Data Guard during creation of a previous standby 
database and must be of the same type that you are creating.
In the Primary Host Credentials section, specify the operating-system credentials of the user 
who owns the primary database Oracle server installation. The credentials are preset to the 
host-preferred credentials that are stored with the primary database-preferred credentials by 
default.
Oracle Database 11g: Data Guard Administration   5 - 10
Step 3: Select the Standby Database Location Instance Name
In the Instance Name field, specify the instance name for your new standby database, or use 
the default instance name that is provided. The instance name must conform to Oracle 
naming guidelines.
Note: For a physical standby, the database name is the same as the primary because a 
physical standby is an exact, block-by-block copy of the primary. You can make the instance 
name the same as the primary. However, you must make the instance name different from the 
primary if the standby is on the same machine as the primary.
In the Standby Database Location section, specify the host machine name and Oracle Home 
location for the database software. There may be more than one Oracle Home on the same 
machine.
In the Standby Host Credentials section, specify the operating system credentials of the user 
who owns the Oracle installation in the selected Oracle Home on the standby host.
Oracle Database 11g: Data Guard Administration   5 - 11
Step 3: Select the Standby Database Location Oracle Home
The Standby Database Location section lists all available Oracle Homes that match the 
primary database version and host operating system. From this list, select the host and 
Oracle Home for your new standby database.
Note: The standby database home location should not be a Grid Infrastructure home.
Oracle Database 11g: Data Guard Administration   5 - 12
Step 4: Specify the Standby Database File Locations (Staging Method)
The Standby Host Backup File Access section appears only when you are creating a standby 
database on a host other than the primary database. You must select a method to be used to 
make the primary backup files accessible to the standby host. This is screenshot is valid when 
staging areas have been selected as the backup method.
 Transfer files: If you choose to transfer files from the primary host working directory to a 
standby host directory, you must specify a temporary location on the standby host to 
store the backup files copied from the primary host. In addition, you must select the file-
transfer method: FTP or HTTP server. FTP is the faster of the two methods. Select the 
HTTP server option if you know that the primary or standby host does not support FTP.
 Directly access the files: If you select this method, you must supply the network path 
name for the standby host. This method is appropriate when the primary host working 
directory location is directly accessible from the standby host via NFS, a network share, 
or some other network method. This option saves time and disk space because there is 
no file transfer to the standby host and because no temporary location is needed.
Oracle Database 11g: Data Guard Administration   5 - 13
Step 4: Specify the Standby Database File Locations
By default, all standby database files are placed in an Oracle Optimal Flexible Architecture 
(OFA) directory structure when your primary and standby databases are on the same host.
When your primary and standby databases are on different hosts, you can specify that you 
want to convert the standby files to an OFA structure or keep the file names and locations the 
same as the primary database. As an option, you can change the locations of individual 
standby database files by clicking the Customize button to display the File Locations 
Customize page of the wizard.
The Flash Recovery Area (now known as Fast Recovery Area) allows you to enable the 
feature, define a location for the Fast Recovery Area, and set the Fast Recovery Area size. 
Data Guard automatically adds configuration information for the new standby database to the 
listener.ora and tnsnames.ora files in the directory that is specified in the 
Configuration File Location field in the Network Configuration File Location section. The 
default location is the network administration directory for the standby databases Oracle 
home. The default location is correct for most configurations. You can specify a different 
directory if you want the new standby database to be serviced by a listener that is running in a 
different Oracle home on the standby host.
Oracle Database 11g: Data Guard Administration   5 - 14
Step 5: Specify Standby Database Configuration Parameters
On the Standby Configuration page, you can specify configuration parameters for the standby 
database. The parameters that must be specified depend on whether you are adding an 
existing standby database, creating a physical standby database, or creating a logical 
standby database. The configuration parameters include the instance name, service provider 
name, target name, and standby archive location. The default values are based on 
corresponding primary database settings.
When you create a physical database, you must configure the following parameters:
 Database Unique Name: Specify a value for the database DB_UNIQUE_NAME
parameter. This name must be unique in the Data Guard configuration. 
Note: This field appears only if you are creating a physical standby database. 
 Target Name: Specify a name for Enterprise Manager to use for the new standby 
database. This name will appear in the list of database targets maintained by Enterprise 
Manager. This name should be the same as the database unique name.
In the Standby Database Monitoring Credentials, you can choose between a non-SYSDBA 
user such as DBSNMP to monitor the database or choose to use the SYSDBA monitoring 
credentials.
Oracle Database 11g: Data Guard Administration   5 - 15
Step 6: Review the Configuration Information
The Review page displays a summary of your selections and lists the parameters to be used 
to create the standby database.
The standby database is created in the background by an Oracle Enterprise Manager job. 
The name of the job that is submitted is provided at the top of the page.
When you click Finish, the Processing page appears. This page tracks each step through the 
submission of the standby creation job. After the job submission is complete, you see the 
Data Guard Overview page, where you can monitor the progress of the standby creation job.
Oracle Database 11g: Data Guard Administration   5 - 16
Standby Database Creation: Processing
On the Processing page, you can view the progress of the Add Standby Database process. 
On completion of the process, Oracle Enterprise Manager displays the Data Guard Overview 
page.
The display on the Processing page differs based on whether you are adding an existing 
standby database or creating a standby database. An arrow indicates which step is being 
processed. When the process is completed, a check icon appears next to the step. 
The following steps appear on the Processing page:
 Creating Data Guard Configuration or Updating Data Guard Configuration: The 
Data Guard configuration (if it does not exist) is created during this step. If you are 
adding an existing standby database, it is added to the configuration.
 Preparing standby creation job: This step appears only if you are creating a standby 
database. The standby database is actually created by an Enterprise Manager job; 
preliminary setup steps to prepare for job submission are accomplished in this step. You 
can cancel the Add Standby Database process at any point up to the completion of this 
step.
Oracle Database 11g: Data Guard Administration   5 - 17
Standby Database Creation: Progress
After the job is submitted, you return to the Data Guard Overview page. The Data Guard 
Status column indicates that standby database creation is in progress. Click the Creation in 
progress link to access the job page and monitor the progress.
After creation of the standby database, it appears on the Data Guard Overview page with a 
status of Normal.
Oracle Database 11g: Data Guard Administration   5 - 19
Verifying a Data Guard Configuration
After creating your configuration, you should use the Data Guard Verify operation to check the 
configuration. (You can use the Verify operation at any other time to check your 
configuration.) Invoke the Verify operation by clicking Verify Configuration in the Additional 
Administration section of the Data Guard page. The Verify operation performs a series of 
validation checks on the Data Guard configuration, including a health check of each database 
and agent. The Verify operation:
 Determines the current data protection mode settings, including the current redo 
transport mode settings for each database and whether the standby redo logs are 
configured properly. If standby redo logs are needed for a database, a message 
indicates this on the Detailed Results page. You can then add the standby redo logs.
 Validates each database for the current status. 
 Performs a log switch on the primary database (for non-RAC databases) and verifies 
that the log was applied on each standby database.
 Checks the agent status for each database. The verify process executes a SQL*Plus job 
on the agent if credentials are available. If credentials are not available to run the job, 
the agent is pinged instead. If errors occur, a message appears on the Results page.
 Displays the results of the Verify operation (including errors). 
Note: You can cancel the Verify operation at any time by clicking Cancel.
Oracle Database 11g: Data Guard Administration   5 - 20
Reviewing Results of the Verify Operation
View the results of the Verify operation on the Detailed Results page. If errors occur during 
the operation, detailed information appears on this page.
Oracle Database 11g: Data Guard Administration   5 - 21
Performing Routine Maintenance
You can use Enterprise Manager Grid Control to maintain your broker configuration. Each 
task is described in detail in the next few slides.
Oracle Database 11g: Data Guard Administration   5 - 22
Editing Standby Database Properties
To access the Standby Database Properties page, select your standby database on the Data 
Guard overview page and click Edit.
Oracle Database 11g: Data Guard Administration   5 - 23
Managing Apply Services
You may need to temporarily stop Redo Apply for routine maintenance tasks. You can stop 
apply services by selecting Log Apply Off on the Edit Standby Database Properties page and 
then clicking Apply.
When you specify Log Apply Off, Redo Apply is stopped and redo data is not applied to the 
standby database. However, the standby database continues to receive data from the primary 
database.
Oracle Database 11g: Data Guard Administration   5 - 24
Changing the Basic Properties of a Database
To use Enterprise Manager to view or change properties:
1. In the Primary Database section on the Data Guard Overview page (or in the Standby 
Databases section, as appropriate), click Edit.
2. Click the Standby Role Properties tab or the Common Properties tab (depending on the 
property that you want to change).
3. Make the appropriate change and click Apply.
When the process is completed, a message indicates success.
Oracle Database 11g: Data Guard Administration   5 - 25
Changing the Advanced Properties of a Database
To use Enterprise Manager to view or change properties:
1.  In the Primary Database section on the Data Guard Overview page (or in the Standby 
Databases section, as appropriate), click Edit.
2.  Click the Standby Role Properties tab or the Common Properties tab (depending on the 
property that you want to change).
3.   Expand the Show Advanced Properties link. The advanced properties will be different 
depending on the type of standby database.
4.  Make the appropriate change and click Apply.
When the process is completed, a message indicates success.
Oracle Database 11g: Data Guard Administration   5 - 26
Setting the Redo Transport Mode by Using Enterprise Manager
On the Standby Role Properties page, select the redo transport mode from the following 
values in the Log Transport Mode list: 
   ASYNC: Configures redo transport services for your standby database by using the 
LGWR, ASYNC, and NOAFFIRM attributes of the LOG_ARCHIVE_DEST_n initialization 
parameter. This mode, along with standby redo log files, provides a moderate level of 
protection to the primary database and incurs a moderate performance impact.
   SYNC: Configures redo transport services for your standby database by using the LGWR, 
SYNC, and AFFIRM attributes of the LOG_ARCHIVE_DEST_n initialization parameter. 
This mode, along with standby redo log files, is required for the maximum-protection or 
maximum-availability protection modes. This redo transport mode provides the highest 
level of data protection to the primary database, but it also incurs the highest 
performance impact.
Oracle Database 11g: Data Guard Administration   5 - 27
Answer: b
Oracle Database 11g: Data Guard Administration   5 - 28
Answer: b
Oracle Database 11g: Data Guard Administration   5 - 29
Oracle Database 11g: Data Guard Administration   5 - 30
Oracle Database 11g: Data Guard Administration   6 - 2
Benefits of Implementing a Logical Standby Database
A logical standby database provides benefits in disaster recovery, high availability, and data 
protection that are similar to those of a physical standby database. It also provides the 
following specialized benefits:
 Efficient utilization of system resources: A logical standby database is an open, 
independent, and active production database. It can include data that is not part of the 
primary database, and users can perform data manipulation operations on tables in 
schemas that are not updated from the primary database. It remains open while the 
tables are updated from the primary database, and those tables are simultaneously 
available for read access. Because the data can be presented with a different physical 
layout, additional indexes and materialized views can be created to improve your 
reporting and query requirements and to suit your specific business requirements.
Note: Oracle Database 11g includes the Active Data Guard option. Active Data Guard 
includes the Real-Time Query feature, which enables you to open a physical standby 
database in read-only mode while Redo Apply is active. However, you cannot add 
additional structures to the physical standby database as you can with a logical standby 
database. 
 Reduction in primary database workload: The logical standby tables that are updated 
from the primary database can be used for other tasks (such as reporting, summations, 
and queries), thereby reducing the primary database workload.
Oracle Database 11g: Data Guard Administration   6 - 3
Benefits of Implementing a Logical Standby Database (continued)
 Data protection: A logical standby database provides a safeguard against data 
corruption and user errors. Primary-side physical corruptions do not propagate through 
the redo data that are transported to the logical standby database. Similarly, user errors 
that may cause the primary database to be permanently damaged can be resolved 
before application on the logical standby through delay features.
 Disaster recovery: A logical standby database provides a robust and efficient disaster-
recovery solution. Easy-to-manage switchover and failover capabilities enable easy role 
reversals between primary and logical standby databases, thereby minimizing the down 
time of the primary database for planned and unplanned outages.
 Database upgrades: A logical standby database can be used to upgrade Oracle 
Database software and apply patch sets with almost no down time. The logical standby 
database can be upgraded to the new release and switched to the primary database 
role. The original primary database is then converted to a logical standby database and 
upgraded. 
Note: See the lesson titled Upgrading Databases in a Data Guard Configuration for 
additional information about using a logical standby database to perform upgrades.
Oracle Database 11g: Data Guard Administration   6 - 4
Logical Standby Database: SQL Apply Architecture
In a logical standby database configuration, Data Guard SQL Apply uses redo information 
shipped from the primary system. However, instead of using media recovery to apply changes 
(as in the physical standby database configuration), archived redo log information is 
transformed into equivalent SQL statements by using LogMiner technology. These SQL 
statements are then applied to the logical standby database. The logical standby database is 
open in read/write mode and is available for reporting capabilities.
Oracle Database 11g: Data Guard Administration   6 - 5
SQL Apply Process: Architecture
SQL Apply uses a collection of parallel execution servers and background processes that 
apply changes from the primary database to the logical standby database as follows:
 The reader process reads redo records from the archived redo log files. 
 The preparer processes convert the block changes into table changes or logical change 
records (LCRs). At this point, the LCRs do not represent any specific transactions.
 The builder process assembles completed transactions from the individual LCRs.
 The analyzer process examines the records, possibly eliminating transactions and 
identifying dependencies between the different transactions. 
 The coordinator process (LSP):
- Assigns transactions
- Monitors dependencies between transactions and coordinates scheduling
- Authorizes the commitment of changes to the logical standby database
 The applier process: 
- Applies the LCRs to the database
- Asks the coordinator process to approve transactions with unresolved 
dependencies, scheduled appropriately so that the dependencies are resolved.
- Commits the transactions
Oracle Database 11g: Data Guard Administration   6 - 6
Preparing to Create a Logical Standby Database
When creating a logical standby database, you must take several actions before you begin. 
The following slides cover these steps in detail.
Oracle Database 11g: Data Guard Administration   6 - 7
Unsupported Objects
If the primary database contains unsupported tables, log apply services automatically exclude 
these tables when applying redo data to the logical standby database.
Oracle Database 11g: Data Guard Administration   6 - 8
Unsupported Data Types
Ensure that your logical standby database can support the data types of the database objects 
that are defined in your primary database.
Note: See Oracle Data Guard Concepts and Administration for additional information about 
unsupported data types and objects. SecureFile LOB's are supported if the database 
compatibility level is set to 11.2 or higher.
Oracle Database 11g: Data Guard Administration   6 - 9
Checking for Unsupported Tables
You can query DBA_LOGSTDBY_UNSUPPORTED_TABLE to determine which tables in the 
primary database are not supported by log apply services.
Oracle Database 11g: Data Guard Administration   6 - 10
Checking for Tables with Unsupported Data Types
You can query the DBA_LOGSTDBY_UNSUPPORTED data dictionary view to see all tables that 
contain data types that are not supported by logical standby databases. These tables are not 
maintained (that is, they do not have DML applied) in the logical standby database. Changes 
made to unsupported data types, tables, sequences, or views on the primary database are 
not propagated to the logical standby database, and no error message is returned.
It is a good idea to query this view on the primary database to ensure that those tables that 
are necessary for critical applications are not in this list before you create the logical standby 
database. If the primary database includes unsupported tables that are critical, consider using 
a physical standby database instead.
Note: This view does not show any tables from the SYS schema because changes to the SYS
schema object are not applied to the logical standby database. 
Oracle Database 11g: Data Guard Administration   6 - 11
SQL Commands That Do Not Execute on the Standby Database
Not all data SQL commands that are executed on the primary database are applied to the 
logical standby database. If you execute any of the commands (shown in the slide) on the 
primary database, they are not executed on any logical standby database in your 
configuration. You must execute them on the logical standby database if needed to maintain 
consistency between the primary database and the logical standby database.
Oracle Database 11g: Data Guard Administration   6 - 12
Unsupported PL/SQL Supplied Packages
Oracle PL/SQL supplied packages that modify system metadata typically are not supported 
by SQL Apply, and therefore their effects are not visible on the logical standby database. 
Oracle PL/SQL supplied packages that do not modify system metadata but may modify user 
data are supported as long as the modified data belongs to the supported data types. 
Example of such packages are DBMS_LOB, DBMS_SQL, and DBMS_TRANSACTION. Specific 
support for DBMS_JOB has been provided. Jobs created on the primary database are 
replicated on the standby database, but will not run as long as the standby maintains its 
standby role. Specific support for DBMS_SCHEDULER has been provided to allow jobs to run 
on the standby database with the database_role attribute of jobs.
Note: See Oracle Data Guard Concepts and Administration for additional information about 
unsupported data types and objects. 
Oracle Database 11g: Data Guard Administration   6 - 13
Ensuring Unique Row Identifiers
Because the row IDs on a logical standby database might not be the same as the row IDs on 
the primary database, a different mechanism must be used to match the updated row on the 
primary database to its corresponding row on the logical standby database. Primary keys and 
unique indexes can be used to match the corresponding rows. It is recommended that you 
add a primary key or a unique index to tables on the primary database (whenever appropriate 
and possible) to ensure that SQL Apply can efficiently apply data updates to the logical 
standby database.
You can query the DBA_LOGSTDBY_NOT_UNIQUE view to identify tables in the primary 
database that do not have a primary key or unique index with NOT NULL columns. Issue the 
following query to display a list of tables that SQL Apply might not be able to uniquely identify:
SQL> SELECT OWNER, TABLE_NAME,BAD_COLUMN 
2  FROM DBA_LOGSTDBY_NOT_UNIQUE
3  WHERE TABLE_NAME NOT IN 
4  (SELECT TABLE_NAME FROM DBA_LOGSTDBY_UNSUPPORTED);
Oracle Database 11g: Data Guard Administration   6 - 14
Adding a Disabled Primary Key RELY Constraint
If your application ensures that the rows in a table are unique, you can create a disabled 
primary key RELY constraint on the table without incurring the overhead of maintaining a 
primary key on the primary database.
The RELY constraint tells the system to log the named columns (in this example, 
EMPLOYEE_ID and LAST_NAME) to identify rows in this table. Be careful to select columns for 
the disabled RELY constraint that uniquely identify the row. If the columns selected for the 
RELY constraint do not uniquely identify the row, SQL Apply does not apply redo information 
to the logical standby database. 
To improve the performance of SQL Apply, add a unique constraint/index to the columns to 
identify the row on the logical standby database. Failure to do so results in full table scans 
during UPDATE or DELETE statements carried out on the table by SQL Apply.
Note: For this example, assume that the HR.EMPLOYEES table does not have a primary key.
Oracle Database 11g: Data Guard Administration   6 - 16
Creating a Logical Standby Database by Using SQL Commands
The remainder of this lesson covers each of these steps in detail.
Oracle Database 11g: Data Guard Administration   6 - 17
Step 1: Create a Physical Standby Database
You create a logical standby database by first creating a physical standby database. Then 
you convert the physical standby database into a logical standby database. 
To create the physical standby database:
a. Create a physical standby database as described in the lesson titled Creating a 
Physical Standby Database by Using SQL and RMAN Commands.
b. Ensure that the physical standby database is current with the primary database by 
allowing recovery to continue until the physical standby database is consistent with the 
primary database, including all database structural changes (such as adding or dropping 
data files).
Oracle Database 11g: Data Guard Administration   6 - 18
Step 2: Stop Redo Apply on the Physical Standby Database
To stop Redo Apply, issue one of the following commands:
 If the configuration is not managed by the broker
SQL > ALTER DATABASE RECOVER MANAGED STANDBY DATABASE CANCEL;
 If the configuration is managed by the broker
DGMGRL > EDIT DATABASE '<database name>' set state='apply-off';
Oracle Database 11g: Data Guard Administration   6 - 19
Step 3: Prepare the Primary Database to Support a Logical Standby Database
a. To transition the primary database to the logical standby role, you must modify the 
initialization parameters on the primary database so that no parameters need to change 
after a role transition. To do this, include the LOG_ARCHIVE_DEST_2 destination on the 
primary database. This parameter takes effect only when the primary database is 
transitioned to the standby database role.
b. Set the UNDO_RETENTION initialization parameter to 3600. The UNDO_RETENTION
parameter specifies (in seconds) the amount of committed undo information to retain in 
the database. The value of 3600 is recommended for best results when building a 
LogMiner dictionary for the logical standby database to prevent ora-1555 errors when 
there are a number of active transactions.
Oracle Database 11g: Data Guard Administration   6 - 20
Step 4: Build a LogMiner Dictionary in the Redo Data
SQL Apply requires a LogMiner dictionary in the redo data so that it can properly interpret 
changes in the redo. When you execute the DBMS_LOGSTDBY.BUILD procedure, the 
LogMiner dictionary is built and supplemental logging is automatically enabled for logging 
primary key and unique key columns. Supplemental logging ensures that each update 
contains enough information to logically identify the affected row.
Note: The DBMS_LOGSTDBY.BUILD procedure waits for all existing transactions to complete 
so that long-running transactions executing on the primary database will affect its operation.
Oracle Database 11g: Data Guard Administration   6 - 21
Step 5: Transition to a Logical Standby Database
To prepare the physical standby database to transition to a logical standby database:
a. Issue the ALTER DATABASE RECOVER TO LOGICAL STANDBY db_name command to 
continue applying redo data to the physical standby database until it is ready to convert 
to a logical standby database. Specify a database name (db_name) to identify the new 
logical standby database. 
The redo log files contain the information needed to convert your physical standby 
database to a logical standby database. The statement applies redo data until the 
LogMiner dictionary is found in the redo log files.
b. Shut down the logical standby database instance and restart it in MOUNT mode.
c. Modify the LOG_ARCHIVE_DEST_n parameters to specify separate local destinations 
for:
- Archived redo log files that store redo data generated by the logical standby 
database
- Archived redo log files that store redo data received from the primary database
Oracle Database 11g: Data Guard Administration   6 - 22
Step 6: Open the Logical Standby Database
To open the logical standby database and start SQL Apply:
a. On the logical standby database, issue the ALTER DATABASE OPEN RESETLOGS
command to open the database.
b. On the logical standby database, issue the following command to start SQL Apply:
ALTER DATABASE START LOGICAL STANDBY APPLY IMMEDIATE
Oracle Database 11g: Data Guard Administration   6 - 23
Adding a Logical Standby Database to a Data Guard Broker Configuration
Use the ADD DATABASE DGMGRL command to define the standby database and create a 
broker configuration profile. The database name that is specified must be the same as the 
value of the DB_UNIQUE_NAME initialization parameter. The connect identifier is used by 
Oracle Net Services to access the database from all other databases in the configuration.
Note: If the existing Data Guard broker configuration has not been enabled, you will need to 
enable it to allow the broker to manage the new logical standby database.
Oracle Database 11g: Data Guard Administration   6 - 24
Step 7: Verify That the Logical Standby Database Is Performing Properly
After creating your logical standby database and setting up redo transport services and log 
apply services, you should verify that redo data is being transmitted from the primary 
database and applied to the standby database. 
To verify that the logical standby database is functioning properly:
a. Connect to the logical standby database and query the DBA_LOGSTDBY_LOG view to 
verify that the archived redo log files were registered on the logical standby system:
SQL> SELECT SEQUENCE#, FIRST_TIME, NEXT_TIME, 
2  DICT_BEGIN,DICT_END
3  FROM DBA_LOGSTDBY_LOG ORDER BY SEQUENCE#;
b. Connect to the primary database and issue the following command to begin sending 
redo data to the standby database:
SQL> ALTER SYSTEM ARCHIVE LOG CURRENT;
c. Connect to the logical standby database and requery the DBA_LOGSTDBY_LOG view as 
shown in step a. This enables you to verify that the new archived redo log files were 
registered.
Oracle Database 11g: Data Guard Administration   6 - 25
Step 7: Verify That the Logical Standby Database Is Performing Properly 
(continued)
d. On the logical standby database, query the V$LOGSTDBY_STATS view to verify that 
redo data is being applied correctly:
SQL> SELECT NAME, VALUE FROM V$LOGSTDBY_STATS 
2  WHERE NAME = 'coordinator state';
A value of INITIALIZING in the VALUE column indicates that log apply services are 
preparing to begin SQL Apply, but that data from the archived redo log files is not being 
applied to the logical standby database.
e. Query the V$LOGSTDBY_PROCESS view to see information about the current state of the 
SQL Apply processes.
f. Query the V$LOGSTDBY_PROGRESS view on the logical standby database to check the 
overall progress of SQL Apply:
SQL> SELECT APPLIED_SCN, LATEST_SCN 
2  FROM V$LOGSTDBY_PROGRESS;
Oracle Database 11g: Data Guard Administration   6 - 26
Creating a Logical Standby Database by Using Enterprise Manager
To create a logical standby database by using Enterprise Manager:
1. Click Add Standby Database on the Data Guard overview page to invoke the Add 
Standby Database Wizard.
Note: If the logical standby database is the first database to be created in your 
configuration, access the Add Standby Database Wizard by clicking Setup and 
Manage in the Data Guard section on the Availability page. Next, click the Add Standby 
Database link to invoke the Add Standby Database Wizard.
2. Select Create a new logical standby database on the Add Standby Database page, 
and click Continue.
3. The wizard guides you through a procedure that is similar to adding a physical standby 
database.
Oracle Database 11g: Data Guard Administration   6 - 27
Using the Add Standby Database Wizard
On the Add Standby Database: Backup Type page, you determine if you have tables or 
columns that are not supported by SQL Apply. In the SQL Apply Unsupported Tables section, 
select Table Columns and Data Types in the drop-down list and click Go to see the 
unsupported tables.
Oracle Database 11g: Data Guard Administration   6 - 28
Using the Add Standby Database Wizard (continued)
On the Add Standby Database: Configuration page, specify the values for the DB_NAME and 
DB_UNIQUE_NAME parameters for your logical standby database. In addition, specify the 
target name to be used by Enterprise Manager Grid Control. 
In the Standby Database Monitoring Credentials section, you can choose between a non-
SYSDBA user such as DBSNMP to monitor the database or choose to use the SYSDBA 
monitoring credentials.
Oracle Database 11g: Data Guard Administration   6 - 29
Using the Add Standby Database Wizard (continued)
After completing all pages in the wizard, you see the Add Standby Database Review page. 
Review the information on this page and click Finish to submit a job to create your logical 
standby database.
Oracle Database 11g: Data Guard Administration   6 - 30
Securing Your Logical Standby Database
The database guard controls user access to tables in a logical standby database. Use the 
ALTER DATABASE GUARD command to configure the database guard.
By default, it is not possible for a nonprivileged user to modify data on a Data Guard SQL 
Apply database, because the database guard is automatically set to ALL. With this level of 
security, only the SYS user can modify data. 
When you set the security level to STANDBY, users are able to modify data that is not 
maintained by the logical apply engine. A security level of NONE permits any users to access 
the standby database if they have the appropriate privileges.
When creating a logical standby database manually with SQL commands, you must issue the 
ALTER DATABASE GUARD ALL command before opening the database. Failure to do so 
allows jobs that are submitted through DBMS_JOB.SUBMIT to be scheduled and to potentially 
modify tables in the logical standby database.
Note: Be careful not to let the primary and logical standby databases diverge while the 
database guard is disabled.
Oracle Database 11g: Data Guard Administration   6 - 31
Automatic Deletion of Redo Log Files by SQL Apply
Archived redo logs on the logical standby database are automatically deleted by SQL Apply 
after they are applied. This feature reduces the amount of space consumed on the logical 
standby database and eliminates the manual step of deleting the archived redo log files.
You can enable and disable the auto-delete feature for archived redo logs by using the 
DBMS_LOGSTDBY.APPLY_SET procedure. By default, the auto-delete feature is enabled.
Note: If you are using a flash recovery area, auto deletion is based on the flash recovery 
areas space pressure.
Oracle Database 11g: Data Guard Administration   6 - 32
Managing Remote Archived Log File Retention
By default, SQL Apply deletes an archived redo log file after applying the contents. This 
behavior is controlled by the LOG_AUTO_DELETE parameter. During a flashback operation or 
point-in-time recovery of the logical standby database, SQL Apply must stop and re-fetch all 
remote archived redo log files.
In Oracle Database 11g, you use the LOG_AUTO_DEL_RETENTION_TARGET parameter to 
specify a retention period for remote archived redo log files. You can modify 
LOG_AUTO_DEL_RETENTION_TARGET by using the DBMS_LOGSTDBY.APPLY_SET and 
DBMS_LOGSTDBY.APPLY_UNSET procedures.
Note: This parameter is applicable only when you are not using the fast recovery area.
Oracle Database 11g: Data Guard Administration   6 - 33
Managing SQL Apply Filtering
You can use SQL Apply filters to control what to apply and what not to apply. To define a SQL 
Apply filter, use the following configurable database properties:
   LsbyASkipCfgPr: Provides a way to indicate to SQL Apply that it should ignore (skip) 
SQL statements that you do not want to apply to the logical standby database. Valid 
values for this property are a valid set of arguments to the DBMS_LOGSTDBY.SKIP
procedure.
   LsbyASkipErrorCfgPr: Provides criteria to determine if an error should cause SQL 
Apply to stop. All errors to be skipped are stored in system tables that describe how 
exceptions should be handled. Valid values for this property are a valid set of arguments 
to the DBMS_LOGSTDBY.SKIP_ERROR procedure. The string must contain comma 
separators between the arguments.
   LsbyASkipTxnCfgPr: Enables you to specify the transaction ID (XIDSQN NUMBER) of 
a problematic transaction that you want SQL Apply to ignore. Valid values for this 
property are a valid set of arguments to the DBMS_LOGSTDBY.SKIP_TRANSACTION
procedure.
See the Oracle Database PL/SQL Packages and Types Reference for detailed information 
about the DBMS_LOGSTDBY package and its procedures.
Oracle Database 11g: Data Guard Administration   6 - 34
Managing SQL Apply Filtering (continued)
Use the following configurable database properties to delete a previously defined SQL Apply 
filter:
   LsbyDSkipCfgPr: Deletes an existing SQL Apply skip specification. Valid values are a 
valid set of arguments to the DBMS_LOGSTDBY.UNSKIP procedure
   LsbyDSkipErrorCfgPr: Deletes an existing SQL Apply skip error specification. Valid 
values are a valid set of arguments to the DBMS_LOGSTDBY.UNSKIP_ERROR
procedure.
   LsbyDSkipTxnCfgPr: Reverses or removes the actions of the LsbyASkipTxnCfgPr
property. Valid values are a valid set of arguments to the 
DBMS_LOGSTDBY.UNSKIP_TRANSACTION procedure.
See the Oracle Database PL/SQL Packages and Types Reference for detailed information 
about the DBMS_LOGSTDBY package and its procedures.
Oracle Database 11g: Data Guard Administration   6 - 35
Viewing SQL Apply Filtering Settings
You can query the DBA_LOGSTDBY_SKIP view on the logical standby database to determine 
the SQL Apply filtering settings. The view contains the following columns:
   ERROR: Indicates whether the statement should be skipped or should return an error for 
the statement
   STATEMENT_OPT: Specifies the type of statement that should be skipped (It must be 
one of the SYSTEM_AUDIT statement options.)
   OWNER: Name of the schema under which the skip option is used
   NAME: Name of the table that is being skipped
   USE_LIKE: Indicates whether the statement uses a SQL wildcard search when 
matching names
   ESC: Escape character to be used when performing wildcard matches
   PROC: Name of a stored procedure that is executed when processing the skip option
You can query DBA_LOGSTDBY_SKIP_TRANSACTION to view settings for transactions to be 
skipped. 
Oracle Database 11g: Data Guard Administration   6 - 36
Managing SQL Apply Filtering by Using Enterprise Manager
You can use Enterprise Manager to implement SQL Apply filtering by navigating to the Edit 
Standby Database Properties page. On the Standby Role Properties tabbed page, expand 
Advanced Properties to access the Skip Table Entries section.
Use the Add Skip Table Entry page to specify the following skip criteria:
 Identify SQL statements that are not applied to the standby database by specifying the 
schema and database object to be skipped.
 Specify criteria to be used to determine if an error should cause log apply services to 
stop. All errors to be skipped are stored in system tables that describe how exceptions 
should be handled.
 Specify additional processing that should be done (such as execution of a stored 
procedure).
Oracle Database 11g: Data Guard Administration   6 - 37
Using DBMS_SCHEDULER to Create Jobs on a Logical Standby Database
Use the DBMS_SCHEDULER package to create Scheduler jobs so that they are executed when 
intended. Scheduler jobs can be created on a standby database.
When a Scheduler job is created, it defaults to the local role. If the job is created on the 
standby database, it defaults to the role of a logical standby. The Scheduler executes jobs 
that are specific to the current database role. Following a role transition (switchover or 
failover), the Scheduler automatically switches to executing jobs that are specific to a new 
role.
Scheduler jobs are replicated to the standby, but they do not run by default. However, existing 
jobs can be activated under the new role by using the DBMS_SCHEDULER.SET_ATTRIBUTE
procedure. If you want a job to run for all database roles on a particular host, you must create 
two copies of the job on that host: one with a database_role of 'PRIMARY' and the other 
with a database_role of 'LOGICAL STANDBY'. Query the DBA_SCHEDULER_JOB_ROLES
view to determine which jobs are specific to which role.
See the Oracle Database PL/SQL Packages and Types Reference for detailed information 
about using the DBMS_SCHEDULER package.
Oracle Database 11g: Data Guard Administration   6 - 38
Answer: b
Oracle Database 11g: Data Guard Administration   6 - 39
Answer: a
Oracle Database 11g: Data Guard Administration   6 - 40
Oracle Database 11g: Data Guard Administration   6 - 41
Oracle Database 11g: Data Guard Administration   6 - 42
Oracle Database 11g: Data Guard Administration   7 - 2
Snapshot Standby Databases: Overview
A snapshot standby database is a fully updatable standby database that is created by 
converting a physical standby database to a snapshot standby database. A snapshot standby 
database receives and archivesbut does not applyredo data from a primary database. 
Redo data received from the primary database is applied when a snapshot standby database 
is converted back to a physical standby database, after discarding all local updates to the 
snapshot standby database.
You can create a snapshot standby database by using DGMGRL commands or SQL 
commands.
When the standby database is converted to a snapshot standby database, an implicit 
guaranteed restore point is created and Flashback Database is enabled. After performing 
operations on the snapshot standby database, you can convert it back to a physical standby 
database.
Data Guard implicitly flashes the database back to the guaranteed restore point and 
automatically applies the primary database redo that was archived by the snapshot standby 
database since it was created. The guaranteed restore point is dropped after this process is 
completed.
Oracle Database 11g: Data Guard Administration   7 - 3
Snapshot Standby Database: Architecture
After a physical standby database is converted to a snapshot standby database, Redo Apply 
no longer applies the redo data. The redo data continues to be received using the defined 
transport method (SYNC or ASYNC), but it is not applied until the snapshot standby database is 
converted back to a physical standby database.
Oracle Database 11g: Data Guard Administration   7 - 4
Converting a Physical Standby Database to a Snapshot Standby Database
Use the CONVERT DATABASE DGMGRL command to convert a physical standby database to 
a snapshot standby database, as in the following example:
DGMGRL> convert database pdb1 to snapshot standby;
Converting database "pdb1" to a Snapshot Standby database, 
please wait...
Database "pdb1" converted successfully
Oracle Database 11g: Data Guard Administration   7 - 5
Activating a Snapshot Standby Database: Issues and Cautions
Keep the following in mind when activating a snapshot standby database:
 Potential data loss when there is a corrupted log file: The snapshot standby 
database accepts redo log files but does not apply them. If there is a corrupted redo log 
file at the snapshot standby database, it is not discovered until the database is 
converted back to a physical standby database and the managed recovery process 
(MRP) is started. If the primary database is unavailable at that time, there is no way to 
retrieve that log. Also, the loss or corruption of a flashback log file might prevent 
conversion back to a physical standby database.
 Lengthy conversion of the snapshot standby database to a primary database: In 
the event of a failure of the primary database, the snapshot standby database can be 
converted back to a physical standby database. The redo that has been received can 
then be applied, and the database can be converted to a primary database. If the 
snapshot standby database lags far behind the primary database, it may take a long 
time to apply the redo that has been received and convert it to the primary database.
Oracle Database 11g: Data Guard Administration   7 - 6
Snapshot Standby Database: Target Restrictions
When you convert the physical standby database to a snapshot standby database, it cannot 
be the only standby database in the configuration if your configuration is in maximum 
protection mode. In addition, you cannot make changes to the configuration after converting 
to a snapshot standby database that would create this situation.
You cannot perform a switchover to a snapshot standby database. 
A snapshot standby database cannot be configured as a fast-start failover target.
Oracle Database 11g: Data Guard Administration   7 - 7
Viewing Snapshot Standby Database Information
The DATABASE_ROLE column of the V$DATABASE view indicates that the database is a 
snapshot standby database.
Oracle Database 11g: Data Guard Administration   7 - 8
Using DGMGRL to View Snapshot Standby Database Information
Use the SHOW CONFIGURATION and SHOW CONFIGURATION VERBOSE DGMGRL commands 
to display information about the snapshot standby database.
Oracle Database 11g: Data Guard Administration   7 - 9
Using DGMGRL to View Snapshot Standby Database Information (continued)
When you execute the SHOW DATABASE and SHOW DATABASE VERBOSE commands for a 
snapshot standby database, SNAPSHOT STANDBY is displayed in the role field.
Oracle Database 11g: Data Guard Administration   7 - 10
Converting a Snapshot Standby Database to a Physical Standby Database
Use the CONVERT DATABASE command to convert the database back to a physical standby 
database. 
Oracle Database 11g: Data Guard Administration   7 - 11
Answer: b
Oracle Database 11g: Data Guard Administration   7 - 12
Oracle Database 11g: Data Guard Administration   7 - 13
Oracle Database 11g: Data Guard Administration   7 - 14
Oracle Database 11g: Data Guard Administration   8 - 2
Oracle Active Data Guard
Oracle Active Data Guard is a separately licensed database option for Oracle Database 11g
Enterprise Edition. It includes the Real-time Query feature, which enables a physical standby 
database to be open read-only while Redo Apply is active. With this feature, users who are 
connected to a physical standby database can query and report against data that is up-to-
date with the primary database.
Oracle Active Data Guard also enables you to configure RMAN block change tracking for a 
physical standby database. With RMAN block change tracking, you can offload fast 
incremental backups from the production database to the physical standby database.
Oracle Database 11g: Data Guard Administration   8 - 3
Using Real-Time Query
With Oracle Active Data Guard, you can use a physical standby database for queries while 
redo is applied to the physical standby database. This feature enables you to use a physical 
standby database for disaster recovery and to offload work from the primary database during 
normal operation. 
Note: If you need to create additional structures (such as indexes and materialized views), 
you can create a logical standby database as described in the lesson titled Creating a 
Logical Standby Database.
In addition, this feature provides a loosely coupled read/write clustering mechanism for OLTP 
workloads when configured as follows:
 Primary database: Recipient of all update traffic
 Several readable standby databases: Used to distribute the query workload
The physical standby database can be opened in read-only mode only if all files were 
recovered up to the same system change number (SCN). Otherwise, the open fails.
Oracle Database 11g: Data Guard Administration   8 - 4
Enabling Real-Time Query
With Oracle Database 11g Release 2 (11.2), it is no longer necessary to stop redo apply on a 
physical standby database when opening the database to enable real-time query mode if and 
only if the physical standby is managed by the Data Guard broker. The Data Guard broker 
automatically stops redo apply when an open is attempted. After the instance is opened, the 
Data Guard broker automatically restarts redo apply according to the settings recorded in the 
broker configuration file.
DGMGRL> show database pc01sby1
Database - pc01sby1
Enterprise Manager Name: pc01sby1.us.oracle.com
Role:                    PHYSICAL STANDBY
Intended State:          APPLY-ON
Transport Lag:           0 seconds
Apply Lag:               0 seconds
Real Time Query:         OFF
Instance(s):
pc01sby1
Oracle Database 11g: Data Guard Administration   8 - 5
Disabling Real-Time Query
To disable Real-time Query, you must shut down the standby database instance and restart it 
in MOUNT mode.
Oracle Database 11g: Data Guard Administration   8 - 7
Checking the Standbys Open Mode
You can use the OPEN_MODE column of V$DATABASE to check the open mode of a physical 
standby database. If the physical standby database stops redo apply in order to open the 
database in read-only mode, then the OPEN_MODE column will indicate 'READ ONLY'.
After the database has been opened read-only, Redo Apply can be restarted to enable Active 
Data Guard real-time query mode with the following command:
SQL>  alter database recover managed standby database using 
current logfile disconnect;
After Redo Apply has been started on an open read-only physical standby database, the 
OPEN_MODE column will indicate 'READ ONLY WITH APPLY'.
Oracle Database 11g: Data Guard Administration   8 - 8
Understanding Lag in an Active Data Guard Configuration
Active Data Guard can improve performance by off-loading a read-only workload to a physical 
standby database. However, due to hardware and network issues, the data on a standby 
database may lag behind the data on the primary database. The standby database may not 
always be current with the primary database if it does not have the capacity to apply redo as 
quickly as it is received. Limited bandwidth may prevent the primary database from shipping 
redo as quickly as it is generated, particularly during periods of peak workload.
Oracle Database 11g Release 2 (11.2) includes features to enable you to determine the lag 
time and take appropriate action.
You can establish a tolerance level for data staleness by configuring a maximum value for 
apply lag. Query results are returned to the application if the lag is within the acceptable 
tolerance level; otherwise, an error results.
If you determine that you want your application to receive the results of a query, regardless of 
the staleness of the data, you can monitor the apply lag via the V$DATAGUARD_STATS view 
and then take appropriate action if the lag is unacceptable.
Oracle Database 11g: Data Guard Administration   8 - 9
Monitoring Apply Lag: V$DATAGUARD_STATS
Apply lag has been redefined in Oracle Database 11g Release 2 (11.2). Apply lag is a 
measure of the degree to which a standby database lags behind the primary database, due to 
delays in propagating and applying redo to the standby database. 
The apply lag metric is computed using data that is periodically received from the primary 
database. The DATUM_TIME column contains a timestamp of when this data was last 
received by the standby database. The TIME_COMPUTED column contains a timestamp taken 
when the apply lag metric was calculated. The difference between the values in these 
columns should be less than 30 seconds. If the difference is larger than this, the apply lag
metric may not be accurate. This metric is computed to the nearest second. 
Oracle Database 11g: Data Guard Administration   8 - 10
Monitoring Apply Lag: V$STANDBY_EVENT_HISTOGRAM
V$STANDBY_EVENT_HISTOGRAM is a new view that is available on the standby database. 
This view displays the histogram of the apply lag on the physical standby database.
Use the histogram to focus on periods of time when the apply lag exceeds desired levels. 
Determine the cause of the lag during those time periods and take steps to resolve the 
excessive lag.
Each distinct value of apply lag has its own bucket. The count in the bucket is incremented 
when the physical standby database samples its data delay.
Oracle Database 11g: Data Guard Administration   8 - 11
Setting a Predetermined Service Level for Currency of Standby Queries
You can configure a limit through the use of the STANDBY_MAX_DATA_DELAY session 
parameter. Use this session parameter to specify a limit for the amount of time (in seconds) 
allowed to elapse between when changes are committed on the primary database and when 
those same changes can be queried on the active standby database.
If the specified limit cannot be met, an error is returned to the query as follows:
ORA-3172 STANDBY_MAX_DATA_DELAY has been exceeded
This guarantees that a query will not receive a stale result if the apply lag exceeds the 
service level agreement.  In addition, a warning message is written to the standby database 
alert log.
The default value is NONE, which indicates that queries issued to the physical standby 
database will be executed regardless of the apply lag on that database.
Oracle Database 11g: Data Guard Administration   8 - 12
Configuring Zero Lag Between the Primary and Standby Databases
You can ensure that your application querying data on the standby database sees all data 
that has been committed on the primary database by setting STANDBY_MAX_DATA_DELAY to 
0.
A query does not execute until the query SCN on the standby database has advanced to a 
value equal to that of the current SCN on the primary database at the time the query was 
issued.
To support zero lag, the primary database must operate in maximum availability or maximum 
protection mode. 
Specify SYNC for redo transport mode.
Real-time query must be enabled as a prerequisite for configuring zero lag.
Oracle Database 11g: Data Guard Administration   8 - 13
Setting STANDBY_MAX_DATA_DELAY by Using an AFTER LOGON Trigger
You can create an AFTER LOGON trigger that sets the STANDBY_MAX_DATA_DELAY session 
parameter when the database is a physical standby database that is operating in real-time 
query mode.
In Oracle Database 11g Release 2 (11.2), the DATABASE_ROLE attribute of the USERENV
context enables you to determine the role of the database. SQL and PL/SQL clients can 
retrieve this information by using the SYS_CONTEXT function. This enables you to write 
triggers that perform certain actions based on the database role.
Oracle Database 11g: Data Guard Administration   8 - 14
Example: Setting STANDBY_MAX_DATA_DELAY by Using an AFTER LOGON Trigger
The slide presents an example of an AFTER LOGON trigger that is used to set the value of 
STANDBY_MAX_DATA_DELAY based on the database role.
Oracle Database 11g: Data Guard Administration   8 - 15
Forcing Redo Apply Synchronization
You can execute the ALTER SESSION SYNC WITH PRIMARY command to ensure that the 
standby database is completely synchronized with the primary database at the time of 
execution. The use of this command is particularly applicable in a reporting environment.
ALTER SESSION SYNC WITH PRIMARY performs a blocking wait on the standby database 
upon execution. This command causes the application to be blocked until the standby 
database is in sync with the primary database as of the time this command is executed.
When the ALTER SESSION command returns control to the session, the session can continue 
to process queries without having to wait for redo apply on the standby database.
If redo apply is not active or is canceled before the standby database is in sync with the 
primary database, an ORA-3173 Standby may not be synced with primary error is 
returned.
Oracle Database 11g: Data Guard Administration   8 - 16
Creating an AFTER LOGON Trigger for Synchronization
This type of trigger is useful when you are using the standby database for reporting and want 
to be sure that the reports have the most current data. The standby-only AFTER LOGON trigger 
executes the ALTER SESSION SYNC WITH PRIMARY command to force a wait for 
synchronization between the primary database and the standby database. A standby-only 
trigger is created and enabled on the primary database, and then becomes part of the redo 
that is propagated to the standby database. However, the trigger logic is designed only to take 
certain actions if the database role is set to physical standby.
Oracle Database 11g: Data Guard Administration   8 - 17
Supporting Read-Mostly Applications
Reporting applications that are predominantly read-only, but require limited read-write 
database access are referred to as read-mostly applications. Active Data Guard enables a 
standby database to support the read-only portion of read-mostly applications if writes are 
redirected to the primary database or a local database.
Oracle Database 11g: Data Guard Administration   8 - 18
Example: Transparently Redirecting Writes to the Primary Database
Consider an application as described in the slide. The application executes as user U, reading 
the U.R table and writing to the U.W table. The application connects as user U when 
executing on the primary database.
User S accesses U.R with the S.R synonym and U.W with the S.W synonym.
The AFTER LOGON trigger is created on the standby database for another user, R.
When the application executes on the standby database, it connects as the U user. The 
AFTER LOGON trigger fires and transparently switches to the S schema. All reads on R
execute as reads to the U.R table on the standby database. All reads and writes to W execute 
as reads and writes to U.W@primary.
Oracle Database 11g: Data Guard Administration   8 - 19
Enabling Block Change Tracking on a Physical Standby Database
With the Oracle Active Data Guard option, you can enable block change tracking on a 
physical standby database. When you back up the physical standby database, RMAN uses 
the block change tracking file to quickly identify the blocks that have changed since the last 
incremental backup. RMAN reads only the changed blocks rather than the entire data file.
Oracle Database 11g: Data Guard Administration   8 - 20
Creating Fast Incremental Backups
The goal of an incremental backup is to back up only those data blocks that have changed 
since a previous backup. You can use RMAN to create incremental backups of data files, 
tablespaces, or the entire database. During media recovery, RMAN examines the restored 
files to determine whether it can recover them from an incremental backup. RMAN always 
chooses incremental backups over archived redo logs because applying changes at a block 
level is faster than reapplying individual changes. 
If you enable the block change tracking feature, Oracle Database tracks the physical location 
of all database changes in the change tracking file. RMAN uses this change-tracking data to 
determine which blocks to read during an incremental backup, creating much faster 
incremental backups by eliminating the need to read the entire data file. The maintenance of 
this file is fully automatic and does not require your intervention. The size of the change 
tracking file is proportional to the following:
 Database size in bytes
 Number of enabled threads in a RAC environment
 Number of old backups maintained by the change tracking file
The minimum size for the change tracking file is 10 MB; new space is allocated in 10 MB 
increments. By default, the Oracle Database server does not record block-change 
information.
Oracle Database 11g: Data Guard Administration   8 - 21
Enabling Block Change Tracking 
You enable block change tracking from the database home page. Click the Policy tab on the 
Backup Settings page. You do not need to set the change tracking file destination if the 
DB_CREATE_FILE_DEST initialization parameter is set, because the file is created as an 
Oracle Managed File (OMF) file in the DB_CREATE_FILE_DEST location. You can, however, 
specify the name of the change tracking file and place it in any location you choose. 
You can also enable or disable block change tracking by using an ALTER DATABASE SQL 
command. If the change tracking file is stored in the database area with your database files, it 
is deleted when you disable change tracking. 
You can rename the change tracking file by using the ALTER DATABASE RENAME SQL 
command. Your database must be in the MOUNT state to rename the tracking file. The ALTER
DATABASE RENAME FILE command updates the control file to refer to the new location. Use 
the following syntax to rename the change tracking file:
ALTER DATABASE RENAME FILE '...' TO '...';
Oracle Database 11g: Data Guard Administration   8 - 22
Monitoring Block Change Tracking
The output of the V$BLOCK_CHANGE_TRACKING view shows where the change tracking file 
is located, the status of block change tracking (ENABLED/DISABLED), and the size (in bytes) 
of the file.
Querying the V$BACKUP_DATAFILE view shows the effectiveness of block change tracking in 
minimizing the incremental backup I/O (the PCT_READ_FOR_BACKUP column). A high value 
indicates that RMAN reads most blocks in the data file during an incremental backup. You can 
reduce this ratio by decreasing the time between incremental backups.
Sample Formatted Output from the V$BACKUP_DATAFILE Query
FILE#  BLOCKS_IN_FILE  BLOCKS_READ PCT_READ_FOR_BACKUP BLOCKS_BACKED_UP
----- -------------- ----------- ------------------- ----------------
1           56320         4480                   7               462
2            3840         2688                  70              2408
3           49920        16768                  33              4457
4             640           64                  10                 1
5           19200          256                   1                91
Oracle Database 11g: Data Guard Administration   8 - 23
Answer: b
Oracle Database 11g: Data Guard Administration   8 - 24
Oracle Database 11g: Data Guard Administration   8 - 25
Oracle Database 11g: Data Guard Administration   8 - 26
Oracle Database 11g: Data Guard Administration   9 - 2
Data Protection Modes and Redo Transport Modes 
When you define a redo transport mode, you are configuring the shipment of log files from the 
primary database to the standby database (physical or logical). You must set your redo 
transport mode to support the protection mode that you want for your configuration. However, 
configuring the redo transport mode alone does not set up the protection mode.
After setting up the redo transport mode, you can put the configuration into a data protection 
mode. The data protection mode setting causes internal rules to be implemented, ensuring 
that your configuration is protected at the necessary level.
Oracle Database 11g: Data Guard Administration   9 - 3
Data Protection Modes
Oracle Data Guard offers maximum protection, maximum availability, and maximum 
performance modes to help enterprises balance data availability against system performance 
requirements.
In some situations, a business cannot afford to lose data. In other situations, the availability of 
the database may be more important than the loss of data. Some applications require 
maximum database performance and can tolerate the potential loss of data.
Oracle Database 11g: Data Guard Administration   9 - 4
Maximum Protection Mode
This protection mode ensures that no data loss occurs if the primary database fails. To 
provide this level of protection, the redo data that is needed to recover each transaction must 
be written to both the local online redo log and the standby redo log on at least one standby 
database before the transaction commits. To ensure that data loss cannot occur, the primary 
database shuts down if a fault prevents it from writing its redo stream to at least one remote 
standby redo log. For multiple-instance RAC databases, Data Guard shuts down the primary 
database if it is unable to write the redo records to at least one properly configured database 
instance.
Maximum protection mode requirements:
 Configure standby redo log files on at least one standby database. 
 Set the SYNC and AFFIRM attributes of the LOG_ARCHIVE_DEST_n parameter for at 
least one standby database destination.
Note: Oracle recommends a minimum of two standby databases for maximum protection 
mode.
Oracle Database 11g: Data Guard Administration   9 - 5
Maximum Availability Mode
This protection mode provides the highest possible level of data protection without 
compromising the availability of the primary database. A transaction does not commit until the 
redo that is needed to recover that transaction is written to the local online redo log and to at 
least one remote standby redo log. The primary database does not shut down if a fault 
prevents it from writing its redo stream to a remote standby redo log. Instead, the primary 
database operates in an unsynchronized mode until the fault is corrected and all gaps in redo 
log files are resolved. When all gaps are resolved and the standby database is synchronized, 
the primary database automatically resumes operating in maximum availability mode.
This mode guarantees that no data loss occurs if the primary database failsbut only if a 
second fault does not prevent a complete set of redo data from being sent from the primary 
database to at least one standby database.
Maximum availability mode requirements:
 Configure standby redo log files on at least one standby database. 
 Set the SYNC and AFFIRM attributes of the LOG_ARCHIVE_DEST_n parameter for at 
least one standby database.
Oracle Database 11g: Data Guard Administration   9 - 6
Maximum Performance Mode
Maximum performance is the default protection mode and provides the highest possible level 
of data protection without affecting the performance of the primary database. This is 
accomplished by allowing a transaction to commit as soon as the redo data needed to recover 
that transaction is written to the local online redo log. The primary databases redo data is 
also written to at least one standby database, but that redo data is written asynchronously 
with respect to the commitment of the transactions that create the redo data.
When network links with sufficient bandwidth are used, this mode provides a level of data 
protection that approaches that of maximum availability mode with minimal impact on primary 
database performance.
Maximum performance mode requirement: Set the ASYNC and NOAFFIRM redo transport 
attributes of the LOG_ARCHIVE_DEST_n parameter on at least one standby database.
Oracle Database 11g: Data Guard Administration   9 - 7
Comparing Data Protection Modes
Consider the characteristics of each protection mode. You must balance cost, availability, 
performance, and transaction protection when choosing the protection mode.
Note: If you plan to enable fast-start failover, you must set the protection mode to maximum 
availability or maximum performance. See the lesson titled Enabling Fast-Start Failover for 
additional information.
Oracle Database 11g: Data Guard Administration   9 - 8
Setting the Data Protection Mode by Using DGMGRL
1. You must configure standby redo log files for the primary database or another standby 
database in the configuration to ensure that it can support the chosen protection mode 
after a switchover.
2. Use the EDIT DATABASE SET PROPERTY command to set the redo transport mode for 
the standby database. For example, if you are changing the data protection mode to 
maximum availability, use the EDIT DATABASE command to specify SYNC for redo 
transport services:
DGMGRL> EDIT DATABASE 'DR_Sales' SET PROPERTY 
'LogXptMode'='SYNC';
You must also set the redo transport services for the primary database or another 
standby database in the configuration to ensure that it can support the chosen protection 
mode after a switchover.
3. Use the EDIT CONFIGURATION SET PROTECTION MODE AS command to set the overall 
configuration protection mode. To set the protection mode to maximum availability, use 
the following command:
DGMGRL> EDIT CONFIGURATION SET PROTECTION MODE AS 
MAXAVAILABILITY;
Oracle Database 11g: Data Guard Administration   9 - 9
Setting the Data Protection Mode
If the data protection mode that you need requires a standby database to use the SYNC or 
ASYNC redo transport mode, Enterprise Manager automatically sets the redo transport mode 
for the primary database and the selected standby databases.
Enterprise Manager automatically determines the correct number and size of standby redo log 
files that are needed for all databases in the configuration and adds those log files using the 
directory locations that you specify.
To set the data protection mode with Enterprise Manager:
1. Navigate to the Data Guard page.
2. Click the link in the Protection Mode field to access the Change Protection Mode: Select 
Mode page.
Oracle Database 11g: Data Guard Administration   9 - 10
Setting the Data Protection Mode (continued)
3. Select Maximum Protection, Maximum Availability, or Maximum Performance, and click 
Continue.
4. If prompted, enter the username and password of a user with SYSDBA privileges. Click 
Login.
5. Select one or more standby databases to support the protection mode that you selected. 
(If standby redo log files are needed, verify the names of the log files.) Click OK.
6. On the Confirmation page, click Yes.
Oracle Database 11g: Data Guard Administration   9 - 11
Answer: a, b, d
Oracle Database 11g: Data Guard Administration   9 - 12
Oracle Database 11g: Data Guard Administration   9 - 13
Oracle Database 11g: Data Guard Administration   9 - 14
Oracle Database 11g: Data Guard Administration   10 - 2
Role Management Services
You can use role management services to change the primary and standby roles dynamically 
as a planned transition called a switchover operation, or as a result of a database failure 
through a failover operation. 
For example, you might perform a switchover operation to transition the primary database to 
the standby role and transition a standby database to the primary role to perform routine 
maintenance tasks.
Oracle Database 11g: Data Guard Administration   10 - 3
Role Transitions: Switchover and Failover
Switchover
You can use the switchover feature to switch the role of the primary database to one of the 
available standby databases. The chosen standby database becomes the primary database, 
and the original primary database then becomes a standby database. There is no need to 
re-create any of the databases involved in the switchover operation. There is no data 
divergence between the original and new primary databases after successful completion of 
the switchover.
Failover
You invoke a failover operation when a failure occurs on the primary database and there is no 
possibility of recovering the primary database in a timely manner. During a failover operation, 
the standby database assumes the primary database role. You invoke the failover operation 
on the standby database that you want to fail over to the primary role.
Note: You can enable fast-start failover to fail over automatically when the primary database 
becomes unavailable. When fast-start failover is enabled, the broker determines if a failover is 
necessary and initiates the failover to the specified target standby database automatically, 
with no need for DBA intervention and with no loss of data. For details, see the lesson titled 
Enabling Fast-Start Failover.
Oracle Database 11g: Data Guard Administration   10 - 4
Switchover
A switchover operation transitions the primary database to the standby role and transitions the 
standby database to the primary role, without resetting the online redo logs of the new primary 
database. 
The primary database at the start of a switchover operation will need to be shutdown and 
restarted. The physical standby database is not shutdown and restarted during a switchover. 
If the physical standby database is in the Active Data Guard mode, it is closed for the 
transition then opened again after the switchover completes, but it is never totally shutdown to 
require a restart.
If the switchover operation involves a logical standby database, there is no need to shut down 
and restart either the primary database or any of the standby databases. Logical standby 
databases do not need to be shut down and restarted.
Note: When necessary, the broker automatically starts and stops all but one instance in a 
Real Application Clusters (RAC) environment for the primary database. If the broker is not 
used, this must be done manually. Starting with Oracle Database 11g Release 2 (11.2), the 
secondary RAC instances of a physical standby database no longer need to be shutdown 
during the switchover. They can stay in the mounted or Active Data Guard state. The primary 
still requires only one instance be running during a switchover.
Oracle Database 11g: Data Guard Administration   10 - 5
Switchover: Before
As an example, suppose that the primary database is located in San Francisco and the 
physical standby database is located in Boston. Switchovers are started only on the primary 
database and completed on the target standby database. You can be connected to any 
database in the configuration through DGMGRL to execute the SWITCHOVER command.
Oracle Database 11g: Data Guard Administration   10 - 6
Switchover: After
After the switchover is completed, each database has the role opposite to the one that it had 
before the switchover. In this example, Boston is now the primary database and San 
Francisco is the standby database.
Because Data Guard does not automatically switch over sessions from one database to the 
other, active sessions for each system need to reconnect. See the lesson titled Managing 
Client Connectivity for information about configuring automatic methods to reconnect 
sessions.
Oracle Database 11g: Data Guard Administration   10 - 7
Preparing for a Switchover
Before you execute the SWITCHOVER command, verify the following:
 Each location in the Data Guard configuration has connectivity through Oracle Net to the 
primary database and to all associated standby databases.
 The state of the primary is set to TRANSPORT-ON and the state of the standby 
databases is APPLY-ON.
 There are no errors or warning for any of the participating databases.
 The standby LogXptMode, DbFileNameConvert, LogFileNameConvert, 
StandbyArchiveLocation, and LogArchiveFormat database properties are set 
on the primary database, so that the primary database can function correctly when 
transitioned to a standby database.
 The LogXptMode configurable database property is set to SYNC on the current primary 
database if the configuration is set to in either maximum availability mode or maximum 
protection mode.
 Standby redo log files are configured on the primary database. Standby redo log 
configuration should be identical on the primary database and on any physical standby 
databases. Even though the standby redo logs are not used when the database is in the 
primary role, configuring the standby redo logs on the primary database is 
recommended in preparation for an eventual switchover operation.
Oracle Database 11g: Data Guard Administration   10 - 8
Performing a Switchover by Using DGMGRL
After verifying the conditions required for executing a switchover, execute the SWITCHOVER
command to perform the switchover operation. The Data Guard broker performs the following 
operations:
1. Verifies that the primary database and target standby database are in the correct states
2. Shuts down any instances as necessary
3. Switches roles between the primary and standby databases
4. Updates the broker configuration file with the new role information
5. Restarts the new standby database
6. Opens the new primary database in read/write mode and starts redo transport services
Note: For detailed information about each step, see Oracle Data Guard Broker.
Oracle Database 11g: Data Guard Administration   10 - 9
Performing a Switchover by Using Enterprise Manager
When it is used for the switchover, Enterprise Manager:
a. Checks to ensure that the primary database and standby database are not currently in 
an error status condition and that broker management of the primary database is 
enabled and online
b. Automatically closes any active sessions connected to the primary database during the 
switchover
c. First changes the primary database to the standby role, and then changes the standby 
database to the primary role
d. Opens the target database if it is a mounted physical standby database and restarts the 
former primary database
To initiate a switchover by using Enterprise Manager:
1. On the Data Guard page, select the standby database that you want to become the 
primary database.
2. Click Switchover. 
The Data Guard Switchover Confirmation page is displayed.
Oracle Database 11g: Data Guard Administration   10 - 10
Performing a Switchover by Using Enterprise Manager (continued)
3. Click the Browse Primary Database Sessions link to view active sessions.
4. Click Yes to continue with the switchover, or click No to cancel.
You cannot cancel the switchover operation after it begins.
Oracle Database 11g: Data Guard Administration   10 - 11
Performing a Switchover by Using Enterprise Manager (continued)
The Data Guard Switchover Processing page displays the progress of the switchover 
operation as it:
 Switches roles between the primary and standby databases (If the switchover target is a 
physical standby database and mounted, it is opened without restarting. The former 
primary database is restarted.)
 Waits for the Data Guard broker to complete the initialization tasks required to switch the 
database roles.
You can view the database alert log of the primary and standby databases by clicking the 
respective View alert log links. A new browser window opens with the content of the alert 
log.
After the switchover operation is complete, you are returned to the Data Guard page.
Oracle Database 11g: Data Guard Administration   10 - 12
Considerations When Performing a Switchover to a Logical Standby Database
 Unlike a switchover to a physical standby database, a switchover to a logical standby 
database does not require a shutdown of the primary database.
 If you are switching over to a logical standby database, you do not need to terminate 
applications that are connected to the current primary database or to the logical standby 
database, because neither database is shut down during the switchover operation. 
However, because sessions on the old primary database may fail after the switchover 
operation is completed and the database guard is turned on, you should terminate such 
open sessions now. The database guard prevents users from making changes in the 
logical standby database. 
 If you switch over to a logical standby database, be aware that you may not have all of 
the data that was in your primary database if the logical standby database is only a 
subset of the primary database.
 A switchover to a logical standby database invalidates and disables all physical and 
snapshot standby databases in the configuration. You must re-create the physical 
standby databases from a backup of the new primary database before you can reenable 
them.
Oracle Database 11g: Data Guard Administration   10 - 13
Situations That Prevent a Switchover
You cannot perform a switchover if:
 Archived redo log files are unavailable: If there is a gap in the archived redo log files 
on the standby database, you cannot switch over to that standby database. 
 Point-in-time recovery is required: When you perform a switchover to a standby 
database, you always switch over to the current state of the primary database. You 
cannot switch over to a time in the past.
 The production database is not open and cannot be opened: A switchover is 
initiated on the primary database while it is in the open state. If you cannot open the 
primary database, a switchover is not possible.
Oracle Database 11g: Data Guard Administration   10 - 14
Failover
You invoke a failover operation when a failure occurs on the primary database and there is no 
possibility of recovering the primary database in a timely manner. During a failover operation, 
the primary database is disabled from the Data Guard environment and a standby database 
assumes the primary database role. Failing over to a standby database is a one-way 
operation. You cannot "fallback" and return the database to its former role as a standby 
database. Because of this, you should invoke a failover operation only in an emergency.
It is not always necessary to fail over to the standby database. In some cases, recovery of the 
primary database may be faster. Most failures can be resolved at a primary database in a 
reasonable amount of time.
In a failover operation:
 The original primary database is presumed to be lost. (If you want, you can reinstate or 
re-create the original primary database as a new standby database. You may then 
initiate a switchover operation compared to a failover operation to return the databases 
to their original roles.)
 Standby databases that are online at the time of the failover operation, but are not 
involved in the role transition, do not need to be shut down and restarted unless they 
were ahead of the failover target due to differences in apply lag situations. In that case, 
they may need to be flashed back to the point the standby became a primary or re-
created.
Oracle Database 11g: Data Guard Administration   10 - 15
Types of Failovers
A manual failover is invoked through DGMGRL or Enterprise Manager. There are two types of 
manual failover:
 Complete: The maximum amount of redo data for the protection mode is recovered. In 
this type of failover, the broker avoids disabling any standby databases that are not the 
failover target. Complete failover is the default and recommended type of failover.
 Immediate: No additional redo data is applied to the standby database after the failover 
is invoked. This is the fastest type of failover. After an immediate failover, you must re-
create or reinstate the original primary database and all standby databases that were 
not a target of the failover.
Note: You should always try to perform a complete failover. Perform an immediate failover 
only when a complete failover is unsuccessful. Depending on the destination attributes of 
redo transport services, a complete failover can take place without incurring any data loss, 
while an immediate failover usually results in the loss of data.
You can configure fast-start failover so that the broker automatically fails over to a chosen 
standby database in the event of the loss of the primary database. For details, see the lesson 
titled Enabling Fast-Start Failover.
Oracle Database 11g: Data Guard Administration   10 - 16
Failover Considerations
During a failover operation, a standby database transitions to the primary role and the old 
primary database is rendered unable to participate in the configuration. Depending on the 
protection mode under which the old primary database was operating before the failover, 
there may be some or no data loss during a failover. 
A failover is typically used only when a primary database becomes incapacitated and there is 
no possibility of performing a switchover or successfully repairing the primary database in a 
reasonable amount of time. 
The specific actions that are performed during a failover vary, depending on:
 Whether a logical or physical standby database is involved in the failover operation
 The state of the configuration at the time of the failover
 The specific SQL commands that are used to initiate the failover
Oracle Database 11g: Data Guard Administration   10 - 17
Performing a Failover by Using DGMGRL
After determining that the primary database cannot be recovered in a timely manner, execute 
the FAILOVER command to perform the failover operation.
If you specify the IMMEDIATE option, no attempt is made to apply any unapplied redo that 
has been received.
The Data Guard broker performs the following operations for a complete failover:
a. Verifies that the target standby database is enabled
b. Stops Redo Apply after all unapplied redo data is applied to the target standby database
c. Transitions the target standby database to the primary database role by:
- Opening the new primary database in read/write mode
- Determining if any standby databases need to be reinstated or recreated
- Starting redo transport services
For an immediate failover, the broker does not wait for all available redo data to be applied 
(as described in step b). For details about each step, see Oracle Data Guard Broker.
Oracle Database 11g: Data Guard Administration   10 - 18
Reenabling Disabled Databases by Using DGMGRL
After a failover, you may need to reinstate or re-create databases in your configuration.
If a database can be reinstated, the database has the following status after a complete 
failover:
ORA-16661: the standby database needs to be reinstated
Note: To reinstate a database, Flashback Database must have been enabled on the 
database prior to the failover and flashback logs must be available.
To reinstate the database:
1.  Start the database instance and mount the database.
2. Invoke DGMGRL and connect to the new primary database.
3. Use the REINSTATE DATABASE DGMGRL command to reinstate the database.
If a database must be re-created, it has the following status after the failover:
ORA-16795: the standby database needs to be re-created
You must re-create the standby database from a copy of the primary database and then 
reenable it by using the ENABLE DATABASE DGMGRL command.
Oracle Database 11g: Data Guard Administration   10 - 19
Performing a Failover by Using Enterprise Manager
Perform a failover only in the event of a software or system failure that results in the loss of 
the primary database. The failed primary database is disabled by the broker and must be re-
created. The standby database then assumes the primary database role.
To initiate a failover by using Enterprise Manager:
1.  On the Data Guard page, select the standby database that you want to become the 
primary database.
2. Click Failover.
Oracle Database 11g: Data Guard Administration   10 - 20
Performing a Failover with Enterprise Manager (continued)
3. On the Data Guard Failover Confirmation page, specify the type of failover that you want 
to perform:
- Complete: All available redo is applied on the standby database. Oracle 
Corporation recommends that you specify this type of failover.
- Immediate: No additional data is applied on the standby database, resulting in a 
data-loss failover. An immediate failover should be used only when a complete 
failover is not possible.
4. Select the failover option, and click Yes to confirm the failover operation.
.
Oracle Database 11g: Data Guard Administration   10 - 21
Performing a Failover with Enterprise Manager (continued)
After you click Yes, the Failover Processing page displays the progress of the failover 
operation. 
You cannot cancel this operation after it begins.
Oracle Database 11g: Data Guard Administration   10 - 22
Performing a Failover to a Physical Standby Database
During the failover operation, the selected standby database transitions into the primary role. 
The failover target (a physical standby database) is restarted. When the operation finishes, 
the Data Guard Overview page reflects the updated configuration.
After a complete or immediate failover, the primary database and some standby databases 
may need to be reinstated or re-created. To reinstate the database, click the Database must 
be reinstated link. Then click Reinstate on the General Properties page. Enterprise Manager 
reinstates the database as a standby database to the new primary database.
Note: Flashback Database must have been enabled on the database prior to the failover, and 
the required flashback logs must be available on that database for reinstatement to succeed. 
In addition, the database to be reinstated and the new primary database must have network 
connectivity.
Oracle Database 11g: Data Guard Administration   10 - 23
Performing a Failover to a Logical Standby Database
When you perform a failover to a logical standby database, any physical standby databases in 
the configuration are permanently disabled after the failover and are no longer usable. These 
databases must be re-created from the new primary database.
Oracle Database 11g: Data Guard Administration   10 - 24
Answer: a
Oracle Database 11g: Data Guard Administration   10 - 25
Answer: b
Oracle Database 11g: Data Guard Administration   10 - 26
Oracle Database 11g: Data Guard Administration   10 - 27
Oracle Database 11g: Data Guard Administration   10 - 28
Oracle Database 11g: Data Guard Administration   11 - 2
Using Flashback Database in a Data Guard Configuration
Flashback Database provides the following advantages in a Data Guard configuration: 
 Provides an alternative to delaying the application of redo to protect against user errors 
or logical corruptions. By using Flashback Database in this context, standby databases 
are more closely synchronized with the primary database, thereby reducing failover and 
switchover times.
 Eliminates the need to completely re-create the original primary database after a 
failover. The failed primary database can be flashed back to a point in time before the 
failover and converted to be a standby database for the new primary database.
Flashback Database is used in a Data Guard configuration for the following features:
 Fast-start failover: You must enable Flashback Database and set up a fast recovery 
area on the primary database and the target standby database before enabling fast-start 
failover. (See the lesson entitled Enabling Fast-Start Failover for additional 
information.)
 Snapshot standby: To convert a physical standby database to a snapshot standby 
database, you must configure the Fast Recovery Area and size. If Flashback Database 
is not enabled, it will be enabled when the primary database is converted to a snapshot 
standby database. (See the lesson titled Creating and Managing a Snapshot Standby 
Database for additional information.)
Oracle Database 11g: Data Guard Administration   11 - 3
Overview of Flashback Database
With Flashback Database, you can quickly bring your database to an earlier point in time by 
undoing all changes that took place since that time. This operation is fast because you do not 
need to restore backups. You can use this feature to undo changes that resulted in logical 
data corruptions.
When you use Flashback Database, Oracle Database uses past block images to back out 
changes to the database. During normal database operation, Oracle Database occasionally 
logs these block images in flashback logs, which are written sequentially and are not 
archived. Oracle Database automatically creates, deletes, and resizes flashback logs in the 
fast recovery area. You need to be aware of flashback logs only for monitoring performance 
and deciding how much disk space to allocate to the fast recovery area for flashback logs.
The time it takes to rewind a database with Flashback Database is proportional to how far 
back in time you need to go and the amount of database activity after the target time. The 
time it would take to restore and recover the whole database could be much longer. The 
before images in the flashback logs are used only to restore the database to a point in the 
past, and forward recovery is used to bring the database to a consistent state at some time in 
the past. Oracle Database returns data files to the previous point in timebut not auxiliary 
files such as initialization parameter files. 
Flashback Database can also be used to complement Data Guard and Recovery Advisor and 
to synchronize clone databases.
Oracle Database 11g: Data Guard Administration   11 - 4
Configuring Flashback Database
As of Oracle Database 11g Release 2 (11.2), the database can be open when you enable 
flashback. In prior versions, the database had to be mounted after a clean shutdown prior to 
enabling flashback.
1. Configure the fast recovery area.
2. Set the retention target with the DB_FLASHBACK_RETENTION_TARGET initialization 
parameter. 
You can specify an upper limit, in minutes, on how far back you want to be able to flash 
back the database. The example uses 2,880 minutes, which is equivalent to two days. 
This parameter is only a target and does not provide any guarantee. Your flashback time 
interval depends on how much flashback data was kept in the fast recovery area.
3. Enable Flashback Database with the following command:
ALTER DATABASE FLASHBACK ON;
Before you can issue the command to enable Flashback Database, the database must 
be configured for archiving.
Determine whether Flashback Database is enabled with the following query:
SELECT flashback_on FROM v$database;
Disable Flashback Database with the ALTER DATABASE FLASHBACK OFF command. As a 
result, all existing Flashback Database logs are deleted automatically.
Oracle Database 11g: Data Guard Administration   11 - 5
Configuring Flashback Database by Using Enterprise Manager
1. On the Availability page, select Recovery Settings in the Backup/Recovery region. 
2. Ensure that your database is in ARCHIVELOG mode. If not, select ARCHIVELOG Mode.
Oracle Database 11g: Data Guard Administration   11 - 6
Configuring Flashback Database by Using Enterprise Manager (continued)
3. Review the flash recovery area location. 
The flash recovery area is a unified storage location for all recovery-related files and 
activities in an Oracle database. All files that are needed to completely recover a 
database from a media failure are part of the flash recovery area. The recovery-related 
files that can be created in the flash recovery area include archived redo log files, control 
files, backups created by Recovery Manager (RMAN), flashback logs, and the change 
tracking file. By allocating a storage location and unifying recovery-related files in a 
specific area, the Oracle database server relieves the database administrator from 
having to manage the disk files created by these components. If you want it in a different 
location, specify the location in the Flash Recovery Area Location field. 
4. Set the flash recovery size in the Flash Recovery Area Size field.
5. Select Enable Flashback Database. You can also set the flashback retention time, and 
you can view important information regarding your flashback database window.
6. Scroll down to the bottom of the Recovery Settings page, and click Apply.
Note: Flash recovery area has been renamed fast recovery area in Oracle 11g Release 2 
(11.2). Enterprise Manager is still at version 10.2.0.5.2 as of the writing of this course and 
uses the old name.
Oracle Database 11g: Data Guard Administration   11 - 7
Using Flashback Database Instead of Apply Delay
As an alternative to the Apply Delay configuration option, you can use Flashback Database to 
protect against the application of corrupted or erroneous data to the standby database. 
Flashback Database can quickly and easily flash back a standby database to an arbitrary time 
in the past. You can configure one standby database with Flashback Database to achieve the 
same benefit as multiple standby databases with different delays.
Note: Apply delay will be discussed in the lesson titled "Optimizing a Data Guard 
Configuration".
Oracle Database 11g: Data Guard Administration   11 - 8
Using Flashback Database and Real-Time Apply
The Oracle Data Guard real-time apply feature reduces failover time. Flashback Database 
protects a physical standby database from logical data corruption and user error.
The Data Guard broker automatically enables real-time apply.
Oracle Database 11g: Data Guard Administration   11 - 9
Using Flashback Database After RESETLOGS
Physical Standby Configuration
For a physical standby database, it is possible that the Redo Apply service might not halt 
when it encounters the OPEN RESETLOGS command in the redo information. If the physical 
standby databases SCN (system change number) is far enough behind the primary 
databases SCN, then the Redo Apply service can interpret the OPEN RESETLOGS command 
without stopping.
Note: Recall that the recovery through RESETLOGS feature was implemented in Oracle 
Database 10g.
Use the following procedure to avoid re-creating a standby database after you issue an OPEN
RESETLOGS command on the primary database and the managed recovery process is halted 
on the physical standby database:
1. On the primary database, determine an SCN that is at least two SCNs prior to the SCN 
when the OPEN RESETLOGS command was issued. This is necessary to enable the 
standby to recover properly through OPEN RESETLOGS. Use the following query to find 
the before RESETLOGS SCN: 
SELECT TO_CHAR(resetlogs_change# - 2) FROM v$database;
1 2
Oracle Database 11g: Data Guard Administration   11 - 10
Flashback Through Standby Database Role Transitions
Use Flashback Database to revert a database to a point in time before a physical standby 
database switchover or failover. The database role does not change when flashing back 
through a physical standby switchover, failover, or activation. 
In a logical standby database, the FLASHBACK DATABASE command reverts the database to 
a system change number (SCN) or time stamp before a switchover or failover. For a logical 
standby database, the database reverts to its original role at the time of the flashback SCN or 
flashback time. 
You can also use Flashback Database to undo a physical standby activation.
Note: For detailed information about switchover and failover, see the lesson titled Performing 
Role Transitions.
Oracle Database 11g: Data Guard Administration   11 - 12
Using Flashback Database After Failover
You invoke a failover operation when a catastrophic failure occurs on the primary database 
and there is no possibility of recovering the primary database in a timely manner. After a 
failover operation, the old standby database becomes the new primary database, and the old 
primary database is placed in the needs reinstatement state. 
Note: Detail on reinstating the database is provided in the lesson titled Performing Role 
Transitions.
Use the Flashback Database feature to convert the old primary database into a new standby 
database without re-creating the database. You can flash back the old primary database so 
that it contains only those changes that are already applied to the old standby database. This 
enables you to convert the old primary database into a new standby database without 
restoring the old primary database. 
The STANDBY_BECAME_PRIMARY_SCN column in V$DATABASE can provide the SCN 
number corresponding to the failover. The old primary database should use the "FLASHBACK 
DATABASE TO SCN .."  command to rewind to this point. It can then be converted into a 
standby database with the SQL command "ALTER DATABASE CONVERT TO PHYSICAL 
STANDBY". 
Note: You must enable the Flashback Database feature on the old primary database prior to 
the failover.
1
2
Oracle Database 11g: Data Guard Administration   11 - 13
Answer: b
Oracle Database 11g: Data Guard Administration   11 - 14
Oracle Database 11g: Data Guard Administration   11 - 15
Oracle Database 11g: Data Guard Administration   11 - 16
Oracle Database 11g: Data Guard Administration   12 - 2
Fast-Start Failover: Overview
Fast-start failover enables Data Guard to rapidly and automatically fail over to a previously 
chosen standby database without requiring manual intervention. This feature increases the 
availability of your database in the event of a disaster by reducing the need for you to perform 
a failover operation manually.
The observer is an Oracle Call Interface (OCI) client-side component that typically runs on a 
separate computer and monitors the availability of the primary database.
Oracle Database 11g: Data Guard Administration   12 - 3
When Does Fast-Start Failover Occur?
Fast-start failover occurs when any of the following conditions are met:
 Loss of connectivity between both the primary database and the observerand 
between the primary database and the fast-start failover target standby database
exceeds the fast-start failover threshold.
 The database health-check mechanism determines any of the following (as optionally 
configured):
- A data file is offline because of a write error.
- Dictionary corruption of a critical database object occurs.
- Control file is permanently damaged because of a disk failure.
- LGWR is unable to write to any member of the log group because of an I/O error.
- Archiver is unable to archive a redo log because the device is full or unavailable.
 An instance crash occurs for a single-instance database.
 All instances of a Real Application Clusters (RAC) primary database crash.
 Shutdown abort of the primary database occurs.
 An application initiates a fast-start failover by calling the 
DBMS_DG.INITIATE_FS_FAILOVER function.
Oracle Database 11g: Data Guard Administration   12 - 4
Installing the Observer Software
To use fast-start failover, you should install the DGMGRL program (which contains the 
observer software) on a computer system that is separate from the primary database and 
standby database systems.
To install DGMGRL on the observer computer, use one of the following methods:
 Install the complete Oracle Client Administrator by choosing the Administrator option in 
the Oracle Universal Installer. This installation includes DGMGRL but it does not include 
the Oracle Enterprise Manager agent. This type of installation enables you to manage 
the observer by using DGMGRL commands but not Oracle Enterprise Manager.
 Install the full Oracle Database software kit. This installation includes DGMGRL.
Note: To manage the observer from Oracle Enterprise Manager (EM) Grid Control, the EM 
Grid Control agent will need to be installed on the observer machine in addition to DGMGRL.
The observer host should be located on the client network or the location that contains the 
most client activity or highest priority activity.  This method could introduce a false failover, 
that is a fast-start failover occurs even though the primary is running and accessible locally, 
but if the clients can't get to the primary it may as well be down.
Oracle Database 11g: Data Guard Administration   12 - 5
Fast-Start Failover Prerequisites
 The broker configuration must be operating in maximum availability or maximum 
performance mode.
 The primary database must be configured with standby redo log files. 
 The standby database that is the target of fast-start failover must have its LogXptMode
property set to SYNC to enable fast-start failover in maximum availability mode or to 
ASYNC to enable fast-start failover in maximum performance mode.
 Flashback Database must be enabled on the primary database and target standby 
database.
 The primary database and target standby database must have connectivity.
 Configure the tnsnames.ora file on the observer system so that the observer is able to 
connect to the primary database and the preselected target standby database.
 Create a static service name so that the observer can automatically restart a database 
as part of reinstatement.
Oracle Database 11g: Data Guard Administration   12 - 6
Configuring Fast-Start Failover
The manual steps to configure fast-start failover are described in detail on the next few pages. 
Configuring fast-start failover by using Enterprise Manager Grid Control is described later in 
the lesson.
Oracle Database 11g: Data Guard Administration   12 - 7
Step 1: Specify the Target Standby Database
In a Data Guard configuration with multiple standby databases, you must set the 
FastStartFailoverTarget database property on the primary database and your chosen 
target standby database before enabling fast-start failover.
On the primary database, set the FastStartFailoverTarget property to the fast-start 
failover target standby database. Execute the command when connected to the primary 
database or to any standby database in the configuration that has connectivity to the primary 
database. The command syntax is:
EDIT DATABASE database-name
SET PROPERTY FastStartFailoverTarget = FSFO-database-name; 
You need not set the FastStartFailoverTarget property in a configuration with only one 
standby database: The Data Guard broker automatically sets it appropriately for the primary 
database and the standby database when fast-start failover is enabled.
Oracle Database 11g: Data Guard Administration   12 - 8
Step 2: Set the Protection Mode
You can enable fast-start failover when the configuration is in maximum availability mode or 
maximum performance mode. For details about each mode, see the lesson titled Configuring 
Data Protection Modes.
In maximum performance mode, set the FastStartFailoverLagLimit configuration 
property to an acceptable limit (in seconds) by which the standby database is permitted to fall 
behind the primary database in terms of redo applied. If the standby database is further 
behind than this value, fast-start failover is not allowed.
Oracle Database 11g: Data Guard Administration   12 - 9
Step 3: Set the Fast-Start Failover Threshold
The fast-start failover threshold specifies how long the observer and target standby database 
should simultaneously wait to hear from the primary database before initiating a fast-start 
failover. The threshold value is specified as a positive, nonzero number of seconds. The 
default value for the FastStartFailoverThreshold property is 30 seconds. When 
choosing a value for this property, you must balance the increased risk of an unnecessary 
failover (for example, if the network connection was temporarily broken for a few seconds) 
against the benefits of faster failover and less down time during a critical outage.
Recommended settings for the FastStartFailoverThreshold property:
 Single-instance primary, low-latency reliable network = 1015 seconds
 Single-instance primary, high-latency network over WAN = 3045 seconds
 RAC primary = (CSS misscount + reconfiguration time) + (2440 seconds)
Execute the EDIT CONFIGURATION SET PROPERTY FastStartFailoverThreshold =
threshold-val command when connected to the primary database or to any standby 
database in the Data Guard broker configuration with connectivity to the primary database.
Note: You can modify this property whether fast-start failover is enabled or disabled.
Oracle Database 11g: Data Guard Administration   12 - 10
Step 4: Set Additional Fast-Start Failover Properties
You can set additional properties to control fast-start failover operation. 
The FastStartFailoverPmyShutdown property enables users to decide whether the 
primary database shuts down if redo generation has stalled and the primary database has lost 
connectivity with the observer and target standby database for longer than the value specified 
in FastStartFailoverThreshold. Redo generation stalls because the primary database 
has lost connectivity to both the observer and the target standby database concurrently. This 
property cannot be used to prevent the primary database from shutting down if a fast-start 
failover occurred because a user-configurable condition was detected or was requested by an 
application calling the DBMS_DG.INITIATE_FS_FAILOVER function.
The FastStartFailoverAutoReinstate property enables users to decide whether the 
old primary database should be automatically reinstated if a fast-start failover was initiated 
because it lost connectivity with the observer and target standby database for longer than the 
value specified in FastStartFailoverThreshold. This property cannot be used to cause 
automatic reinstatement if a fast-start failover occurred because a user-configurable condition 
was detected or was requested by an application calling the 
DBMS_DG.INITIATE_FS_FAILOVER function.
Note: Each of these three properties is discussed in more detail on the following pages.
Oracle Database 11g: Data Guard Administration   12 - 11
Setting the Lag-Time Limit
You can configure fast-start failover for configurations operating in maximum performance 
protection mode. Use the FastStartFailoverLagLimit property to specify an acceptable 
lag-time limit in seconds. If the standby databases applied redo point is within the specified 
number of seconds of the primary databases redo generation point, a fast-start failover is 
allowed. If the standby databases applied point lags beyond this limit, a fast-start failover is 
not allowed. The lag limit is ignored for SYNC destinations. This is applicable only to 
configurations when fast-start failover is enabled in maximum performance modes.
Real-time apply must be enabled on the target standby database to ensure a valid calculation 
of the lag time. 
Configure the FastStartFailoverLagLimit property as follows: 
EDIT CONFIGURATION 
SET PROPERTY FastStartFailoverLagLimit = {n};
The minimum value for n is 10. The default value is 30.
You can perform a manual failover to a maximum performance fast-start failover target. The 
maximum performance failover target must be within the specified lag limit of the primary 
database for the failover to be allowed. If the failover target is more than the specified lag limit 
behind the primary database, an error is returned.
Oracle Database 11g: Data Guard Administration   12 - 12
Configuring the Primary Database to Shut Down Automatically 
If you do not want the old primary database to shut down automatically after a fast-start 
failover is triggered due to the primary redo generation being stalled and the primary database 
loosing connectivity with the observer and target standby database for longer than the number 
of seconds specified by the FastStartFailoverThreshold configuration property , set 
the FastStartFailoverPmyShutdown property to FALSE. When the property is set to 
FALSE, the old primary database stalls awaiting diagnosis of the condition that caused the 
fast-start failover.
DGMGRL> edit configuration set property
> FastStartFailoverPmyShutdown = false;
Property "faststartfailoverpmyshutdown" updated
A value of TRUE causes the primary database to shut down with the ABORT option after the 
elapse of the number of seconds specified in the FastStartFailoverThreshold property 
and the primary database has no contact from its fast-start failover partners. TRUE is the 
default.
Note: The primary database is always shut down if a user configurable fast-start failover 
condition is detected or if an application initiated a fast-start failover by calling the 
DBMS_DG.INITIATE_FS_FAILOVER function even if FastStartFailoverPmyShutdown
is set to FALSE.
Oracle Database 11g: Data Guard Administration   12 - 13
Automatic Reinstatement After Fast-Start Failover
Reinstatement of the original primary database is critical for reestablishing high availability 
after a fast-start failover. The original primary database can act as the fast-start failover target 
standby database for the new primary database after being reinstated as a standby database. 
Unless you reconfigure the fast-start failover environment, you cannot perform a subsequent 
fast-start failover until the original primary database is reinstated. 
Automatic reinstatement of the original primary database is triggered when all of the following 
conditions are met:
 FastStartFailoverAutoReinstate is set to TRUE.
 The original primary database and the new primary database comprise the same fast-
start failover configuration before the failover occurs and after the original primary 
database restarts.
 In a multi-standby database configuration, you have not performed a subsequent 
failover or switchover before the original primary database restarting.
 The observer can connect to the original primary database.
 The original primary database must be able to connect to the new primary database to 
complete the reinstatement operation.
Oracle Database 11g: Data Guard Administration   12 - 14
Configuring Automatic Reinstatement of the Primary Database
The FastStartFailoverAutoReinstate property enables you to determine whether the 
observer should automatically reinstate the old primary database after a fast-start failover. In 
some fast-start failover situations, you may want to diagnose the cause of the fast-start 
failover before reinstating the primary database; you should set the property to FALSE. The 
default value is TRUE.
DGMGRL> edit configuration set property
> FastStartFailoverAutoReinstate = false;
Property "faststartfailoverautoreinstate" updated
DGMGRL> show fast_start failover
Fast-Start Failover: ENABLED
Threshold:        90 seconds
Target:           pc01sby1
Observer:         EDBVR6P2
Lag Limit:        60 seconds
Shutdown Primary: TRUE
Auto-reinstate:   FALSE
Oracle Database 11g: Data Guard Administration   12 - 16
Setting a Connect Identifier for the Observer
Use the ObserverConnectIdentifier configurable database property to specify how the 
observer should connect to and monitor the primary and standby database. Set this property 
for the primary and target standby database if you want the observer to use a different 
connect identifier than the one that is used to ship redo data (that is, the connect identifier 
specified by the DGConnectIdentifier property).
Oracle Database 11g: Data Guard Administration   12 - 17
Step 5: Configure Additional Fast-Start Failover Conditions
Use the ENABLE/DISABLE FAST_START FAILOVER broker commands to specify the 
conditions under which a fast-start failover should occur. The Oracle Database server detects 
when a specified condition occurs and informs the observer. The observer initiates a fast-start 
failover without waiting for FastStartFailoverThreshold to expire (if the standby is in a 
valid fast-start failover state to accept a failover).
Use the SHOW FAST_START FAILOVER command to obtain a list of valid conditions and 
confirm your changes. They include the following:
Configurable Failover Conditions
Health Conditions:
Corrupted Controlfile          YES
Corrupted Dictionary           YES
Inaccessible Logfile            NO
Stuck Archiver                  NO
Datafile Offline               YES
Oracle Error Conditions
(none)
Oracle Database 11g: Data Guard Administration   12 - 18
Configuring Fast-Start Failover Conditions
Additional database health conditions for a fast-start failover are displayed in the table. 
The conditions Datafile Offline, Corrupted Controlfile, and Corrupted
Dictionary are enabled by default. An error is returned if the value you specify is not 
recognized. 
If the condition was already set, no error is displayed.
Example: Enable a database health condition for a fast-start failover:
DGMGRL> enable fast_start failover condition "Inaccessible 
Logfile"
DGMGRL> show fast_start failover