Skip to main content
Recover database from the downloaded backup data
Updated over 6 months ago

After the backup data is downloaded, the DBA can run RMAN scripts to fetch backup data from the restore location and restore the database on the required Oracle server host. To proceed with the database recovery, the DBA must have permission to access the restore directory and its parent directory.

To recover a database, ensure that the control file in the current database is intact. If the control file is damaged, you must identify the control file from the downloaded backup data and proceed with the recovery.


From agent version 7.0.1-477342, for every manual restore, a README file is created at the same location as the restored data. This file contains instructions for performing the restore and has a sample configure/allocate channel command, which you can directly copy and use in the restore script.

Procedure

The following section provides instructions to recover the database from the downloaded backup data:

Recover database when the control file is intact

  1. Open the RMAN command prompt using the following command:

    $rman target <user>/<password>@<host_name>/<database_name>


    where,
    <user> has the

    SYSDBA/SYSBACKUP 

    privileges,
    <password> is the password specified by the SYSDBA in the orapwd file of the target database.
    Example:

    $rman target sys/oracle@localhost/autodb1
  2. Shutdown the active database using the following command :

    shutdown immediate;
    Step2.png
  3. Mount the database to initiate RMAN operations using the following command:

    startup mount;
    Step3.png
  4. Configure the SBT channel and provide the Druva SBT library located at /opt/Druva/PhoenixOracle/lib/libphxsbt.so (for agent version 6.x or earlier) or /opt/Druva/EnterpriseWorkloads/lib/oracledtc/libphxsbt.so (for agent version 7.x or later).
    For agent version 7.0.1-472646 or earlier, run the following configure channel command:

    configure channel device type sbt PARMS 'SBT_LIBRARY=/opt/Druva/PhoenixOracle/lib/libphxsbt.so (for agent version 6.x or earlier) or SBT_LIBRARY=/opt/Druva/EnterpriseWorkloads/lib/oracledtc/libphxsbt.so (for agent version 7.x or later),SBT_PARMS=(LogDirSuffix=restore_logs;RestoreFromLocalDir=/home/oracle/Wed-Jul-19-17-47-04-2023/437)';


    where,
    LogDirSuffix is the directory to save the restore logs.
    RestoreFromLocalDir is the directory where you have downloaded the backup data

    Step4.png


    From agent version 7.0.1-477342 onwards use the parameters mentioned in the README file to configure or allocate RMAN channels.

  5. Restore the database by running the following command:

    restore database;
  6. Recover the database by running the following command:

    recover database;
    Step6.png
  7. Open the database by running the following command:

    open database;
    Step7.png
  8. Check the status of the database after it is recovered.

    DB status after recover.png
  9. Back up the database based on your requirement.

Recover database when the control file is damaged

  1. Open the RMAN command prompt using the following command:

    $rman target <user>/<password>@<host_name>/<database_name>


    where,
    <user> has the

    SYSDBA/SYSBACKUP 

    privileges,
    <password> is the password specified by the SYSDBA in the orapwd file of the target database.
    Example:

    $rman target sys/oracle@localhost/autodb1
  2. Shutdown the active database using the following command :

    shutdown immediate;
    Step2-2.png
  3. Start the database in nomount mode by running the following command:

    startup nomount; 
    Step3-3.png
  4. Open RMAN command prompt and restore the control file. For agent version 7.0.1-472646 or earlier, run the following configure channel command: ​

    run { allocate channel ch0 device type sbt PARMS 'SBT_LIBRARY=/opt/Druva/PhoenixOracle/lib/libphxsbt.so (for agent version 6.x or earlier) or SBT_LIBRARY=/opt/Druva/EnterpriseWorkloads/lib/oracledtc/libphxsbt.so (for agent version 7.x or later),SBT_PARMS=(RestoreFromLocalDir=/home/oracle/Wed-Jul-19-18-20-53-2023/442/)'; restore controlfile from 'Phx_DN-AUTODB1_DBID-206331253_DT-20230719-175705_3221lu43_1_1_CF'; }


    Where,
    LogDirSuffix is the directory to save the restore logs.
    RestoreFromLocalDir is the directory where you have downloaded the backup data.

    Step4-4.png


    From agent version 7.0.1-477342 onwards, use the parameters mentioned in the README file to configure or allocate RMAN channels.

  5. Mount the database by running the following command:

    alter database mount;
    Step5-5.png
  6. Reset the database to incarnation using the following command:

    reset database to incarnation  <incarnation_no> ;


    For example:

    reset database to incarnation 46;


    You can get the <incarnation_no> from the metadata.json file that is available in the restore logs.

    image 9.png
  7. For agent version 7.0.1-472646 or earlier, run the following configure channel command to restore and recover the database:

    run{     allocate channel ch0 device type sbt PARMS 'SBT_LIBRARY=/opt/Druva/PhoenixOracle/lib/libphxsbt.so (for agent version 6.x or earlier) or SBT_LIBRARY=/opt/Druva/EnterpriseWorkloads/lib/oracledtc/libphxsbt.so (for agent version 7.x or later),SBT_PARMS=(RestoreFromLocalDir=/home/oracle/Wed-Jul-19-18-20-53-2023/442)';     allocate channel ch1 device type sbt PARMS 'SBT_LIBRARY=/opt/Druva/PhoenixOracle/lib/libphxsbt.so (for agent version 6.x or earlier) or SBT_LIBRARY=/opt/Druva/EnterpriseWorkloads/lib/oracledtc/libphxsbt.so (for agent version 7.x or later),SBT_PARMS=(RestoreFromLocalDir=/home/oracle/Wed-Jul-19-18-20-53-2023/442)';     allocate channel ch2 device type sbt PARMS 'SBT_LIBRARY=/opt/Druva/PhoenixOracle/lib/libphxsbt.so (for agent version 6.x or earlier) or SBT_LIBRARY=/opt/Druva/EnterpriseWorkloads/lib/oracledtc/libphxsbt.so (for agent version 7.x or later),SBT_PARMS=(RestoreFromLocalDir=/home/oracle/Wed-Jul-19-18-20-53-2023/442)';     allocate channel ch3 device type sbt PARMS 'SBT_LIBRARY=/opt/Druva/PhoenixOracle/lib/libphxsbt.so (for agent version 6.x or earlier) or SBT_LIBRARY=/opt/Druva/EnterpriseWorkloads/lib/oracledtc/libphxsbt.so (for agent version 7.x or later),SBT_PARMS=(RestoreFromLocalDir=/home/oracle/Wed-Jul-19-18-20-53-2023/442)';     crosscheck backup;     restore database;     recover database;     }

    📝 Note

    For PIT restore, in the above run command, after the crosscheck backup command add:
    set until time="to_date('11072023 05:16:01','ddmmyyyy hh24:mi:ss')";


    Step6-6.png


    From agent version 7.0.1-477342 onwards, use the parameters mentioned in the README file to configure or allocate RMAN channels.

  8. Open the database using the

     alter database open
    resetlogs 

    command

    .
  9. Check the status of the database after it is recovered.

    DB status after recover.png
  10. Back up the database based on your requirement.

Related articles

Did this answer your question?