-
- Novice
- Posts: 9
- Liked: never
- Joined: Mar 26, 2021 12:49 pm
- Full Name: Tarandeep Singh
- Contact:
Case #04983558: Start-VESQLRestoreSession not working
Hi Team,
I had script to list out all the databases in sql backup job. Script was working well with veeam 10. However, it is not working well with the new powershell module in veeam 11.
I have been getting exception in command start-VESqlRestoreSession.
Error is mentioned in the screenshot below:
I had script to list out all the databases in sql backup job. Script was working well with veeam 10. However, it is not working well with the new powershell module in veeam 11.
I have been getting exception in command start-VESqlRestoreSession.
Error is mentioned in the screenshot below:
-
- Product Manager
- Posts: 14840
- Liked: 3086 times
- Joined: Sep 01, 2014 11:46 am
- Full Name: Hannes Kasparick
- Location: Austria
- Contact:
Re: Case #04983558: Start-VESQLRestoreSession not working
Hello,
and welcome to the forums.
The screenshot on the forums is not accessible for me. I looked in the support case and it looks like there is an issue with the IP address and earlier the script says "restore point not found".
Start-VESQLRestoreSession doesn't have any input for IP addresses... if you could copy & paste the relevant parts of the script and also the error, that would allow others to help.
Best regards,
Hannes
and welcome to the forums.
The screenshot on the forums is not accessible for me. I looked in the support case and it looks like there is an issue with the IP address and earlier the script says "restore point not found".
Start-VESQLRestoreSession doesn't have any input for IP addresses... if you could copy & paste the relevant parts of the script and also the error, that would allow others to help.
Best regards,
Hannes
-
- Novice
- Posts: 9
- Liked: never
- Joined: Mar 26, 2021 12:49 pm
- Full Name: Tarandeep Singh
- Contact:
Re: Case #04983558: Start-VESQLRestoreSession not working
logs deleted
Start-VESQLRestoreSession : Object of type 'System.Net.IPAddress[]' cannot be converted to type 'System.String[]'.
Start-VESQLRestoreSession : Object of type 'System.Net.IPAddress[]' cannot be converted to type 'System.String[]'.
-
- Novice
- Posts: 9
- Liked: never
- Joined: Mar 26, 2021 12:49 pm
- Full Name: Tarandeep Singh
- Contact:
Re: Case #04983558: Start-VESQLRestoreSession not working
Here is the script
Code: Select all
import-module Veeam.Backup.Powershell
function write-log
{
Param( [parameter(Position=0)]
[string]
$logEvent
,
[parameter(Position=1)]
[ValidateSet("info","warning","success", "error")]
[string]
$type ="info"
)
$date = "$((get-date).tostring('yyyy-MM-dd HH:mm:ss'))"
$colorHash = @{
"info"="cyan";
"warning"="yellow";
"success"="green";
"error"="red"
}
$color = $colorHash.Item($type)
Write-Host "[$date] $type`:$logEvent" -ForegroundColor $color
}
try {
$data = @()
$dbsProcessed = @{}
Connect-VBRServer -Server $PlanTarget -User $HostUser -Password $HostUserAdminPass
$jobs = Get-VBRJob | ?{$_.isbackup -eq $true}
write-log "Jobs found $($jobs.count)"
$jobs | ForEach-Object {
write-log "fetching details for job $($_.name)"
$job = $_
$jobname= $_.name
$state = "Ready"
$jobBackup = Get-VBRBackup -Name $job.Name
$dbsProcessed = @{}
if($jobBackup -ne $null) {
$jobBackup.GetObjectOibsAll() | ForEach-Object {
$device = $_
$deviceName=$_.Name
write-log "Fetching dbs for device $($device.Name)"
write-log "Fetching restore point [$($device.Name)]"
$rp = Get-VBRRestorePoint -Backup $jobBackup -Name $device.Name |Sort-Object -Descending CreationTime | Select-Object -First 1
if($rp -ne $null -and (Get-VBRApplicationRestorePoint -Id $rp.Id) -ne $null) {
$appRestorePoint = Get-VBRApplicationRestorePoint -Id $rp.Id
write-log "creating restore session [$($device.Name)]"
$restoreSession = Start-VESQLRestoreSession -RestorePoint $appRestorePoint
write-log "Restore session created [$($device.Name)]"
$dbs = Get-VESQLDatabase -Session $restoreSession
write-log "$($dbs.Count) Dbs found for device [$($device.Name)]"
$dbs| ForEach-Object {
$dbKey = "$($_.serverName)_$($_.instanceName)_$($_.name)"
$obj = New-Object System.Object | select planName, deviceName, database, guid,state
$obj.PlanName = $job.Name
$obj.deviceName = $device.Name
$obj.database = $dbKey
$obj.state =$state
$obj.guid = "$($_.name)-$($device.ObjId.Guid)"
$data += $obj
}
$restoreSession | Stop-VESQLRestoreSession -ErrorAction SilentlyContinue
} else {
Write-log "Restore point not found for device [$deviceName]" -type warning
}
}
} else {
write-log "not able to find dbs for job $($job.name)"
write-log "No backup found for job $($job.name)" -type warning
}
}
}catch{
$_
}
-
- Veeam Software
- Posts: 2010
- Liked: 670 times
- Joined: Sep 25, 2019 10:32 am
- Full Name: Oleg Feoktistov
- Contact:
Re: Case #04983558: Start-VESQLRestoreSession not working
Hi Tarandeep,
Please refrain from posting logs in forum threads. We can get them from a support case.
I'll take time to review your script in my lab and come back with findings.
Thanks,
Oleg
Please refrain from posting logs in forum threads. We can get them from a support case.
I'll take time to review your script in my lab and come back with findings.
Thanks,
Oleg
-
- Novice
- Posts: 9
- Liked: never
- Joined: Mar 26, 2021 12:49 pm
- Full Name: Tarandeep Singh
- Contact:
Re: Case #04983558: Start-VESQLRestoreSession not working
Hi Oleg,
Is there any update ?
Is there any update ?
-
- Veteran
- Posts: 643
- Liked: 312 times
- Joined: Aug 04, 2019 2:57 pm
- Full Name: Harvey
- Contact:
Re: Case #04983558: Start-VESQLRestoreSession not working
Just my input, you're doing tons of extra processing you don't need to in your script.
Basically all of this can be removed and you can just parse on the RestorePoint object property HasSQL.
This is a much better way of checking if a restore point should be passed to the Start-VESQLRestore session and it will reduce clutter in your code significantly.
I can't get your code to reproduce the issue in my lab environments, so my guess is you're somehow passing an object that breaks your validation and sends some invalid item, but it's not possible to tell with just the code you have.
Add in some debug lines before starting the VESQL session to post the object name, id, and maybe the object itself to console.
Code: Select all
$jobBackup.GetObjectOibsAll() | ForEach-Object {
$device = $_
$deviceName=$_.Name
write-log "Fetching dbs for device $($device.Name)"
write-log "Fetching restore point [$($device.Name)]"
$rp = Get-VBRRestorePoint -Backup $jobBackup -Name $device.Name |Sort-Object -Descending CreationTime | Select-Object -First 1
if($rp -ne $null -and (Get-VBRApplicationRestorePoint -Id $rp.Id) -ne $null) {
Code: Select all
PS C:\Users\Administrator\Desktop> $rp = Get-VBRRestorePoint -Backup $backup |sort -Property CreationTime -Descending
PS C:\Users\Administrator\Desktop> $rp.Hassql
False
True
True
I can't get your code to reproduce the issue in my lab environments, so my guess is you're somehow passing an object that breaks your validation and sends some invalid item, but it's not possible to tell with just the code you have.
Add in some debug lines before starting the VESQL session to post the object name, id, and maybe the object itself to console.
-
- Veeam Software
- Posts: 2010
- Liked: 670 times
- Joined: Sep 25, 2019 10:32 am
- Full Name: Oleg Feoktistov
- Contact:
Re: Case #04983558: Start-VESQLRestoreSession not working
Hi Tarandeep,
Apologies for being away for a while. Like Harvey, I couldn't reproduce your issue in my lab. I did connect with the QA for assistance though and sent you a PM with the further information needed.
Thanks,
Oleg
Apologies for being away for a while. Like Harvey, I couldn't reproduce your issue in my lab. I did connect with the QA for assistance though and sent you a PM with the further information needed.
Thanks,
Oleg
-
- Novice
- Posts: 9
- Liked: never
- Joined: Mar 26, 2021 12:49 pm
- Full Name: Tarandeep Singh
- Contact:
Re: Case #04983558: Start-VESQLRestoreSession not working
My script seems to be working in other environment. May be issue was in my environment.
We are setting up a new lab. I think it will work fine there
We are setting up a new lab. I think it will work fine there
-
- Veeam Software
- Posts: 2010
- Liked: 670 times
- Joined: Sep 25, 2019 10:32 am
- Full Name: Oleg Feoktistov
- Contact:
Re: Case #04983558: Start-VESQLRestoreSession not working
It did look like the environment issue. Anyways, if you'll notice such exception when running this script in your new environment please send me the info I asked in PM. Thanks!
Who is online
Users browsing this forum: No registered users and 7 guests