Oracle® Data Guard Broker 10g Release 1 (10.1) Part Number B10822-01 |
|
|
View PDF |
The Data Guard command-line interface enables you to manage a Data Guard broker configuration and its databases directly from the command line, or from batch programs or scripts. You can use the Data Guard command-line interface as an alternative to the Data Guard graphical user interface (GUI), integrated with Oracle Enterprise Manager, for managing a Data Guard configuration.
This chapter provides reference information for the Data Guard command-line interface.
To run the Data Guard command-line interface, you must have SYSDBA privileges.
Start the command-line interface by entering DGMGRL
at the command-line prompt on a system where Oracle is installed:
% DGMGRL DGMGRL for Solaris: Version 10.1 Copyright (c) 2000, 2003 Oracle. All rights reserved. Welcome to DGMGRL, type "help" for information. DGMGRL>
You can supply optional parameters on the command line to indicate how you want the Data Guard command-line interface to display output such as command prompts, banners, and messages.
Additionally, a single command mode is available. In this mode, DGMGRL executes one command and exits upon the completion of the command. The exit code is the result of the command. If the exit code is 0, the command completed successfully. Otherwise, there was an error.
The command line of DGMGRL appears as follows:
% DGMGRL [<options>] [<logon> [<command>] ]
Specify none, one, or all of the following keywords when you invoke the DGMGRL command-line interface:
<options>
can be one of the following choices:
-echo
Displays command input and output to the default display device. If you do not use this parameter, only the output from the command is displayed.
-silent
Suppresses the display of the DGMGRL (DGMGRL>
) command prompt on your default display device. This option is useful if you are directing the command output to a file or to another display tool.
<logon>
is:
username/password [@connect-identifier]
The username
and password
with which you want to connect to the database. The connect-identifier
is a fully specified connect descriptor or a name to be resolved by an Oracle naming method (for example, TNS). The connect-identifier
is optional.
<command>
is a single command.
For example:
% DGMGRL sys/knl_test7@primary "show database db"
The following subsections specify the command format that you enter at the DGMGRL>
command prompt.
The DGMGRL commands allow you to create and maintain one broker configuration at a time. A broker configuration can consist of a primary database and up to 9 standby databases.
After you invoke the command-line interface, you can enter any of the DGMGRL commands listed in Table 7-1. Each command and its associated parameters are described in detail in later sections of this chapter.
Table 7-1 Summary of DGMGRL Commands
Command | Effect |
---|---|
ADD DATABASE |
Adds a new standby database profile to the existing broker configuration. |
CONNECT |
Connects to the specified database using the specified username. |
CREATE CONFIGURATION |
Creates a broker configuration and creates and adds a primary database profile to the configuration. |
DISABLE CONFIGURATION |
Disables broker management of a configuration so that the configuration and all of its databases are no longer managed by the broker. |
DISABLE DATABASE |
Disables broker management of the named standby database. |
EDIT CONFIGURATION (Protection Mode) |
Changes the current protection mode setting for the broker configuration. |
EDIT DATABASE (Property) |
Changes the value of a property for the named database. |
EDIT DATABASE (Rename) |
Changes the name used by the broker to refer to the specified database. |
EDIT DATABASE (State) |
Changes the state of the specified database. |
EDIT INSTANCE (AUTO PFILE) |
Sets the name of the initialization parameter file for the specified instance. |
EDIT INSTANCE (Property) |
Changes the value of a property for the specified instance. |
ENABLE CONFIGURATION |
Enables broker management of the broker configuration and all of its databases. |
ENABLE DATABASE |
Enables broker management of the specified database. |
EXIT |
Exits the Data Guard command-line interface. |
FAILOVER |
Performs a database failover operation in which the standby database, to which the CLI is currently connected, fails over to the role of primary database. |
HELP |
Displays online help for the Data Guard command-line interface. |
QUIT | Quits the Data Guard command-line interface. |
REMOVE CONFIGURATION |
Removes the broker configuration including all of its database profiles from the broker configuration file. |
REMOVE DATABASE |
Removes the specified standby database profile from the broker configuration. |
REMOVE INSTANCE |
Removes knowledge of an instance from an existing database profile in the broker configuration. |
SHOW CONFIGURATION |
Displays information about the broker configuration. |
SHOW DATABASE |
Displays information about the specified database. |
SHOW INSTANCE |
Displays information about the specified instance. |
SHUTDOWN |
Shuts down a currently running Oracle database. |
STARTUP |
Starts an Oracle instance with the same options as SQL*Plus, including mounting and opening a database. |
SWITCHOVER |
Performs a switchover operation in which the current primary database becomes a standby database, and the specified standby database becomes the primary database. |
Note: Existing Oracle9i command-line scripts are supported in Oracle Database 10g for non-RAC databases. See Appendix A for information about deprecated commands. |
To use the Data Guard command-line interface, the following must be true:
The DG_BROKER_START
dynamic initialization parameter is set to true
.
To enable broker operations that require restarting instances without manual intervention, Oracle Net Services must be configured on each of the hosts that contain the primary and standby database instances. Specifically, the listener.ora file must contain static configuration information about the instance. The GLOBAL_DBNAME
attribute must be set to db_unique_name
_DGMGRL.
db_domain
. See Chapter 6 for additional information.
The net service name, if used, must be resolvable from any of the hosts in the configuration.
See Also: Section 1.7.5 for information about the listener prerequisites. Chapter 6 for more information about preparing and starting Oracle Data Guard broker. See the Oracle Database Administrator's Guide for more information about setting up the network files and listener on the standby database. |
You must have SYSDBA privileges to use the Data Guard command-line interface. Do not include AS SYSDBA
on the CONNECT
command because SYSDBA is the default setting for this command.
The password for SYS needs to be identical on all databases, and all databases should use the remote password file (either SHARED or EXCLUSIVE).
A semicolon is required at the end of each DGMGRL command.
Characters specified in a DGMGRL command string value are interpreted as lowercase characters, unless enclosed in double (") or single (') quotation marks. For example, database and DatAbaSe are equivalent, but "database" and "DatAbaSe" are distinctive.
You can use the backslash (\) to escape a single quotation mark ('), a double quotation mark ("), and the backslash character (\) itself if these characters appear in a character string.
Some operations on a broker configuration may require that one or more databases be shut down and restarted. In most cases, the CLI will automatically shut down and restart a given database for you if the following are true:
The instance-name
is the SID (this applies for the GUI as well as the CLI).
The broker must be able to connect to the database using the username and password given in the last CONNECT
command, even if the last CONNECT
command was used to connect to another database. Thus, the remote password file for the database must contain the username and password given in the last CONNECT
command.
See Also: Oracle Database Administrator's Guide for more information about setting up remote password files and the default location of the PFILE and SPFILE initialization parameter files. |
Example 1
This example demonstrates how to connect to the DGMGRL command-line interface on a local system.
% DGMGRL Welcome to DGMGRL, type "help" for information. DGMGRL> CONNECT sys/change_on_install; Connected.
Example 2
This example demonstrates how to connect to the Data Guard (DGMGRL) command-line interface on a remote system.
DGMGRL> CONNECT sys/change_on_install@remote-stby; Connected.
When you are done working with the command-line interface and want to return to the operating system, enter the EXIT
or QUIT
command at the DGMGRL command prompt. For example:
DGMGRL> EXIT;
Creates a new standby database profile and adds it to the existing broker configuration. The standby database type (physical or logical) is specified by the MAINTAINED AS
clause.
Format
ADD DATABASE database-name AS
CONNECT IDENTIFIER IS connect-identifier
MAINTAINED AS {PHYSICAL | LOGICAL};
Command Parameters
The name that will be used by the broker to refer to this standby database. It must match (case-insensitive) the value of the corresponding database DB_UNIQUE_NAME
initialization parameter.
A fully specified connect descriptor or a name to be resolved by an Oracle Net Services naming method (for example, TNS).
Usage Notes
You must connect to the primary database to issue this command.
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 you use tnsnames.ora files to resolve the connect-identifier
, you must ensure it will be resolved to the same connect descriptor at all tnsnames.ora files and the resulting connect descriptor can be used to reach the database specified in this ADD DATABASE
command.
If the connection cannot be made, the broker does not add the new database to the configuration.
Command Example
The following example shows how to add a database named DR_Sales
.
DGMGRL> ADD DATABASE 'DR_Sales' AS > CONNECT IDENTIFIER IS DR_Sales.foo.com > MAINTAINED AS PHYSICAL; Database "DR_Sales" added.
Connects a given username to the specified database.
Format
CONNECT username/password [@connect-identifier];
Command Parameters
Represents the username and password with which you want to connect to the database.
Consists of the Oracle Net Services connect identifier of the database to which you want to connect. The exact syntax depends upon the Oracle Net Services communications protocol your Oracle installation uses.
Usage Notes
The username and password must be valid for the database to which you are trying to connect. The username you specify must have the SYSDBA privilege. You do not have to include AS SYSDBA
on the CONNECT
command because SYSDBA is the default setting for this command.
If the CONNECT
command returns an error, check to see that you specified a valid connect-identifier
.
Command Examples
Example 1
This example connects to the default database on the local system.
DGMGRL> CONNECT sys/change_on_install; Connected.
Example 2
This example connects to a remote database whose connect-identifier
is prmy
.
DGMGRL> CONNECT sys/change_on_install@prmy; Connected.
Creates a new broker configuration, and creates and adds a primary database profile to the configuration.
Format
CREATE CONFIGURATION configuration-name AS
PRIMARY DATABASE IS database-name
CONNECT IDENTIFIER IS connect-identifier;
Command Parameters
A user-friendly name for the configuration you are creating. Valid names contain any alphanumeric characters. If spaces are included in the name, the name must be enclosed in double or single quotation marks. The name must consist of 30 or fewer bytes.
The name that will be used by the broker to refer to the primary database. It must match (case-insensitive) the value of the corresponding database DB_UNIQUE_NAME
initialization parameter.
A fully specified connect descriptor or a name to be resolved by an Oracle Net Services naming method (for example, TNS).
Usage Notes
A broker configuration is a named collection of one or more databases that you want to manage as a group. You must specify a value for each of the command parameters. There are no default values.
You must connect to the primary database to issue this command.
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 you use tnsnames.ora files to resolve the connect-identifier
, you must ensure it will be resolved to the same connect descriptor at all tnsnames.ora files and the resulting connect descriptor can be used to reach the primary database specified in this CREATE CONFIGURATION
command.
To add standby databases after you create the broker configuration, use the ADD DATABASE command.
Command Example
The following example creates a new broker configuration named DRSolution
with a primary database named North_Sales
.
DGMGRL> CREATE CONFIGURATION 'DRSolution' AS > PRIMARY DATABASE IS 'North_Sales' > CONNECT IDENTIFIER IS North_Sales.foo.com; Configuration "DRSolution" created with primary database "North_Sales".
Disables broker management of a configuration so that the configuration and all of its databases are no longer managed by the broker.
Format
DISABLE CONFIGURATION;
Command Parameters
None.
Usage Notes
A disabled configuration and all of its constituent databases are no longer managed by the broker.
The only way to disable broker management of the primary database is to use the DISABLE CONFIGURATION
command.
This command does not remove the broker configuration. See the REMOVE CONFIGURATION command for more information about removing the configuration.
You can edit database properties and modify the configuration's protection mode while the configuration is disabled. However, any changes made to properties or to the protection mode will not take effect until the configuration is enabled.
Command Example
The following example disables management of the broker configuration and all of its databases.
DGMGRL> DISABLE CONFIGURATION; Disabled.
Disables broker management of the named standby database. This means that broker directed state changes will be disallowed for this database, and the broker will not monitor the database for health status or for monitorable property values.
Format
DISABLE DATABASE database-name;
Command Parameter
Name of the standby database to be disabled.
Usage Notes
You cannot specify the name of a primary database.
Use the DISABLE CONFIGURATION
command to disable the primary and all standby databases.
If the sole standby database is disabled, you have no failover option. This standby database is not viable for failover until it is reenabled.
Command Example
The following example shows how to disable a database named DR_Sales
.
DGMGRL> DISABLE DATABASE 'DR_Sales'; Disabled.
Edits the current protection mode setting for the broker configuration.
Format
EDIT CONFIGURATION SET PROTECTION MODE AS protection-mode;
Command Parameter
The data protection mode in which you want the configuration to run when the configuration is enabled. The possible protection modes are:
MAXPROTECTION
MAXAVAILABILITY
MAXPERFORMANCE
Usage Notes
Before you use the EDIT CONFIGURATION
command to set the protection mode to either the MAXPROTECTION
or MAXAVAILABILITY
mode, ensure that standby redo log files are configured on a standby database.
The following table shows the configuration protection modes and the minimum corresponding settings for log transport services:
Protection Mode | Log Transport Mode | Standby Redo Log Files Needed? |
---|---|---|
MAXPROTECTION |
SYNC |
Yes |
MAXAVAILABILITY |
SYNC |
Yes |
MAXPERFORMANCE |
ARCH or ASYNC |
Yes for ASYNC |
The default protection mode for the configuration is MAXPERFORMANCE
.
After you change the protection mode, the primary database will automatically restart, if necessary.
Use the SHOW CONFIGURATION
command to display the current protection mode for the configuration.
DGMGRL> SHOW CONFIGURATION; Configuration Name: DRSolution Enabled: YES Protection Mode: MaxPerformance Databases: North_Sales - Primary database DR_Sales - Physical standby database Current status for "DRSolution": SUCCESS
If broker management of the configuration is disabled when you enter the EDIT CONFIGURATION
command, the protection mode of the configuration does not take effect until the next time you enable the configuration with the ENABLE CONFIGURATION command.
Command Example
The following example shows how to upgrade the broker configuration to the MAXPROTECTION
protection mode. The broker configuration will have the maximum amount of data protection after these commands complete.
Verify that standby redo log files are configured on the standby database and that the log transport mode is set to SYNC
, for example:
DGMGRL> EDIT DATABASE 'DR_Sales' SET PROPERTY 'LogXptMode'='SYNC'; Property "LogXptMode" updated. DGMGRL> EDIT CONFIGURATION SET PROTECTION MODE AS MAXPROTECTION; Operation requires shutdown of instance "sales1" on database "North_Sales". Shutting down instance "sales"... Database closed. Database dismounted. ORACLE instance shut down. Operation requires startup of instance "sales1" on database "North_Sales". Starting instance "sales1"... ORACLE instance started. Database mounted.
The broker automatically stops and restarts the primary database.
Changes the value of a property for the named database.
Format
EDIT DATABASE database-name
SET PROPERTY property-name = value;
Command Parameters
The name of the database for which you want to change a property value.
The name of an existing database-specific property. If this is a RAC database, this property change affects all instances of the database.
The new value for the property.
Caution: This command can be used to change the value of a per-instance property if and only if just one instance is known by the broker for the named database. An attempt to use this command to change a per-instance property when the broker knows of multiple instances of the database will be rejected. It is recommended to only useEDIT INSTANCE (property) to change the value of a per-instance property. |
Command Examples
Example 1
Edit a database level property.
DGMGRL> EDIT DATABASE 'North_Sales' SET PROPERTY 'ArchiveLagTarget'=1200; Property "ArchiveLagTarget" updated.
Example 2
Edit an instance level property of a non-RAC database.
DGMGRL> EDIT DATABASE 'DR_Sales' SET PROPERTY > 'StandbyArchiveLocation'='/archfs/arch/'; Property "StandbyArchiveLocation" updated.
Example 3
Edit an instance level property of a RAC database. This will not succeed because it is not clear to which instance the property change should be applied.
DGMGRL> EDIT DATABASE 'North_Sales' SET PROPERTY > 'StandbyArchiveLocation'='/archfs/arch/'; Error: ORA-16587: Ambiguous object specified to Data Guard broker Failed.
Changes the name used by the broker to refer to the specified database, as recorded in that database's profile in the broker configuration.
Format
EDIT DATABASE database-name
RENAME TO new-database-name;
Command Parameters
The name of the database that you want to change.
The name of the new database.
Usage Notes
Use this command to track changes to the DB_UNIQUE_NAME
initialization parameter for this database.
Caution: The |
This command can only be done when broker management of the database that you are renaming is disabled.
Command Example
The following example shows how to edit and rename a database.
DGMGRL> EDIT DATABASE 'DR_Sales_typo' RENAME TO 'DR_Sales'; Succeeded. DGMGRL> ENABLE DATABASE 'DR_Sales'; Enabled.
Changes the state of the specified database.
Format
EDIT DATABASE database-name
SET STATE = state
[WITH APPLY INSTANCE = instance-name];
Command Parameters
The name of the database for which you want to change the state.
The state in which you want the database to be running. The possible states are:
ONLINE
LOG-TRANSPORT-OFF
(primary database only)LOG-APPLY-OFF
(standby database only)READ-ONLY
(physical standby database only)OFFLINE
The name of the instance you want to become the apply instance if this is a RAC standby database.
Usage Notes
If the target state is ONLINE
and this database is currently in the standby role, the optional WITH APPLY INSTANCE
clause specifies which instance will become the apply instance.
If the target state is not ONLINE
or if the database is currently in the primary role, the WITH APPLY INSTANCE
clause is ignored even if it is specified.
All instances of a RAC database are affected by this database state change.
Command Example
The following example shows how to change the state of a database.
DGMGRL> EDIT DATABASE 'DR_Sales' SET STATE='READ-ONLY'; Succeeded. DGMGRL> EDIT DATABASE 'North_Sales' SET STATE='OFFLINE'; Operation requires shutdown of instance "sales1" on database "North_Sales". Shutting down instance "sales1"... Database closed. Database dismounted. ORACLE instance shut down.
Sets the name of the initialization parameter file for the specified instance.
Format
EDIT INSTANCE instance-name
[ON DATABASE database-name]
SET AUTO PFILE [= { initialization-file | OFF } ];
Command Parameters
The name of the instance (SID) for which you want to specify its initialization parameter file.
The name of the database to which the instance-name
is associated.
Executes the startup operation for the instance when a subsequent broker operation requires the instance to be started automatically. If SET AUTO PFILE
is set to OFF
, automatic restart of that instance is disabled. When a subsequent operation needs to start that instance, you must start it manually. If you do not specify SET AUTO PFILE
for the instance, the automatic startup operation looks for the initialization parameter file at the default location.
Usage Notes
The instance-name
can be unique across the configuration. If instance-name
is not unique, you must specify both the database-name
and the instance-name
to fully identify the instance.
SET AUTO PFILE
is valid only for the duration of the current DGMGRL session. You must specify SET AUTO PFILE
again if you quit and reenter DGMGRL.
Command Example
The following example shows how to edit an instance of a database.
DGMGRL> EDIT INSTANCE 'dr_sales1' ON DATABASE 'DR_Sales' > SET AUTO PFILE='initsales1.ora'; Instance 'dr_sales1' updated.
Changes the value of a property for the specified instance.
Format
EDIT INSTANCE instance-name
[ON DATABASE database-name]
SET PROPERTY property-name = value;
Command Parameters
The name of the instance (SID) for which you want to change a per-instance property value.
The name of the database to which the instance-name
is associated.
The name of the per-instance property for which you want to set a new value.
The new value for the property.
Usage Notes
The instance-name
can be unique across the configuration. If instance-name
is not unique, you must specify both the database-name
and the instance-name
to fully identify the instance.
This command cannot be used to change a database-specific property.
Command Examples
Example 1
Edit an instance level property.
DGMGRL> EDIT INSTANCE 'sales1' ON DATABASE 'North_Sales' > SET PROPERTY 'StandbyArchiveLocation'='/archfs/arch/'; Property "StandbyArchiveLocation" updated.
Example 2
Edit a database level property. This will not be allowed.
DGMGRL> EDIT INSTANCE 'sales1' ON DATABASE 'North_Sales' > SET PROPERTY 'LogXptMode'='SYNC'; Error: ORA-16586: Could not edit database property through instance. Failed.
Enables the broker to actively manage the broker configuration including all of its databases.
Format
ENABLE CONFIGURATION;
Command Parameters
None.
Usage Notes
Use this command to enable broker management of the primary database.
By default, broker management of the configuration's databases is enabled in the ONLINE
state with log transport services turned on at the primary database and log apply services turned on at the standby databases. You can change the state of any database using the EDIT DATABASE (State) command, but not when the database or the entire configuration is disabled.
Use the SHOW CONFIGURATION command to display information about the configuration.
Command Example
The following example enables management of a broker configuration.
DGMGRL> ENABLE CONFIGURATION; Enabled.
Enables broker management of the specified standby database.
Caution: Do not issue theENABLE DATABASE command on a standby database that needs to be re-created until it has been re-created as described in Section 4.2.5. |
Format
ENABLE DATABASE database-name;
Command Parameter
The name of the standby database for which you want to enable broker management.
Usage Notes
A standby database may have been disabled by the broker as a consequence of a prior failover or switchover operation. Recovery of the database is required as described in Section 4.2.5 before this command should be issued.
By default, broker management of the standby database is enabled in the ONLINE
state with log apply services enabled. You can change the state of the standby database using the EDIT DATABASE (State) command, but only when the database is enabled.
Use the SHOW DATABASE command to display information about the database.
For a RAC database, only one instance is required to be started and mounted for this command to succeed.
Command Example
The following example shows how to enable a database named DR_Sales
.
DGMGRL> ENABLE DATABASE 'DR_Sales'; Enabled.
Exits (quits) the command-line interface.
Format
EXIT;
Command Parameters
None.
Usage Notes
This command has the same effect as the QUIT command.
A database connection is not required to execute this command. However, if you are connected, this command breaks the connection.
Command Example
The following example demonstrates how to exit (quit) the command-line interface.
DGMGRL> EXIT;
A failover operation changes the named standby database into the role of a primary database.
Note: Because a failover results in a role transition that may result in the loss of application data, you should perform a failover only if the primary database failed. If you want the current primary database and a standby database to switch roles, then use the SWITCHOVER command. |
Format
FAILOVER TO database-name
[ IMMEDIATE ];
Command Parameters
The name of the standby database you want to fail over to the primary database role.
Usage Notes
To be considered a viable candidate for the failover operation, the specified standby database must be enabled before the primary fails. However, an enabled standby database that was taken offline can be a candidate for the failover operation. In this case, restart the standby database using the CLI STARTUP
command, then issue the FAILOVER
command.
The failover operates on the specified database. Thus, the failover changes one of the standby databases into the role of a primary database. Any other standby databases not involved in the failover remain in the standby role.
Before you issue the FAILOVER
command, verify that you are connected to the standby database that will become the new primary database. If necessary, issue a CONNECT command to connect to the standby database.
If the FAILOVER
command is issued without any options, the standby database chosen as the failover target recovers all log files received before changing to the primary role.
If the standby database that you want to fail over to the primary role is a RAC database, the broker will shut down all of the instances except the apply instance before it continues the failover operation. The broker will restart instances that it shut down prior to the failover. See Section 4.2 for details.
If the standby database that is transitioning into the role of primary database is a physical standby database, then the database instance (or instances) will be restarted after the failover completes. If the database is a logical standby database, the database instance (or instances) does not need to be restarted.
If the broker configuration is in either MAXPROTECTION
or MAXAVAILABILITY
protection mode, the failover operation will force the protection mode to be MAXPERFORMANCE
. The log transport mode settings are unaffected. You need to restore the desired protection mode for the resulting configuration after the failover operation.
If the FAILOVER
command is issued with the IMMEDIATE
option, no attempt is made to recover available log files. This option more likely results in lost application data even when standby redo log files are configured on the standby database. Additionally, any remaining standby databases in the configuration cannot function as such until they are re-created.
The original primary database can only participate in the configuration as a standby database after it is re-created.
Caution: You should shut down the original primary database if it still has any active instances running. |
See Also: Section 4.2.5 about re-creating the original primary database so that it could serve as a standby database to the primary database |
Command Examples
The following example performs a failover in which the standby database, DR_Sales
, transitions to the primary role:
DGMGRL> FAILOVER TO "DR_Sales"; Performing failover NOW. Please wait... Operation requires shutdown of instance "dr_sales1" on database "DR_Sales". Shutting down instance "dr_sales1"... ORA-01109: database not open Database dismounted. ORACLE instance shut down. Operation requires startup of instance "dr_sales1" on database "DR_Sales". Starting instance "dr_sales1"... ORACLE instance started. Database mounted. Failover succeeded. New primary is "DR_Sales"
Displays online help for the Data Guard command-line interface.
Format
HELP [topic];
Command Parameter
The topic for which you want to display help information. If you do not specify a topic, the command lists all of the topics and the format. Valid topics are:
ADD
CONNECT
CREATE
DISABLE
EDIT
ENABLE
EXIT
FAILOVER
HELP
QUIT
REMOVE
SHOW
SHUTDOWN
STARTUP
SWITCHOVER
Usage Note
A database connection is not required to execute this command.
Command Examples
Example 1
The following examples get help on the HELP
and CONNECT
commands.
DGMGRL> HELP HELP; Display description and syntax for a given command Syntax: HELP [<command>]; DGMGRL> HELP CONNECT; Connect to an Oracle instance Syntax: CONNECT <username>/<password>[@<connect identifier>]
Example 2
The following example gets help on the EDIT
commands.
DGMGRL> HELP EDIT Edit a configuration, database or instance Syntax: EDIT CONFIGURATION SET PROTECTION MODE AS {MaxProtection|MaxAvailability|MaxPerformance}; EDIT DATABASE <database name> SET PROPERTY <property name> = <value>; EDIT DATABASE <database name> RENAME TO <new database name>; EDIT DATABASE <database name> SET STATE = <state> [WITH APPLY INSTANCE = <instance name>]; EDIT INSTANCE <instance name> [ON DATABASE <database name>] SET AUTO PFILE [ = {<initialization file path>|OFF} ]; EDIT INSTANCE <instance name> [ON DATABASE <database name>] SET PROPERTY <property name> = <value>;
Quits (exits) the Data Guard command-line interface.
Format
QUIT;
Command Parameters
None.
Usage Notes
This command has the same effect as the EXIT command.
A database connection is not required to execute this command. However, if you are connected, this command breaks the connection.
Command Example
The following example shows how to quit (exit) the command-line interface.
DGMGRL> QUIT;
Removes all of the broker configuration information, including all database profiles, from the Data Guard configuration file, and terminates broker management of all of the databases associated with the broker configuration.
Caution: When you use theREMOVE CONFIGURATION command, all profile information is deleted from the Data Guard configuration file and cannot be recovered. |
Format
REMOVE CONFIGURATION [ PRESERVE DESTINATIONS ];
Command Parameters
None.
Usage Notes
When you remove a broker configuration, management of all of the databases associated with that configuration is disabled.
By default, the command removes the corresponding broker settings of the LOG_ARCHIVE_DEST_
n
initialization parameter on the primary database and the LOG_ARCHIVE_CONFIG
initialization parameters on all databases in the configuration. To preserve these settings, use the PRESERVE DESTINATIONS
option.
This command does not remove or affect the actual primary or standby database instances, databases, datafiles, control files, initialization parameter files, server parameter files, or log files of the underlying Data Guard configuration.
Command Example
The following example shows how to remove configuration information from the configuration file.
DGMGRL> REMOVE CONFIGURATION; Removed configuration. DGMGRL> SHOW CONFIGURATION; Error: ORA-16532: Data Guard configuration does not exist
Removes the specified standby database's profile from the broker configuration and terminates broker management of the standby database.
Caution: When you use theREMOVE DATABASE command, the database's profile information is deleted from the broker configuration file and cannot be recovered. |
Format
REMOVE DATABASE database-name [ PRESERVE DESTINATIONS ];
Command Parameter
The name of the standby database whose profile you want to remove from the broker configuration.
Usage Note
An error is returned if you specify the name of the primary database in the broker configuration.
By default, the command removed the corresponding broker settings of the LOG_ARCHIVE_DEST_
n
initialization parameter on the primary database and the LOG_ARCHIVE_CONFIG
initialization parameter on all databases in the configuration. To preserve these settings, use the PRESERVE DESTINATIONS
option.
Command Example
The following example shows how to remove a database from the Data Guard configuration.
DGMGRL> SHOW CONFIGURATION; Configuration Name: DRSolution Enabled: YES Protection Mode: MaxPerformance Databases: North_Sales - Primary database DR_Sales - Physical standby database Current status for "DRSolution": SUCCESS DGMGRL> REMOVE DATABASE 'DR_Sales'; Removed database "DR_Sales" from the configuration. DGMGRL> SHOW CONFIGURATION; Configuration Name: DRSolution Enabled: YES Protection Mode: MaxPerformance Databases: North_Sales - Primary database Current status for "DRSolution": SUCCESS
Removes an instance from an existing database profile in the broker configuration.
Format
REMOVE INSTANCE instance-name
[ON DATABASE database-name];
Command Parameters
The name of the instance (SID) that you want to remove from the broker configuration.
The name of the database to which the instance-name
is associated.
Usage Notes
In a RAC database, the broker automatically adds started instances into the corresponding database profile. However, the broker may not automatically remove instances from the database profile. The REMOVE INSTANCE
command can be used to manually remove any instance that no longer exists from the database profile.
The instance-name
can be unique across the configuration. If instance-name
is not unique, you must specify both the database-name
and the instance-name
to fully identify the instance.
This command is rejected for an instance that is currently active in the broker configuration.
This command is rejected if this is the only instance currently associated with a database profile.
Command Example
The following example shows how to remove an instance of the database.
DGMGRL> REMOVE INSTANCE 'dr_sales3' ON DATABASE 'DR_SALES' ; Removed instance "dr_sales3" from the database "DR_SALES".
Displays a summary and status of the broker configuration. The summary lists all databases included in the broker configuration and other information pertaining to the broker configuration itself.
Format
SHOW CONFIGURATION;
Command Parameters
None.
Usage Notes
None.
Command Examples
The following example provides a summary of the DRSolution
configuration.
DGMGRL> SHOW CONFIGURATION; Configuration Name: DRSolution Enabled: YES Protection Mode: MaxPerformance Databases: North_Sales - Primary database DR_Sales - Physical standby database Current status for "DRSolution": SUCCESS
Displays information or property values of the specified database and its instances.
Format
SHOW DATABASE [VERBOSE] database-name [property-name];
Command Parameters
The name of the database for which you want to display information.
The name of the property for which you want to display a value.
Usage Notes
The SHOW DATABASE
command shows a brief summary of the database. SHOW DATABASE VERBOSE
shows properties of the database in addition to the brief summary. They both show the status of the database.
The SHOW DATABASE VERBOSE
command shows database-specific properties and instance-specific properties. For a non-RAC database, the values of the instance-specific properties are those of the only instance of the database. For a RAC database, the values of the instance-specific properties will not be shown, although the property names are still listed. To see the instance-specific values of these properties, use the SHOW INSTANCE
command.
The properties that the SHOW DATABASE VERBOSE
command shows depend on the database role and the configuration composition:
For the primary database, properties specific to physical standby databases are shown only if there is at least one physical standby database in the configuration. The properties specific to logical standby databases are shown only if there is at least one logical standby database in the configuration.
For physical standby databases, properties specific to logical standby databases are not shown.
For logical standby databases, properties specific to physical standby databases are not shown.
This command is rejected if you use SHOW DATABASE
property-name
command to show an instance-specific property in a RAC database.
Command Examples
Example 1
Shows database information in an abbreviated format.
DGMGRL> SHOW DATABASE 'DR_Sales'; Database Name: DR_Sales Role: PHYSICAL STANDBY Enabled: YES Intended State: ONLINE Instance(s): dr_sales1 Current status for "DR_Sales": SUCCESS
Example 2
Shows database information in an extended format.
DGMGRL> SHOW DATABASE VERBOSE 'North_Sales'; Database Name: North_Sales Role: PRIMARY Enabled: YES Intended State: ONLINE Instance(s): sales1 Properties: InitialConnectIdentifier = 'North_Sales.foo.com' LogXptMode = 'ARCH' Dependency = '' DelayMins = '0' Binding = 'OPTIONAL' MaxFailure = '0' ReopenSecs = '300' AsyncBlocks = '2048' NetTimeout = '30' LogShipping = 'ON' PreferredApplyInstance = '' ApplyInstanceTimeout = '120' RealTimeApply = 'OFF' ApplyNoDelay = 'NO' ApplyNext = '0' ApplyParallel = 'AUTO' StandbyFileManagement = 'AUTO' ArchiveLagTarget = '0' LogArchiveMaxProcesses = '5' LogArchiveMinSucceedDest = '1' DbFileNameConvert = 'dbs/s2t, dbs/t' LogFileNameConvert = 'dbs/s2t, dbs/t' StatusReport = '(monitor)' InconsistentProperties = '(monitor)' InconsistentLogXptProps = '(monitor)' SendQEntries = '(monitor)' LogXptStatus = '(monitor)' RecvQEntries = '(monitor)' HostName = 'north.foo.com' SidName = 'sales1' LocalListenerAddress = '(ADDRESS=(PROTOCOL=TCP)(HOST=north.foo.com)(PORT=1514))' AlternateLocation = '' StandbyArchiveLocation = '/archfs/arch/' LogArchiveTrace = '4095' LogArchiveFormat = 'r_%t_%s_%r_%d.arc' LatestLog = '(monitor)' TopWaitEvents = '(monitor)' Current status for "North_Sales": SUCCESS
Displays information or property value of the specified instance.
Format
SHOW INSTANCE [VERBOSE] instance-name [property-name]
[ON DATABASE database-name];
Command Parameters
The name of the instance for which you want to display information.
The name of the property for which you want to display a value.
The name of the database to which is associated the instance for which you want to show information.
Usage Notes
The SHOW INSTANCE
command shows a brief summary of the instance. SHOW INSTANCE VERBOSE
shows properties of the instance in addition to the brief summary. They both show the status of the instance.
The SHOW INSTANCE VERBOSE
command only shows instance-specific properties.
The properties that the SHOW INSTANCE VERBOSE
command shows depend on the database role and the configuration composition:
For instances of the primary database, properties specific to physical standby instances are shown only if there is at least one physical standby database in the configuration. The properties specific to logical standby instances are shown only if there is at least one logical standby database in the configuration.
For instances of physical standby databases, properties specific to logical standby instances are not shown.
For instances of logical standby databases, properties specific to physical standby instances are not shown.
The instance-name
can be unique across the configuration. If instance-name
is not unique, you must specify both the database-name
and the instance-name
to fully identify the instance.
Command Example
Example 1
The following example shows information about a specific instance of a database.
DGMGRL> SHOW INSTANCE sales1; Instance 'sales1' of database 'North_Sales' Host Name: north.foo.com Current status for "sales1": SUCCESS
Example 2
Shows instance information in an extended format.
DGMGRL> SHOW INSTANCE VERBOSE 'sales1'; Instance 'sales1' of database 'North_Sales' Host Name: north.foo.com PFILE: Properties: HostName = 'north.foo.com' SidName = 'sales1' LocalListenerAddress ='(ADDRESS=(PROTOCOL=TCP)(HOST=north.foo.com)(PORT=1514))' StandbyArchiveLocation = '/archfs/arch/' AlternateLocation = '' LogArchiveTrace = '4095' LogArchiveFormat = 'r_%d_%t_%s_%r.arc' LatestLog = '(monitor)' TopWaitEvents = '(monitor)' Current status for "sales1": SUCCESS
Shuts down a currently running Oracle instance.
Format
SHUTDOWN [ ABORT | IMMEDIATE | NORMAL ];
Command Parameters
None.
Usage Notes
Using the SHUTDOWN
command with no arguments is equivalent to using the SHUTDOWN NORMAL
command.
The following list describes the options to the SHUTDOWN
command:
ABORT
Proceeds with the fastest possible shutdown of the database without waiting for calls to complete or for users to disconnect from the database. Uncommitted transactions are not rolled back. Client SQL statements being processed are terminated. All users connected to the database are implicitly disconnected, and the next database startup will require instance recovery. You must use this option if a background process terminates abnormally.
IMMEDIATE
Does not wait for current calls to complete or users to disconnect from the database. Further connections are prohibited. The database is closed and dismounted. The instance is shut down, and no instance recovery is required on the next database startup.
NORMAL
This is the default option. The process waits for users to disconnect from the database. Further connections are prohibited. The database is closed and dismounted. The instance is shut down, and no instance recovery is required on the next database startup.
Command Example
The following command shuts down the database in normal mode.
DGMGRL > SHUTDOWN; Database closed. Database dismounted. Oracle instance shut down.
Starts an Oracle database instance with any of the following options:
FORCE
: shuts down the current Oracle instance in the SHUTDOWN
ABORT
mode before restarting it.
RESTRICT
: allows only Oracle users with the RESTRICTED SESSION
system privilege to connect to the instance.
PFILE
: specifies the PFILE
initialization parameter file to be used when the database instance is started.
MOUNT
: mounts the specified database without opening it. If you do not specify a database name, the database name is taken from the initialization parameter DB_NAME
.
OPEN
: mounts and opens the specified database.
NOMOUNT
: starts the specified database instance without mounting the database.
Format
STARTUP
[FORCE]
[RESTRICT]
[PFILE=filename]
[MOUNT [db_name] | OPEN [open-options] [db_name] | NOMOUNT];
Command Parameters
The name of the initialization parameter file to be used when starting the database instance. If you do not specify the PFILE
parameter option, then the default server parameter file (specific to your operating system) is used.
The name of the database to mount or open. If you do not specify the db_name
parameter, the database name is taken from the initialization parameter DB_NAME
.
The mode of access in which you want the specified database to start. The possible modes are:
READ ONLY
READ WRITE
Usage Notes
Using the STARTUP
command with no arguments is equivalent to using the STARTUP OPEN
command.
If you do not use the FORCE
clause when you use the STARTUP
command and the current database instance is running, an error results. The FORCE
clause is useful when you are debugging or when error conditions are occurring. Otherwise, it should not be used.
Use the RESTRICT
clause to allow only Oracle users with the RESTRICTED SESSION
system privilege to connect to the instance. Later, you can use the ALTER SYSTEM
command through SQL*Plus to disable the restricted session feature.
If you do not use the PFILE
clause to specify the initialization parameter file, the STARTUP
command uses the default server parameter file, if it exists. Otherwise, the STARTUP
command uses the default initialization parameter file. The default files are platform specific.
See your operating system-specific documentation for more information about the default parameter files.
Use the MOUNT
clause to mount a primary database or a logical standby database without opening it. If you do not specify a database name, the database name is taken from the initialization parameter DB_NAME
.
Use the OPEN
clause to mount and open the specified database.
The NOMOUNT
clause starts the database instance without mounting the database. You cannot use the NOMOUNT
clause with the MOUNT
or OPEN
options.
Command Examples
Example 1
The following examples show two different methods for starting a database instance. Each command starts a database instance using the standard parameter file, mounts the default database in exclusive mode, and opens the database.
DGMGRL> STARTUP; DGMGRL> STARTUP OPEN database;
Example 2
The following command shuts down the current instance, immediately restarts it without mounting or opening the database, and allows only users with restricted session privileges to connect to it.
DGMGRL > STARTUP FORCE RESTRICT NOMOUNT;
Example 3
The following command starts an instance using the parameter file testparm
without mounting the database.
DGMGRL > STARTUP PFILE=testparm NOMOUNT;
Example 4
The following example starts and mounts a database instance, but does not open it.
DGMGRL> STARTUP MOUNT;
A switchover operation is a planned transition in which the primary database exchanges roles with one of the standby databases. When you issue the SWITCHOVER
command, the current primary database becomes a standby database, and the specified standby database becomes the primary database.
Format
SWITCHOVER TO database-name;
Command Parameter
The name of the standby database you want to change to the primary database role.
Usage Notes
The broker verifies that the primary and standby databases are in the following states before starting the switchover:
The primary database must be enabled and ONLINE
, with log transport services started.
The standby database must be enabled and ONLINE
, with log apply services started.
The broker allows the switchover to proceed as long as there are no log transport services errors for the standby database that you selected to participate in the switchover. However, errors occurring for any other standby database not involved in the switchover will not prevent the switchover from proceeding.
If the broker configuration is in either MAXPROTECTION
or MAXAVAILABILITY
mode, the switchover maintains the protection mode even after the operation (see Section 4.1.1). The switchover will not be allowed if the mode cannot be maintained because the target standby database of the switchover was the only standby that satisfied the protection mode requirement.
If the standby database that is assuming the primary role is a physical standby database, then both the primary and standby databases will be restarted after the switchover completes. If the standby database is a logical standby database, then neither the primary database nor the logical standby database is restarted.
If the standby database that is assuming the primary role is a physical standby database, then the original primary becomes a physical standby database. Otherwise, it becomes a logical standby database.
If the primary database is a RAC database, the broker will keep only one instance running and shut down all other instances before it continues the switchover. If the standby database you want to switch to the primary role is a RAC database, the broker will shut down all instances except the apply instance before it continues the switchover. The broker will restart instances that it shut down prior to the switchover. See Section 4.1 for details.
If the standby database that is assuming the primary role is a logical standby database and there are physical standby databases in the configuration, after the switchover, the physical standby databases will not be able to participate as such until they are re-created.
Caution: For this reason, Oracle generally recommends that you specify your physical standby database for switchover instead of your logical standby database. If you must switch over to your logical standby database, see Section 4.2.5 to re-create your physical standby database. |
Command Examples
Example 1
The following example shows a successful switchover in which the standby database, DR_Sales
, transitions into the primary role.
DGMGRL> SWITCHOVER TO "DR_Sales"; Performing switchover NOW. Please wait... Operation requires shutdown of instance "sales1" on database "North_Sales". Shutting down instance "sales1"... ORA-01109: database not open Database dismounted. ORACLE instance shut down. Operation requires shutdown of instance "dr_sales1" on database "DR_Sales". Shutting down instance "dr_sales1"... ORA-01109: database not open Database dismounted. ORACLE instance shut down. Operation requires startup of instance "sales1" on database "North_Sales". Starting instance "sales1"... ORACLE instance started. Database mounted. Operation requires startup of instance "dr_sales1" on database "DR_Sales". Starting instance "dr_sales1"... ORACLE instance started. Database mounted. Switchover succeeded. New primary is "DR_Sales"
Example 2
If you connect to the database using operating system authentication, you can use any username and password to connect. However, the CLI may not be able to shut down and start up the primary and standby database automatically because it cannot remotely authenticate itself.
The following example shows a switchover that succeeded but returns an error because the CLI cannot shut down and start up the primary and standby databases.
DGMGRL> CONNECT / Connected DGMGRL> SWITCHOVER TO "DR_Sales"; Performing switchover NOW. Please wait... Operation requires shutdown of instance "sales1" on database "North_Sales". Shutting down instance "sales1"... ORA-01017: invalid username/password; logon denied You are no longer connected to ORACLE Please connect again. Unable to shut down instance "sales1". You must shut down instance "sales1" manually. Operation requires shutdown of instance "dr_sales1" on database "DR_Sales". You must shut down instance "dr_sales1" manually. Operation requires startup of instance "sales1" on database "North_Sales". You must start instance "sales1" manually. Operation requires startup of instance "dr_sales1" on database "DR_Sales". You must start instance "dr_sales1" manually. Switchover succeeded. New primary is "DR_Sales"
Note: For DGMGRL to restart instances automatically, you must connect to the database as SYSDBA using the username and password you specified in the remote password file before you begin the switchover. The username and password must be the same on the primary and standby databases. |
You must manually issue the SHUTDOWN and STARTUP commands to restart the new primary and standby database instances in this configuration.