Restore-VEORIRDatabase

Short Description

Performs instant recovery of a backed-up Oracle database.

Applies to

Veeam Backup & Replication

Product Edition: Enterprise, Enterprise Plus, Veeam Universal License

Syntax

Restore-VEORIRDatabase [-Database] <VEORDatabase> [-Server <String>] [-OracleHome <String>] [-GlobalDatabaseName <String>] [-OracleSid <String>] [-WindowsCredentials <PSCredential>] [-OracleHomePassword <SecureString>] [-LinuxCredentials <VEORLinuxCredential>] [-SshPort <Int32>] [-ToPointInTimeUTC <DateTime>] [-File <VEORDatabaseFile[]>] [-TargetPath <String[]>] -SwitchOverOptions <VEORIRSchedule> [-Force <SwitchParameter>] [<CommonParameters>]

Detailed Description

This cmdlet performs instant recovery of a backed-up Oracle database. You can recover the database to the original location or to another location. For details, see the Instant Recovery section of the Veeam Explorers User Guide.

Parameters

Parameter

Description

Type

Required

Position

Accept Pipeline Input

Database

Specifies an Oracle database that the cmdlet will restore.

Accepts the VEORDatabase object. To get this object, run the Get-VEORDatabase cmdlet.

True

0

True (ByValue)

SwitchOverOptions

Specifies a switchover option: Auto, Manual or Scheduled.

Accepts the VEORIRSchedule object. To get this object, run the New-VEORIRSwitchOverOptions cmdlet.

True

Named

True (ByValue)

Server

For restore to another server.

Specifies the name of the target server to which the database will be restored.

Note: Do not provide this parameter if you want to restore to the original server.

String

False

Named

False

OracleHome

For restore to another location.

Specifies the target Oracle home path. The cmdlet will restore an Oracle database to the location specified in the Oracle home path.

Note: Do not provide this parameter if you want to restore to the original location.

String

False

Named

False

GlobalDatabaseName

For restore to another location.

Specifies the global database name. The cmdlet will restore an Oracle database with the specified name.

Note: Do not provide this parameter if you want to restore to the original location.

String

False

Named

False

OracleSid

For restore to another location.

Specifies a new SID for an Oracle database. The cmdlet will restore the database with the specified SID.

Note: Do not provide this parameter if you want to restore to the original location.

String

False

Named

False

WindowsCredentials

For restore to a Windows machine.

Specifies Windows credentials that the cmdlet will use to connect to a Windows machine.

Accepts the PSCredential object. To get this object, run the Get-Credential cmdlet.

False

Named

False

OracleHomePassword

For restoring Oracle Database 12c or later on Windows server.

Specifies Oracle home credentials that the cmdlet will use for starting Oracle Services on the guest OS.

Note: This parameter is required in case you use the following types of Oracle home User:

  • Existing Windows user
  • New Windows user

SecureString

False

Named

False

LinuxCredentials

For restore to a Linux machine.

Specifies Linux credentials that the cmdlet will use to connect to a Linux machine.

Accepts the VEORLinuxCredential object. To get this object, run the New-VEORLinuxCredential cmdlet.

False

Named

False

ToPointInTimeUtc

Specifies a point in time in the UTC format within the restore interval of an Oracle database.

The cmdlet will restore the database to the state of the specified point in time.

DateTime

False

Named

False

File

Specifies an array of Oracle database files.

Accepts the VEORDatabaseFile[] object. To get this object, run the Get-VEORDatabaseFile cmdlet.

False

Named

False

TargetPath

Specifies the target path array. The cmdlet will restore the Oracle database files to the locations specified in the array.

Note: You must assign a specific file path for each Oracle database file.

String[]

False

Named

False

Force

Defines that the cmdlet will overwrite the existing Oracle database with the database from the backup.

Note: The cmdlet will show no prompt before executing the command.

SwitchParameter

False

Named

False

SshPort

For restore to a Linux machine.

Specifies the SSH port number that the cmdlet will use to connect to the Linux machine.

Default: 22

Int32

False

Named

False

<CommonParameters>

This cmdlet supports Microsoft PowerShell common parameters. For more information on common parameters, see the About CommonParameters section of Microsoft Docs.

Output Object

The cmdlet returns the VEORIRDatabase object that contains the Oracle database published within the instant recovery session.

Examples

Restore-VEORIRDatabaseExample 1. Performing Instant Recovery of Oracle Database to Original Location with Scheduled Switchover

This example shows how to perform instant recovery of the orcl database to the original location using the scheduled switchover option. The cmdlet will perform the switchover at 13:00:00 on 2023-11-24.

$time = Get-Date -Date "2023-11-24 13:00:00"

$TimeUtc = $time.ToUniversalTime()

$ScheduledSwitch = New-VEORIRSwitchOverOptions -Scheduled -SwitchingTimeUtc $TimeUtc

$session = Get-VEORRestoreSession

$database = Get-VEORDatabase -Session $session[0] -Name "orcl"

Restore-VEORIRDatabase -Database $database -SwitchOverOptions $ScheduledSwitch

Perform the following steps:

  1. Run the Get-Date cmdlet and specify the date and time when the switchover must be performed. Save the result to the $time variable.
  2. Convert the scheduled time to the UTC format using the ToUniversalTime() method. Save the result to the $TimeUtc variable.
  3. Run the New-VEORIRSwitchOverOptions cmdlet. Provide the Scheduled parameter and specify the SwitchingTimeUtc parameter value. Save the result to the $ScheduledSwitch variable.
  4. Run the Get-VEORRestoreSession cmdlet. Save the result to the $session variable.

The cmdlet will return an array of restore sessions. Note the ordinal number of the necessary restore session. In our example, it is the first restore session in the array.

  1. Run the Get-VEORDatabase cmdlet. Set the $session variable as the Session parameter value and select the necessary restore session. Specify the Name parameter value. Save the result to the $database variable.
  2. Run the Restore-VEORIRDatabase cmdlet. Set the $database variable as the Database parameter value. Set the $ScheduledSwitch variable as the SwitchOverOptions parameter value.

Restore-VEORIRDatabaseExample 2. Performing Instant Recovery of Oracle Database to Specific Server with Manual Switchover

This example shows how to perform instant recovery of the orcl database to its latest state with the following settings:

  • The cmdlet will restore the database to the linorcl01 target server.
  • The cmdlet will restore an Oracle database with the orcl_published.tech.local global database name.
  • The cmdlet will restore the database with the orclpub SID.
  • The cmdlet will restore an Oracle database to the /home/oracle/app/oracle/product/11.2.0/db_home_2 Oracle home path.
  • To perform the switchover operation manually, you must run the Switch-VEORIRDatabase cmdlet.

$restore = Get-VBRApplicationRestorePoint -Id fa4de91d-a493-41a8-88f7-1e29b0ab838d

$session = Start-VEORRestoreSession -RestorePoint $restore

$db = Get-VEORDatabase -Session $session -Name "orcl"

$ManualSwitch = New-VEORIRSwitchOverOptions -Manual

$plainpassword = "Password1234"

$securepassword = $plainpassword | ConvertTo-SecureString -AsPlainText -Force

$linuxCredentials = New-VEORLinuxCredential -Account "oracle" -Password $securepassword -ElevateAccountToRoot

$IRDatabase = Restore-VEORIRDatabase -Database $db -SwitchOverOptions $ManualSwitch -Server "linorcl01" -OracleSid "orclpub" -GlobalDatabaseName "orcl_published.tech.local" -LinuxCredentials $linuxCredentials -OracleHome '/home/oracle/app/oracle/product/11.2.0/db_home_2 -Force

Switch-VEORIRDatabase -Database $IRDatabase

Perform the following steps:

  1. Run the Get-VBRApplicationRestorePoint cmdlet. Specify the Id parameter value. Save the result to the $restore variable.
  2. Run the Start-VEORRestoreSession cmdlet. Set the $restore variable as the RestorePoint parameter value. Save the result to the $session variable.
  3. Run the Get-VEORDatabase cmdlet. Set the $session variable as the Session parameter value. Specify the Name parameter. Save the result to the $db variable.
  4. Run the New-VEORIRSwitchOverOptions cmdlet. Provide the Manual parameter. Save the result in the $ManualSwitch variable.
  5. Declare the $plainpassword variable. Assign to this variable the password that will be used to connect to the target server.
  6. Declare the $securepassword variable. Assign to this variable the $plainpassword variable. Pipe the $securepassword variable output to the ConvertTo-SecureString cmdlet. Provide the AsPlainText and Force parameters.
  7. Run the New-VEORLinuxCredential cmdlet. Specify the Account parameter value. Set the $securepassword variable as the Password parameter value. Provide the ElevateAccountToRoot parameter. Save the result to the $linuxCredentials variable.
  8. Run the Restore-VEORIRDatabase cmdlet. Specify the following settings:
  • Set the $db variable as the Database parameter value.
  • Set the $ManualSwitch variable as the SwitchOverOptions parameter value.
  • Specify the Server parameter value.
  • Specify the OracleSid parameter value.
  • Specify the GlobalDatabaseName parameter value.
  • Set the $linuxCredentials variable as the LinuxCredentials parameter value.
  • Specify the OracleHome parameter value.
  • Provide the Force parameter.

Save the result to the $IRDatabase variable.

  1. Run the Switch-VEORIRDatabase cmdlet. Set the $IRDatabase variable as the Database parameter value.

Related Commands

Page updated 6/20/2024

Page content applies to build 12.2.0.334