So I already have a standby database (or multiple standbys in some cases) how do I set up the broker to make my life easier?
The broker requires a special static listener in order for the failover/switchover to work. The broker will use this listener to connect as SYSDBA remotely and perform the startup. The key here is the global name will be the db_unique_name appended with DGMGRL and the domain the database resides. This must be done for both the primary and the standby. No TNS entry is required because the broker knows this is the listener to utilize.
On the primary server:
SID_LIST_LISTENER =
(SID_LIST =
(SID_DESC =
(GLOBAL_DBNAME = PRIMARY_DGMGRL)
(ORACLE_HOME = /u01/app/oracle/product/11.2.0.3)
(SID_NAME = PRIMARY)
)
)
On the standby server:
SID_LIST_LISTENER =
(SID_LIST =
(SID_DESC =
(GLOBAL_DBNAME = STANDBY_DGMGRL)
(ORACLE_HOME = /u01/app/oracle/product/11.2.0.3)
(SID_NAME = PRIMARY)
)
)
Enable data guard broker by setting the DG_BROKER_START parameter to TRUE:
ALTER SYSTEM SET DG_BROKER_START=TRUE;
There are two configuration files for the broker the default values:
$ORACLE_HOME/dbs/dr1
$ORACLE_HOME/dbs/dr2
For RAC it is suggested that these are changed to a shared file system.
Start the data guard broker command line utility and connect as SYS. It is assumed by the broker that sysdba is the privilege and therefore you don't need to specify it.
dgmgrl
DGMGRL> CONNECT SYS
Password:
Next we create the configuration by specifying the primary database name, and the configuration name.
DGMGRL> CREATE CONFIGURATION DG1' AS
PRIMARY DATABASE IS 'PRIMARY'
CONNECT IDENTIFIER IS 'PRIMARY' ;
Configuration "DG1" created with primary database "PRIMARY"
Add the standby databases to the configuration.
DGMGRL> ADD DATABASE 'STANDBY' AS
CONNECT IDENTIFIER IS 'STANDBY';
Database 'STANDBY' added
The data guard configuration must then be enabled.
DGMGRL> ENABLE CONFIGURATION;
Enabled
No comments:
Post a Comment