21 Performing RMAN Tablespace Point-in-Time Recovery (TSPITR)
This chapter explains how to perform RMAN tablespace point-in-time recovery. This chapter contains the following sections:
-
Running RMAN TSPITR:
21.1 Overview of RMAN TSPITR
To use RMAN tablespace point-in-time recovery (TSPITR) effectively, it is helpful to understand what types of problems it can resolve, its components, what RMAN does during TSPITR, and the various limitations and restrictions on when and how it can be run. This section explains the basic concepts, preparatory tasks, and modes of running RMAN TSPITR.
To perform TSPITR for CDBs and PDBs, you must connect to the root as a user with the SYSDBA
or SYSBACKUP
privilege. To perform TSPITR of one more more PDBs, you must have a backup of the root and the CDB seed of the CDB that contains the PDBs.
21.1.1 Purpose of RMAN TSPITR
Recovery Manager (RMAN) TSPITR enables quick recovery of one or more tablespaces in a database to an earlier time without affecting the rest of the tablespaces and objects in the database.
RMAN TSPITR is most useful for the following situations:
-
To recover a logical database to a point different from the rest of the physical database, when multiple logical databases exist in separate tablespaces of one physical database. For example, you maintain logical databases in the
orders
andpersonnel
tablespaces. An incorrect batch job or data manipulation language (DML) statement corrupts the data in only one tablespace. -
To recover data lost after data definition language (DDL) operations that change the structure of tables. You cannot use Flashback Table to rewind a table to before the point of a structural change such as a truncate table operation.
-
To recover a table after it has been dropped with the
PURGE
option. -
To recover from the logical corruption of a table.
-
To recover dropped tablespaces. In fact, RMAN can perform TSPITR on dropped tablespaces even when a recovery catalog is not used.
You can also use Flashback Database to rewind data, but you must rewind the entire database rather than just a subset. Also, unlike TSPITR, the Flashback Database feature necessitates the overhead of maintaining flashback logs. The point in time to which you can flash back the database is more limited than the TSPITR window, which extends back to your earliest recoverable backup.
21.1.2 Basic Concepts of RMAN TSPITR
Understand the concepts of RMAN TSPITR such as the terminology and modes used.
This section contains the following topics:
21.1.2.1 Common Terms for RMAN TSPITR
This section defines some common entities that are used by RMAN TSPITR.
Table 21-1 RMAN TSPITR Entities
Name | Explanation |
---|---|
Target instance |
Contains the tablespace to be recovered to the target time |
Target time |
Point in time or SCN of the tablespace after TSPITR completes |
Auxiliary database |
A database used in the recovery process to perform the work of recovery. The auxiliary database has other files associated with it. See auxiliary set for a complete list. |
Auxiliary destination |
An optional disk location that RMAN uses to temporarily store the auxiliary set files. The auxiliary destination is used only with an RMAN-managed auxiliary database. Specifying an auxiliary destination with a user-managed auxiliary database results in an error. All references to auxiliary destination in this chapter assume use of an RMAN-managed auxiliary database. |
Recovery set |
Data files in the tablespaces that you intend to recover |
Auxiliary set |
Data files required for TSPITR that are not part of the recovery set. The auxiliary set typically includes:
The auxiliary set does not include the parameter file, password file, or associated network files. |
21.1.2.2 Modes of RMAN TSPITR
There are several modes of running RMAN TSPITR. The difference between the various modes of operation corresponds to how much automation versus customization you require in your environment.
You start RMAN TSPITR with the RMAN RECOVER TABLESPACE
command. There are three ways to run the utility:
-
Fully Automated (the default)
In this mode, RMAN manages the entire TSPITR process including the auxiliary database. You specify the tablespaces of the recovery set, an auxiliary destination, the target time, and you allow RMAN to manage all other aspects of TSPITR.
The default mode is recommended unless you specifically need more control over the location of recovery set files after TSPITR, auxiliary set files during TSPITR, channel settings and parameters or some other aspect of your auxiliary database.
-
Automated: RMAN-Managed Auxiliary Database with User Settings
You can override some defaults of RMAN TSPITR while still using an RMAN-managed auxiliary database and destination. This variation of the default mode enables you to benefit from some built-in management that RMAN TSITR provides while being able to specify:
-
Location of auxiliary set or recovery set files
-
Initialization parameters
-
-
Non-Automated: TSPITR and User-Managed Auxiliary Database
This mode of RMAN TSPITR requires you to set up and manage all aspects of the auxiliary database and some aspects of the TSPITR process. This mode may be appropriate if, for example, you must allocate a different number of channels or change the channel parameters for your user-managed auxiliary database.
21.1.2.3 How RMAN TSPITR Works With an RMAN-Managed Auxiliary Database
Select tablespaces from the recovery set, an auxiliary destination, and a target time before you perform fully automated RMAN TSPITR (default).
The automated mode of RMAN TSPITR shares many of these high-level processing steps. RMAN TSPITR automatically performs the following actions:
-
If the tablespaces in the recovery set have not been dropped, checks to see if they are self-contained by executing the
DBMS_TTS.TRANSPORT_SET_CHECK
for the recovery set tablespaces and then checking that the viewTRANSPORT_SET_VIOLATIONS
is empty. If the query returns rows, RMAN stops TSPITR processing. You must resolve any tablespace containment violations before TSPITR can proceed. Example 21-1 shows you how to set up and run the query before invoking RMAN TSPITR. -
Checks to see if a connection to a user-managed auxiliary database was provided. If it is, then RMAN TSPITR uses it. If not, RMAN TSPITR creates the auxiliary database, starts it, and connects to it.
-
Takes the tablespaces to be recovered offline in the target database, if the tablespaces in the recovery set have not been dropped.
-
Restores a backup control file from a point in time before the target time to the auxiliary database.
-
Restores the data files from the recovery set and the auxiliary set to the auxiliary database.
Files are restored either in the:
-
Locations that you specify for each file
-
Original location of the file (for recovery set data files)
-
Auxiliary destination (if you used the
AUXILIARY DESTINATION
argument ofRECOVER TABLESPACE
and an RMAN-managed auxiliary database)
-
-
Recovers the restored data files in the auxiliary database to the specified time.
-
Opens the auxiliary database with the
RESETLOGS
option. -
Makes the recovery set tablespaces read-only in the auxiliary database.
-
Exports the recovery set tablespaces from the auxiliary database using the Data Pump utility to produce a transportable tablespace dump file.
-
Shuts down the auxiliary database.
-
Drops the recovery set tablespaces from the target.
-
Data Pump utility reads the transportable tablespace dump file and plugs the recovery set tablespaces into the target.
-
Makes the tablespaces that were put in the target database read/write and immediately takes them offline.
-
Deletes all auxiliary set files.
At this point, RMAN TSPITR has finished. The recovery set data files are returned to their contents at the specified point in time, and belong to the target database.
The recovery set tablespaces are left offline for you to back up and then bring back online. These last steps follow Oracle's recommendation and best practice of backing up recovered tablespaces as soon as TSPITR completes.
21.2 TSPITR Restrictions, Special Cases, and Limitations
Some database problems cannot be resolved with TSPITR because of certain restrictions and limitations.
The following list explains when you cannot perform TSPITR:
-
If there are no archived redo logs or if the database runs in
NOARCHIVELOG
mode. -
If TSPITR is used to recover a renamed tablespace to a point in time before it was renamed, you must use the previous name of the tablespace to perform the recovery operation.
In this case when TSPITR completes, the target database contains two copies of the same tablespace, the original tablespace with the new name and the TSPITR tablespace with the old name. If this is not your goal, then you can drop the new tablespace with the new name.
-
If constraints for the tables in tablespace
tbs1
are contained in tablespacetbs2
, then you cannot recovertbs1
without also recoveringtbs2
. -
If a table and its indexes are stored in different tablespaces, then the indexes must be dropped before performing TSPITR.
-
You cannot use TSPITR to recover the current default tablespace.
-
You cannot use TSPITR to recover tablespaces containing any of the following objects:
-
Objects with underlying objects (such as materialized views) or contained objects (such as partitioned tables) unless all of the underlying or contained objects are in the recovery set. Additionally, if the partitions of a partitioned table are stored in different tablespaces, then you must either drop the table before performing TSPITR or move all the partitions to the same tablespace before performing TSPITR.
-
Undo or rollback segments
-
Oracle8-compatible advanced queues with multiple recipients
-
Objects owned by the user
SYS
. Examples of these types of objects are: PL/SQL, Java classes, callout programs, views, synonyms, users, privileges, dimensions, directories, and sequences.
-
21.2.1 Limitations of TSPITR
There are some limitations to consider when performing TSPITR.
After TSPITR completes, RMAN recovers the data files in the recovery set to the target time. Note the following special cases:
-
TSPITR does not recover query optimizer statistics for recovered objects.You must gather new statistics after TSPITR completes.
-
If you run TSPITR on a tablespace and bring the tablespace online at time t, then backups of the tablespace created before time t are no longer usable for recovery with a current control file. You cannot use the current control file to recover the database to any time less than or equal to t.
-
If one or more data files in the recovery set have Oracle Managed File (OMF) names and the compatibility in the target database is set to version 10.1 or earlier, RMAN cannot reuse the data file. This restriction is true even if no SET NEWNAME command is provided for the data file. A new OMF name is created for the recovery set data file. This action temporarily doubles the space requirements for the data file. This is because
DB_CREATE_FILE_DEST
has two copies of the data file (the original data file and the one used by TSPITR) until the tablespace is dropped in the target and the original data file is deleted.
RMAN uses the transportable tablespaces functionality to perform TSPITR. Therefore, any limitations on transportable tablespaces are also applicable to TSPITR.
See Also:
Oracle Database Administrator’s Guide for information about limitations on transportable tablespaces
21.2.2 About Special Considerations When Not Using a Recovery Catalog
Be aware of certain precautions when not using a recovery catalog during TSPITR.
The precautions include the following:
-
Because RMAN has no historical record of the undo in the control file, RMAN assumes that the current set of tablespaces with rollback or undo segments were the same set present at the time when recovery was performed. If the tablespace set has changed since that time, then the current rollback or undo segments were the same segments present at the time to which recovery is performed. If the undo segments have changed since that time, then you can use
UNDO TABLESPACE
to indicate the correct set of tablespaces with undo at the point in time where the tablespaces are being recovered. -
TSPITR to a time that is too old may not succeed if Oracle Database has reused the control file records for needed backups. (In planning your database, set the
CONTROL_FILE_RECORD_KEEP_TIME
initialization parameter to a value large enough to ensure that control file records needed for TSPITR are kept.) -
To rerun TSPITR when you are not using a recovery catalog, you must first drop the tablespace to be used by TSPITR from the target database.
21.3 Planning and Preparing for TSPITR
Certain steps must be completed when preparing to perform TSPITR.
To prepare for TSPITR:
- Read and understand the considerations described in "TSPITR Restrictions, Special Cases, and Limitations".
- Select the target time until which the tablespace must be recovered, as described in "Selecting the Right Target Time for TSPITR".
- Determine the recovery set, as described in "Determining the Recovery Set".
- Identify and preserve objects that will be lost after the TSPITR operation completes, as described in "Identifying and Preserving Objects That Are Lost After TSPITR".
21.3.1 Selecting the Right Target Time for TSPITR
It is extremely important that you choose the right target time or SCN for your TSPITR. Note that after you bring a tablespace online after TSPITR, you cannot use any backup from a time earlier than the moment you brought the tablespace online.
If you have a recovery catalog, then you can perform repeated TSPITR operations to different target times because the catalog contains tablespace history information. If RMAN uses only a control file, however, repeated TSPITR is only possible after dropping the tablespace because the control file does not have the tablespace history. In this case, RMAN only knows about the current set of tablespaces. The tablespace on which TSPITR was performed has a creation time equal to the time it was brought online.
To identify a target time for TSPITR, investigate past states of your data and find the point in time when unwanted changes occurred by using one of the following techniques:
-
Flashback Query
-
Oracle Transaction Query
-
Flashback Version Query
See Also:
-
Oracle Database Development Guide for more information on Flashback Query, Flashback Transaction Query, and Flashback Version Query
21.3.2 Determining the Recovery Set
Initially, your recovery set includes the data files for the tablespaces that you intend to recover. However, if objects in the tablespaces that you need have relationships (such as constraints) to objects in other tablespaces, then you must account for these relationships before you can perform TSPITR
You have the following choices when faced with such a relationship:
-
Add the tablespace including the related objects to your recovery set
-
Remove the relationship
-
Suspend the relationship for the duration of TSPITR
See Also:
"Identify and Resolve Dependencies on the Primary Database" for information about resolving relationships to other tablespaces
21.3.2.1 Identify and Resolve Dependencies on the Primary Database
RMAN TSPITR requires that the tablespace that is being recovered be self-contained and that no SYS
-owned objects reside in the tablespace.
To identify and resolve dependencies:
-
Use the
DBMS_TTS.TRANSPORT_SET_CHECK
procedure to locate objects outside the tablespace and identify relationships between objects that span the recovery set boundaries.If the
TRANSPORT_SET_VIOLATIONS
view returns rows, you must investigate and correct the problem according to the choices described in "Determining the Recovery Set". -
Record all actions performed during this step so that you can re-create any suspended or removed relationships after completing TSPITR.
Proceed with TSPITR only when the
TRANSPORT_SET_VIOLATIONS
view is empty for the tablespaces in the recovery set.
Note:
If one or more of the tablespaces in the recovery set have been dropped, RMAN TSPITR cannot run the procedure DBMS_TTS.TRANSPORT_SET_CHECK
. In this case, DBMS_TTS.TRANSPORT_SET_CHECK
is run when the Data Pump export of the auxiliary database occurs. Just like RMAN TSPITR, if the export operation encounters any tablespaces that are not self-contained, it fails.
Example 21-1 Querying DBMS_TTS.TRANSPORT_SET_CHECK for a Subset of Tablespaces
This example illustrates how to use the DBMS_TTS.TRANSPORT_SET_CHECK
procedure for an initial recovery set consisting of tablespaces tools
and users
. It queries the transportable tablespace violations table to manage any dependencies. No rows are returned from this query when all dependencies are managed.
BEGIN DBMS_TTS.TRANSPORT_SET_CHECK('USERS,TOOLS', TRUE,TRUE); END; / SELECT * FROM TRANSPORT_SET_VIOLATIONS;
See Also:
Oracle Database PL/SQL Packages and Types Reference for more information about the DBMS_TTS.TRANSPORT_SET_CHECK
procedure and corresponding view
21.3.3 Identifying and Preserving Objects That Are Lost After TSPITR
When you perform RMAN TSPITR on a tablespace, objects created after the target recovery time are lost. You can preserve such objects after they are identified by exporting them before TSPITR with the Data Pump Export utility and reimporting them afterward with Data Pump Import.
To determine which objects are lost in TSPITR, query the TS_PITR_OBJECTS_TO_BE_DROPPED
view on the primary database. Filter the view for objects whose CREATION_TIME
is after the target time for TSPITR. The following table describes the contents of the view.
Table 21-2 TS_PITR_OBJECTS_TO_BE_DROPPED View
Column Name | Meaning |
---|---|
|
Owner of the object to be dropped |
|
The name of the object that is lost by undergoing TSPITR |
|
Creation time stamp for the object |
|
Name of the tablespace containing the object |
Example 21-2 Querying TS_PITR_OBJECTS_TO_BE_DROPPED
This example displays the objects that need to be preserved when performing TSPITR with a recovery set consisting of users
and tools
and a recovery point in time of November 2, 2017, 7:03:11 am.
SELECT OWNER, NAME, TABLESPACE_NAME, TO_CHAR(CREATION_TIME, 'YYYY-MM-DD:HH24:MI:SS') FROM TS_PITR_OBJECTS_TO_BE_DROPPED WHERE TABLESPACE_NAME IN ('USERS','TOOLS') AND CREATION_TIME > TO_DATE('02-NOV-17:07:03:11','YY-MON-DD:HH24:MI:SS') ORDER BY TABLESPACE_NAME, CREATION_TIME;
The TO_CHAR
and TO_DATE
functions are used to avoid issues with different national date formats. Of course, you can use local date formats in your own work.
Example 21-3 Using SCN and TS_PITR_OBJECTS_TO_BE_DROPPED
If the SCN to recover tablespaces USERS
and TOOLS
is 1645870, this example determines the objects that are dropped. Use conversion functions to determine the time stamp associated with the SCN and the objects that are dropped.
SELECT OWNER, NAME, TABLESPACE_NAME, TO_CHAR(CREATION_TIME,'YYYY-MM-DD:HH24:MI:SS') FROM TS_PITR_OBJECTS_TO_BE_DROPPED WHERE TABLESPACE_NAME IN ('USERS','TOOLS') AND CREATION_TIME > TO_DATE(TO_CHAR(SCN_TO_TIMESTAMP(1645870), 'MM/DD/YYYY HH24:MI:SS'), 'MM/DD/YYYY HH24:MI:SS') ORDER BY TABLESPACE_NAME, CREATION_TIME;
See Also:
Oracle Database Reference for more information about the TS_PITR_OBJECTS_TO_BE_DROPPED
view
21.4 Performing Fully Automated RMAN TSPITR
In the default mode, RMAN bases as much of the configuration for TSPITR as possible on the target database.
During TSPITR, the recovery set data files are written in their current locations on the target database (For OMF files, see "Limitations of TSPITR"). The same channel configurations for the target database are used on the auxiliary database when restoring files from backup. Auxiliary set data files and other auxiliary database files, however, are stored in the auxiliary destination.
Use the AUXILIARY DESTINATION
parameter to set a location for RMAN to use for the auxiliary set data files. The auxiliary destination must be a location on disk with enough space to hold auxiliary set data files. Even if you use other techniques to rename some or all of the auxiliary set data files, specifying an AUXILIARY DESTINATION
parameter provides a default location for auxiliary set data files for which names are not specified. TSPITR does not fail if you inadvertently do not provide names for all auxiliary set data files.
To perform fully automated RMAN TSPITR, the user performing TSPITR must be able to connect with the SYSBACKUP
or SYSDBA
privilege using operating system authentication.
To perform fully automated RMAN TSPITR:
21.5 Overriding Defaults for RMAN TSPITR with an RMAN-Managed Auxiliary Database
You can customize some aspects of RMAN TSPITR while still mostly following the procedure for performing fully automated RMAN TSPITR.
These include the following:
-
Rename or relocate your recovery set data files so that the data files making up the recovered tablespaces are not stored in the original locations after TSPITR. This may be necessary if the disk that originally contained the tablespace is not usable.
-
Specify a location other than the auxiliary destination for some or all auxiliary set data files. You might choose this option if no single location on disk has enough space for all auxiliary set files.
-
Rename files in an Oracle Managed Files format.
-
Set up image copy backups of your auxiliary set data files in advance to avoid having to restore data files during TSPITR.
-
Customize initialization parameters for your RMAN-managed auxiliary database.
21.5.1 Renaming TSPITR Recovery Set Data Files with SET NEWNAME
You may not want the recovery set data files restored and recovered in their original locations. The SET NEWNAME
command enables you to specify a new destination. When you specify a new destination for the recovery set, RMAN does not remove the original data files of the tablespaces.
To specify new recovery set file names, create a RUN
block and use SET NEWNAME
commands within it. Be sure to assign names that do not conflict with each other or with the names of your current data files.
Example 21-4 Renaming Recovery Set Files
This example specifies new names for recovery set data files. In this example, RMAN takes the following actions:
-
Restores each specified data file to the new location during TSPITR.
-
Uses the image copy if one exists at the specified location and its checkpoint is before the specified point in time. If this criteria is not met, then RMAN overwrites the image copy.
-
Plugs the newly recovered data file into the target control file.
RMAN does not detect conflicts between names set with SET NEWNAME
and current data file names on the target database until the actual recovery. If RMAN detects a conflict, then TSPITR fails and RMAN reports an error. The valid data file is not overwritten.
RUN { . . . SET NEWNAME FOR DATAFILE 'ORACLE_HOME/oradata/trgt/users01.dbf' TO '/newfs/users01.dbf'; ...other SET NEWNAME commands... RECOVER TABLESPACE users, tools UNTIL SEQUENCE 1300 THREAD 1; }
21.5.2 Naming TSPITR Auxiliary Set Data Files
Unlike recovery set data files, which are usually stored in their original locations, auxiliary set data files must not overwrite the corresponding original files in the target database. If you do not specify an auxiliary set file location that is different from its original location, then TSPITR fails. The failure occurs when RMAN attempts to overwrite the corresponding file in the original database and discovers the file in use.
The simplest way to provide locations for auxiliary set data files is to specify an auxiliary destination for TSPITR. However, RMAN supports the following alternatives for controlling the location of auxiliary set data files, which are listed in order of precedence shown in Table 21-3.
Table 21-3 Order of Precedence for Naming Files
Order | Technique | Section |
---|---|---|
1 |
|
"Using SET NEWNAME to Name Auxiliary Set Data Files During TSPITR" |
2 |
|
"Using SET NEWNAME and CONFIGURE AUXNAME with Auxiliary Set Image Copies" |
3 |
|
"Using DB_FILE_NAME_CONVERT to Name Auxiliary Set Data Files During TSPITR". If the target database uses OMF names for auxiliary set, then you cannot use |
4 |
|
Settings higher on the list override settings lower on the list in situations where both have been applied. For example, you might run RECOVER TABLESPACE... AUXILIARY DESTINATION
on a target database when some auxiliary set data files have auxiliary names configured with CONFIGURE AUXNAME
.
Even if you intend to use either of the preceding techniques to provide locations for specific files, Oracle recommends that you provide an AUXILIARY DESTINATION
argument to RECOVER TABLESPACE
when using an RMAN-managed auxiliary database. If you overlook renaming some auxiliary set data files, then TSPITR still succeeds. Any files not otherwise renamed are placed in the auxiliary destination.
Note:
You can view any current CONFIGURE AUXNAME
settings by running the SHOW AUXNAME
command, which is described in Oracle Database Backup and Recovery Reference.
21.5.2.1 Considerations When Renaming OMF Auxiliary Set Files in TSPITR
Auxiliary set data files can have Oracle Managed Files (OMF) in the target and can use Automatic Storage Management (ASM) or non-ASM storage. TSPITR performs name conversion differently when the DB_FILE_NAME_CONVERT
initialization parameter is set and the OMF files are in ASM or non-ASM storage.
21.5.2.1.1 Using ASM Storage
You can use DB_FILE_NAME_CONVERT
and LOG_FILE_NAME_CONVERT
initialization parameters for the auxiliary database to specify the conversion of the disk group. RMAN uses the pattern to convert the ASM disk group name and generates a valid OMF file name in the converted disk group.
For Oracle Managed Files (OMF) that use ASM storage, the database converts only disk group names as in: +DISK1 to +DISK2.
The following command specifies the conversion for the log files:
LOG_FILE_NAME_CONVERT='+onlinelogs','+tmpasm'
If the DB_FILE_NAME_CONVERT
and LOG_FILE_NAME_CONVERT
parameters change a substring other than the disk group name, the conversion is ignored and the resulting disk group name is used. For example:
DB_FILE_NAME_CONVERT='+DATAFILE/prod','+DATAFILE/tspitr'
The preceding command results in an invalid ASM OMF file name and the change is ignored. Instead, the files are created in disk group name +DATAFILE and the following message is issued:
WARNING: DB_FILE_NAME_CONVERT resulted in invalid ASM names; names changed to disk group only
If auxiliary set data files are stored in ASM disk groups, then you can use the SET NEWNAME
command to redirect individual files to a specific disk group accessible from the auxiliary database (and allow the database to generate the file name within the disk group).
Example 21-5 Redirecting ASM files
This example shows how to use the SET NEWNAME
command to redirect individual files to a specific disk group.
RUN { SET NEWNAME FOR DATAFILE 1 TO "+DISK2"; SET NEWNAME FOR DATAFILE 2 TO "+DISK3"; RECOVER TABLESPACE users, tools UNTIL LOGSEQ 1300 THREAD 1 AUXILIARY DESTINATION '/disk1/auxdest'; }
21.5.2.1.2 Using Non-ASM Storage
Multiple methods are available to rename OMF (non-ASM) file names for the auxiliary database.
The initialization parameters DB_FILE_NAME_CONVERT
and LOG_FILE_NAME_CONVERT
cannot be used to rename OMF (non-ASM) file names for the auxiliary database because this method generates invalid OMF file names. If you must control the generation of new OMF file names that do not use ASM storage, you must rename them using one of the following alternate techniques.
The various naming options are listed in order from most recommended to least recommended.
21.5.2.2 Using SET NEWNAME to Name Auxiliary Set Data Files During TSPITR
To specify a new name for an auxiliary set data file, you can enclose RECOVER TABLESPACE
in a RUN
command and use a SET NEWNAME
command within the RUN
block to rename the file.
Example 21-6 Renaming Auxiliary Set Oracle Managed Files (OMF) in TSPITR
This example illustrates the basic technique of using SET NEWNAME to rename files. The result depends on whether /disk1/auxdest/system01.dbf
exists when RECOVER TABLESPACE
is executed. If ?/oradata/system01.dbf
exists at the specified location and was created at an SCN before the UNTIL
time for TSPITR, then the DATAFILECOPY
is used and the restore operation is not necessary. Otherwise, RMAN restores the auxiliary set data file to the NEWNAME
instead of the default location. If your intention is to control where the auxiliary set data files are stored, then ensure that no file is stored at the location specified by SET NEWNAME
before performing TSPITR.
RUN { SET NEWNAME FOR DATAFILE '?/oradata/prod/system01.dbf' TO '/disk1/auxdest/system01.dbf'; SET NEWNAME FOR DATAFILE '?/oradata/prod/sysaux01.dbf' TO '/disk1/auxdest/sysaux01.dbf'; SET NEWNAME FOR DATAFILE '?/oradata/prod/undotbs01.dbf' TO '/disk1/auxdest/undotbs01.dbf'; RECOVER TABLESPACE users, tools UNTIL LOGSEQ 1300 THREAD 1 AUXILIARY DESTINATION '/disk1/auxdest'; }
21.5.2.3 Using DB_FILE_NAME_CONVERT to Name Auxiliary Set Data Files During TSPITR
When you do not want to use an auxiliary destination for all of your auxiliary set data files, but you also do not want to name every file individually, you can include a DB_FILE_NAME_CONVERT
initialization parameter in the initialization parameter file used by the auxiliary database.
You can use this technique only when one of the following situations exists:
-
You create your own initialization parameter file for an automatically managed auxiliary database, as described in "Customizing Initialization Parameters for the Automatic Auxiliary Database in TSPITR"
-
You create your own auxiliary database, as described in "Performing RMAN TSPITR Using Your Own Auxiliary Database"
The DB_FILE_NAME_CONVERT
initialization parameter in the auxiliary database specifies how to derive names for files in the auxiliary database from the original names of the corresponding files in the target database instance. The parameter consists of a list of pairs of strings. For any file name that contains the first string of a pair as a substring, the name of the corresponding file in the auxiliary database is generated by substituting the second string of the pair into the original file name.
For example, assume that the target instance contains the following files:
-
?/oradata/trgt/system01.dbf
of theSYSTEM
tablespace -
?/oradata/trgt/sysaux01.dbf
of theSYSAUX
tablespace -
?/oradata/trgt/undotbs01.dbf
of theundotbs
tablespace
To place the corresponding files of the auxiliary database in /bigtmp
, you add the following line to the auxiliary database parameter file:
DB_FILE_NAME_CONVERT=('?/oradata/trgt', '/bigtmp')
New file names for the corresponding auxiliary database files are /bigtmp/trgt/system01.dbf
, /bigtmp/trgt/sysaux01.dbf
, and /bigtmp/trgt/undotbs01.dbf
.
The most important point to remember is that DB_FILE_NAME_CONVERT
must be present in the auxiliary database parameter file. If the auxiliary database was manually created, then add DB_FILE_NAME_CONVERT
to the auxiliary database parameter file.
You can still rename individual auxiliary set data files with the SET NEWNAME
or CONFIGURE AUXNAME
command. Also, files that do not match the patterns provided in DB_FILE_NAME_CONVERT
are not renamed. When using RMAN-managed auxiliary database, you can use the AUXILIARY DESTINATION
parameter of RECOVER TABLESPACE
command to ensure that all auxiliary set data files are sent to some destination. If the renaming methods do not provide a new name for a file at the auxiliary database, then TSPITR fails.
21.5.2.3.1 Renaming Temp Files During TSPITR
Temp files are considered part of the auxiliary set for your database. When the auxiliary database is instantiated, RMAN recreates the temporary tablespaces of the target database and generates their names with the regular rules for the auxiliary data file names.
To rename temp files, you can use one of the following:
-
SET NEWNAME FOR TEMPFILE
command -
DB_FILE_NAME_CONVERT
initialization parameter of the auxiliary database. If the temporary files have non-ASM Oracle Managed File names, you cannot use this parameter option. -
AUXILIARY DESTINATION
clause of theRECOVER
command when using an RMAN-managed auxiliary database
21.5.3 Using Image Copies for Faster RMAN TSPITR Performance
TSPITR performance can be enhanced by redirecting RMAN to use existing image copies of the recovery set and auxiliary set data files. In this case, RMAN does not need to restore the data files from backup.
In general, if a suitable image copy is available in the specified location, then RMAN uses the image copy to perform TSPITR, and the data file copy is uncataloged from the target control file.
You can use the following techniques to tell RMAN about the possible existence of an image copy of a data file:
-
Use the
CONFIGURE AUXNAME
command with image copies of auxiliary set data files -
Use the
SET NEWNAME
command with image copies of recovery set data files or auxiliary set data files
21.5.3.1 Using SET NEWNAME with Recovery Set Image Copies
The SET NEWNAME
command enables you to specify the location of the image copies when performing TSPITR using image copies.
During TSPITR, RMAN looks in the specified NEWNAME
location for the data file. RMAN checks whether an image copy backup of the data file exists with a data file checkpoint SCN early enough that it can be recovered to the target time. If RMAN finds a usable image copy, then RMAN uses it in TSPITR. Otherwise, RMAN restores the data file to the NEWNAME
location. Any file in the location specified by the NEWNAME
is overwritten. The specified NEWNAME
becomes the name of the data file in the target database after TSPITR completes.
Example 21-7 Using SET NEWNAME
This example performs TSPITR by using image copies of recovery set files. The SET NEWNAME
command specifies the location of the image copies of the specified tablespace.
RUN { SET NEWNAME FOR DATAFILE 'ORACLE_HOME/oradata/trgt/users01.dbf' TO '/newfs/users1.dbf'; ...other RMAN commands, if any... RECOVER TABLESPACE users, tools UNTIL SEQUENCE 1300 THREAD 1; }
21.5.3.2 Using SET NEWNAME and CONFIGURE AUXNAME with Auxiliary Set Image Copies
The CONFIGURE AUXNAME
command sets a persistent alternative location for an auxiliary set data file image copy, whereas the SET NEWNAME
command sets an alternative location for the duration of a RUN
command.
Assume that you use SET NEWNAME
or CONFIGURE AUXNAME
to specify a new location for an auxiliary set data file. Also assume that there is an image copy at that location with an SCN that can be used in TSPITR. In this case, RMAN uses the image copy. If there is no usable image copy at that location, however, then RMAN restores a usable copy from backup. (If an image copy is present but the SCN is after the target time for TSPITR, then the data file is overwritten by the restored file.)
As with all auxiliary set files, the file is deleted after TSPITR. This behavior occurs regardless of whether it was an image copy created before TSPITR or restored by RMAN during TSPITR.
The primary use of CONFIGURE AUXNAME
is to make TSPITR faster by eliminating restore times. If you anticipate performing TSPITR, then you can include in your backup routine the maintenance of a set of image copies of the auxiliary set data files, and update these periodically to the earliest point to which you expect to perform TSPITR. The recommended usage model is:
- Configure the
AUXNAME
for the files once when setting up this strategy. - Perform
BACKUP AS COPY DATAFILE n FORMAT auxname
regularly to maintain the updated image copy. For better performance, use an incrementally updated backup strategy to keep the image copies up-to-date without performing full backups of the data files. - When TSPITR is needed, specify a target time after the last update of the image copy.
21.5.3.3 Performing TSPITR with CONFIGURE AUXNAME and Image Copies: Scenario
This procedure uses CONFIGURE AUXNAME
when performing TSPITR using image copies.
Assume that you have enough disk space to save image copies of your entire database for use in TSPITR. In preparation for the possibility of TSPITR, you do the following:
-
Configure an
AUXNAME
for each data file in the auxiliary set by using a command of the following form:CONFIGURE AUXNAME FOR DATAFILE n TO auxname_n;
-
Take an image copy of the auxiliary set every Sunday by using a command of the following form:
BACKUP AS COPY DATAFILE n FORMAT auxname_n
If the image copies are all in the same location on disk, and if they are named similarly to the original data files, then you can avoid performing backups of every data file. Instead, you can use the
FORMAT
orDB_FILE_NAME_CONVERT
options of theBACKUP
command and useBACKUP AS COPY DATABASE
. For example, if the configured auxiliary names are a translation of the locationmaindisk
toauxdisk
, then you use the following command:BACKUP AS COPY DATABASE DB_FILE_NAME_CONVERT (maindisk, auxdisk);
Note:
Because Oracle managed file names cannot generally be translated using a simple substitution, you cannot typically use
DB_FILE_NAME_CONVERT
to generate names for image copies stored in OMF.
After these steps, you are prepared for TSPITR without restoring the auxiliary set from backup. For example, if an erroneous batch job, started on November 15, 2013, at 19:00:00, incorrectly updates the tables in the tablespace parts
, you use the following command to perform TSPITR on tablespace parts
:
RECOVER TABLESPACE parts UNTIL TIME 'November 15 2013, 19:00:00';
Because AUXNAME
locations are configured and refer to data file copies from an SCN before the TSPITR target time, the auxiliary set is not restored from backup. Instead, the data file copies are used in recovery, which reduces the restore overhead.
You can also prevent the recovery set from being restored. You must take frequent image copies of the tablespaces and use SET NEWNAME
to specify the location of these copies. This method ensures that the recovery set is not restored and the tablespace changes location after TSPITR successfully completes.
21.5.4 Customizing Initialization Parameters for the Automatic Auxiliary Database in TSPITR
The automatic auxiliary database uses a set of default initialization parameters. You can add other parameters, if required.
The automatic auxiliary database looks for additional initialization parameters to complement the default parameters in a location that is operating system-dependent. For example, in UNIX this location is: ?/rdbms/admin/params_auxinst.ora
. RMAN always looks for this additional parameter file for an RMAN-automatic auxiliary database when performing TSPITR. If the file is not found, then RMAN does not generate an error. Instead, RMAN uses the default parameters listed in the following table for the RMAN-managed automatic auxiliary database.
Table 21-4 Default Initialization Parameters for the RMAN-Managed Auxiliary Database
Initialization Parameter | Value |
---|---|
|
Same as |
|
Same as the |
|
RMAN auto-generated unique value based on |
|
Same as the |
|
Auxiliary destination (only if the |
|
Auxiliary destination (only if the |
|
|
|
Same as |
|
|
Usually it is not necessary to alter or add to the values of these initialization parameters, especially if you provide an AUXILIARY DESTINATION
clause to the RECOVER TABLESPACE
command when using a RMAN-managed auxiliary database. If you override an initialization parameter in Table 21-4 with an inappropriate value, then TSPITR may fail due to problems with the auxiliary database. Nevertheless, you can add other parameters besides these basic parameters if needed. For example, you can use DB_FILE_NAME_CONVERT
to specify the names of the data files in the auxiliary and recovery sets.
To override or specify parameters for the automatic auxiliary database, you can do either of the following:
-
Place the initialization parameters in the operating system specific default auxiliary parameter file name. For example, in UNIX, the file name is:
?/rdbms/admin/params_auxinst.ora
. -
Perform these steps:
-
Place the initialization parameters in a file.
-
Specify the location of this file with the
SET AUXILIARY INSTANCE PARAMETER FILE
command before executing TSPITR.
-
Regardless of the method that you choose, the parameters that you specify take precedence over defaults and can override the value of an AUXILIARY DESTINATION
clause.
This section contains the following topics:
21.5.4.1 Specifying the Auxiliary Database Control File Location in TSPITR
If you use an initialization parameter file, then you can use the CONTROL_FILES
initialization parameter to specify your own location for the control file of your auxiliary database
If you do not explicitly specify a control file location, and if you use the AUXILIARY DESTINATION
clause, then RMAN locates the control file in the auxiliary destination. If you do not use the AUXILIARY DESTINATION
clause, then the auxiliary database control files are stored in an operating system-specific location.
No matter where you store your auxiliary database control file, it is removed at the end of the TSPITR operation. Because control files are relatively small, it is rare that RMAN encounters a problem creating an auxiliary control file. If there is not enough space to create the control file, however, then TSPITR fails.
21.5.4.2 Specifying the Auxiliary Database Archived Logs in TSPITR
To perform recovery on the auxiliary and recovery sets after restoring them at the auxiliary database, RMAN may need to restore archived logs. When an auxiliary destination is being used, the archived logs are restored to that location.
In the absence of an auxiliary destination and any other initialization parameters, the archived logs are restored to an operating system specific location. For details, consult your operating system specific documentation. You can use the LOG_ARCHIVE_DEST_1
initialization parameter to specify an alternative location where the archived logs are restored.
21.5.4.3 Specifying the Auxiliary Database Online Log Location in TSPITR
If you specify the LOG_FILE_NAME_CONVERT
initialization parameter in your auxiliary database parameter file and the parameter successfully converts the names of the online redo logs of the target, then this parameter determines the online redo log location.
The same restrictions that apply to OMF data files, as described in "Considerations When Renaming OMF Auxiliary Set Files in TSPITR", apply to OMF online redo logs. If RMAN is managing the auxiliary database and an auxiliary destination is specified, RMAN creates the online redo log in the auxiliary destination.
Alternatively, you can use DB_CREATE_FILE_DEST
or DB_CREATE_FILE_DEST
and DB_CREATE_ONLINE_LOG_1
to specify the location where the auxiliary database redo logs are created. If you choose the latter option, then you must use DB_CREATE_ONLINE_LOG_1
with DB_CREATE_FILE_DEST
.
TSPITR fails to create the online redo logs if you do not specify a location for them by using one of the following:
-
LOG_FILE_NAME_CONVERT
-
DB_CREATE_FILE_DEST
-
DB_CREATE_FILE_DEST
andDB_CREATE_ONLINE_LOG_1
-
AUXILIARY DESTINATION
21.6 Performing RMAN TSPITR Using Your Own Auxiliary Database
Although Oracle recommends that you let RMAN manage all aspects of the auxiliary database, there may be times when you must create and manage your own auxiliary database. If you select this mode, you are responsible for setting up, starting, stopping and cleaning up the auxiliary database used in TSPITR.
One reason that you might want to create your own instance is to exercise control of channels used in TSPITR. The automatic auxiliary database uses the configured channels of the target database as the basis for the channels to configure on the auxiliary database and to use during the restore operation. You may need different channel settings and may not want to use the CONFIGURE
command to change the settings on the target database. In this case, you can operate your own auxiliary database. By connecting to the auxiliary database before invoking RECOVER
, a run block can provide specific channel allocations using the ALLOCATE AUXILIARY CHANNEL
command.
This section contains the following topics:
21.6.1 Preparing Your Own Auxiliary Database for RMAN TSPITR
Creating an Oracle instance suitable for use as an auxiliary database requires you to perform a set of steps.
The steps include the following:
21.6.1.1 Step 1: Create an Oracle Password File for the Auxiliary Database
There are multiple ways to create a password file for the auxiliary database.
See Also:
Oracle Database Administrator’s Guideto learn how to create and maintain Oracle password files
21.6.1.2 Step 2: Create an Initialization Parameter File for the Auxiliary Database
Use a text editor to create an initialization parameter file for the auxiliary database on the target database host.
Note:
For TSPITR, the target and auxiliary database instances must be on the same host.
In this example, assume that your parameter file is placed at /tmp/initAux.ora
. Set the parameters described in the following table:
Table 21-5 Initialization Parameters in a User-Managed Auxiliary Database
Initialization Parameter | Mandatory? | Value |
---|---|---|
|
YES |
The same name as the target database |
|
YES |
A value different from any database in the same Oracle home. For simplicity, specify |
|
YES |
Set to |
|
YES |
The same value as the parameter in the target database |
|
YES |
If this initialization parameter is set in the target database, then it must be set to the same value in the auxiliary database. |
|
NO |
Patterns to generate file names for the online redo logs of the auxiliary database based on the online redo log names of the target database. Query Note: Some platforms do not support ending patterns in a forward or backward slash ( See Also: "Specifying the Auxiliary Database Online Log Location in TSPITR" for restrictions on possible values for |
|
NO |
Patterns to convert file names for the data files of the auxiliary database. You can use this parameter to generate file names for those files that you did not name with Note: Some platforms do not support ending patterns in a forward or backward slash ( See Also: "Using DB_FILE_NAME_CONVERT to Name Auxiliary Set Data Files During TSPITR" and "Considerations When Renaming OMF Auxiliary Set Files in TSPITR". |
|
NO |
Identifies a location for all auxiliary set files. |
|
NO |
Identifies where archived logs required for recover are created. |
|
NO |
With |
|
NO |
File names that do not conflict with the control file names of the target instance (or any other existing file). |
|
NO (Recommended) |
|
|
NO YES |
If If |
Set other parameters as needed, including the parameters to specify how much memory the auxiliary database uses.
The following example shows possible initialization parameter settings for an auxiliary database for TSPITR:
DB_NAME=trgt DB_UNIQUE_NAME=_trgt CONTROL_FILES=/tmp/control01.ctl DB_FILE_NAME_CONVERT=('/oracle/oradata/trgt/','/tmp/') LOG_FILE_NAME_CONVERT=('/oracle/oradata/trgt/redo','/tmp/redo') REMOTE_LOGIN_PASSWORDFILE=exclusive COMPATIBLE =11.0.0 DB_BLOCK_SIZE=8192
Note:
After setting these initialization parameters, ensure that you do not overwrite the initialization settings for the production files at the target database.
21.6.1.3 Step 3: Check Oracle Net Connectivity to the Auxiliary Database
The auxiliary database must have a valid net service name. Before proceeding, use SQL*Plus to ensure that you can establish a SYSBACKUP
or SYSDBA
connection to the auxiliary database.
See Also:
Oracle Database Administrator’s Guide for more information about Oracle Net
21.6.2 Preparing RMAN Commands for TSPITR with Your Own Auxiliary Database
Keep in mind certain guidelines when performing TSPITR with your own auxiliary instance.
If you run your own auxiliary database, then it is possible for the sequence of commands required for TSPITR to be long. This situation can occur when you allocate a complex channel configuration for restoring from backup and you are not using DB_CREATE_FILE_DEST
to determine file naming of auxiliary set files.
You may want to store the series of commands for TSPITR in an RMAN command file. Review the command file carefully to catch any errors. To read the command file into RMAN, use the @
command (or the CMDFILE
command-line argument when starting RMAN).
The following example runs the command file named /tmp/tspitr.rman
:
@/tmp/tspitr.rman;
See Also:
21.6.2.1 Planning Channels for TSPITR with Your Own Auxiliary Database
The default behavior for channels when you use your own auxiliary database for TSPITR can be overridden.
When you run your own auxiliary database, the default behavior is to use the automatic channel configuration of the target database. If you decide to allocate your own channels with a different configuration (changing the number of channels or channel parameters), you can include ALLOCATE AUXILIARY CHANNEL
commands in a RUN
block along with the RECOVER TABLESPACE
command for TSPITR. Plan these commands, if necessary, and add them to the sequence of commands you run for TSPITR.
See Also:
"Performing TSPITR with Your Own Auxiliary Database: Scenario" to learn how to include channel allocation in your TSPITR script
21.6.2.2 Planning Data File Names with Your Own Auxiliary Database: SET NEWNAME
You may want to use SET NEWNAME
commands to refer to existing image copies of auxiliary set files to improve TSPITR performance, or to assign new names to the recovery set files for after TSPITR. Plan these commands, if necessary, and add them to the sequence of commands that you run for TSPITR.
21.6.3 Executing TSPITR with Your Own Auxiliary Database
Complete the prerequisites and then follow the steps in this section to perform TSPITR with your own auxiliary database.
Prerequisites to perform this task include:
Use the following steps to perform TSPITR with your own auxiliary instance:
21.6.3.1 Step 1: Start the Auxiliary Database in NOMOUNT Mode
Before beginning RMAN TSPITR, you must start the auxiliary database. Because the auxiliary database does not yet have a control file, you can only start the instance in NOMOUNT
mode.
Do not create a control file or try to mount or open the auxiliary database for TSPITR.
To start the auxiliary database:
-
Start SQL*Plus and connect to the auxiliary database with
SYSOPER
privileges. -
Start the auxiliary database in
NOMOUNT
mode, specifying a parameter file if necessary.For example, enter the following SQL*Plus command:
SQL> STARTUP NOMOUNT PFILE='/tmp/initAux.ora'
Remember that if you specify
PFILE
, then the path for thePFILE
is a client-side path on the host from which you run SQL*Plus.
21.6.3.2 Step 2: Connect the RMAN Client to Target and Auxiliary Databases
Start RMAN and connect to the target database and the manually created auxiliary database.
For example, use a command such as the following:
rman target dba AUXILIARY auxusr@aux
See Also:
21.6.3.3 Step 3: Execute the RECOVER TABLESPACE Command
Use the RECOVER TABLESPACE
command to perform TSPITR with your own auxiliary instance.
In the simplest case, run a RECOVER TABLESPACE... UNTIL
command such as the following at the RMAN prompt:
RECOVER TABLESPACE ts1, ts2... UNTIL TIME 'time';
If you want to use the ALLOCATE AUXILIARY CHANNEL
or SET NEWNAME
commands, then include these commands before the RECOVER TABLESPACE
command within a RUN
command. The following example illustrates this technique:
RUN
{
ALLOCATE AUXILIARY CHANNEL c1 DEVICE TYPE DISK;
ALLOCATE AUXILIARY CHANNEL c2 DEVICE TYPE sbt;
# and so on...
RECOVER TABLESPACE ts1, ts2 UNTIL TIME 'time';
}
21.6.4 Performing TSPITR with Your Own Auxiliary Database: Scenario
This procedure uses the RECOVER TABLESPACE... UNTIL
command to perform TSPITR.
This scenario illustrates the following features of RMAN TSPITR:
-
Managing your own auxiliary database
-
Configuring channels for restore of backups from disk and SBT devices
-
Using recoverable image copies for some auxiliary set data files using
SET NEWNAME
-
Specifying new names for recovery set data files using
SET NEWNAME
To use TSPITR with your own auxiliary database:
Consider storing this command sequence in a command file and executing the command file.
If the TSPITR operation is successful, then the results are:
-
The recovery set data files are registered in the target database control file under the names specified with
SET NEWNAME
, with their contents as of the time specified time for TSPITR. -
The auxiliary files are removed by RMAN, including the control files, online logs, and auxiliary set data files of the auxiliary database.
-
The auxiliary database is shut down.
If the TSPITR operation fails, the auxiliary set files are removed and the auxiliary database is shut down. The recovery set files are left in the specified location and in an unresolved state from the failed TSPITR run.
21.7 Troubleshooting RMAN TSPITR
A variety of problems can cause RMAN TSPITR to fail. The problem must be identified and fixed.
Some of the possible areas to check and fix are as follows:
-
File name conflicts
-
Mismatched or incorrect TSPITR target times for sets of tablespaces and undo segments
-
Management issues with auxiliary databases not created by RMAN
21.7.1 Troubleshooting File Name Conflicts During TSPITR
Name conflicts can occur between files in the target database, file names assigned by the SET NEWNAME
or CONFIGURE AUXNAME
commands, and file names generated by the effect of the DB_FILE_NAME_CONVERT
parameter.
Suppose that SET NEWNAME
, CONFIGURE AUXNAME
, and DB_FILE_NAME_CONVERT
cause multiple files in the auxiliary or recovery sets to have the same name. In this case, RMAN reports an error during TSPITR. To correct the problem, use different values for these parameters.
21.7.2 Troubleshooting the Identification of Tablespaces with Undo Segments During TSPITR
During TSPITR, RMAN needs information about which tablespaces had undo segments at the TSPITR target time. This information is usually available in the recovery catalog, if one is used.
If there is no recovery catalog or if the information is not found in the recovery catalog, RMAN assumes that the set of tablespaces with undo segments at the target time equals the set of tablespaces with undo segments at the present time. If this assumption is not correct, then TSPITR fails with an error. In this case, use the UNDO TABLESPACE
clause to provide a list of tablespaces with undo segments at the target time.
21.7.3 Troubleshooting the Restart of a Manual Auxiliary Database After TSPITR Failure
If you are managing your own auxiliary database and TSPITR fails, do not attempt to rerun TSPITR without resolving the errors.
You must follow this approach:
- Identify and fix the problems that prevented TSPITR from a successful run.
- Start the auxiliary database in
NOMOUNT
. - Run TSPITR again.