Backup and Recovery
Protecting your data is extremely important, your job could depend on it, making sure that your data is backed up and that you are able to restore it in a disaster goes without saying. They are many methods to backing up your data
In this section I will only be covering Oracle RMAN which I have also covered in a previous Oracle article called RMAN, so if you need to brush up on your RMAN skills then take a look. Below is the terminology that I will be using
You can now set persistent RMAN configurations for a primary or physical standby databases, this enables you to use backups made on one database for the restore and recovery of another database in your Data Guard configuration, also metadata on the primary and standby databases can be managed from the same recovery catalog.
You can now enable block change tracking on a physical standby database which will allow you to quickly identify the blocks that have changed since the last incremental backup
enable block change tracking | sql> alter database enable block change tracking using file '/u01/block_change/prod1dr/chgtrack.log'; sql> select filename, status, bytes from v$block_change_tracking; |
Backups of controlfiles are interchangeable between a primary database and its physical standby database. You can restore a standby controlfile on a primary and a primary controlfile on a standby. You do not need to backup the controlfile on your standby databases, RMAN will now automatically synchronize the control file information with the standby databases when using an RMAN catalog.
You can now resynchronize the RMAN catalog from a remote database using the resync catalog command with the connect identifier clause.
resync RMAN remotely | rman> configure db_unique_name prod1dr connect identifier 'prod1dr'; ## can resync from specific site or all sites rman> resync catalog from db_unique_name prod1dr; rman> resync catalog from db_unique_name all; |
RMAN Configuration in Data Guard
RMAN uses the db_unique_name parameter to identify one database from another, only the primary database must be explicitly registered using the register database command. Physical standby databases are registered automatically in the catalog when you use RMAN to connect to them as the target while connected to the recovery catalog. You can change the associated backups files with a different database using the change command with the reset db_unique_name option.
associate backup files with different database | rman> changebackup tag='standby_backup_1' for db_unique_name prod1dr reset db_unique_name; |
There are a number of configuration options I only list the ones that are appropriate with Data Guard
RMAN config for primary | ## keep all backups for at least 7 days rman> configure retention policy to recovery window of 7 days; ## chose one of the following depending on when you want the archives to be deleted after shipping or after being applied rman> configure archivelog deletion policy to shipped to all standby; rman> configure archivelog deletion policy to applied on all standby; ## configure the connect identifiers for all datbases rman> configure db_unique_name prod1 connect identifier 'prod1'; rman> configure db_unique_name prod1dr connect identifier 'prod1dr'; rman> list db_unique_name of database; |
RMAN config for standby | ## enable automatic backups of the control file and server parameters ## Since the logs are backed up at the standby you can specify none |
I am not going to talk about all the different backup scenarios (full, incremental, backup copies, backups of flash recovery area, archive) as I have also discussed this in another section called RMAN. I have also discuss how to create a standby database by cloning the primary database using the duplicate command.
You can use images copies to create a standby database, however the primary database must be shutdown cleanly and opened in mount mode to perform the backup, once complete the primary can be restarted and the image copy copied to the standby server, after fixing the parameters as usual, mounted using the standby control file.
Backups are pretty much the same as in any other database, apart from the deletion of archive log files there is not much to say.
Recovery can come in in the following scenarios
You can use RMAN to check for block corruptions and dbverify to identify corrupt data files, I have section regarding database corruptions.
check for block corruptions | rman> backup validate database archivelog all; |
Also you have the flashback technologies to recover a number of accidents, drop tables, etc.
Here is a small table will the most common recovery scenarios, but have a look at my database recovery section which goes in to great detail on database recovery.
Loss of a data file on a primary database |
|
Using a standby datbase to recover the data file |
|
Loss of a datafile on a standby database |
|
Loss of a standby controlfile |
|
Loss of a primary controlfile | You can restore the control file from a backup by executing the restore controlfile and the database recover commands. |
Loss of a online redo |
|
incomplete recovery of a primary database |
|
Recovering from a dropped table |
|