我写了一个小脚本来获取最近x天中每个还原点的创建时间:
$VMs = $ImportCSV # Names of Virtual Machines
$DateToCompare = 10
foreach ($vm in $VMs) {
$allRestorePoints = Get-VBRRestorePoint -Name $vm.Name |
where {$_.CreationTime -gt $DateToCompare} |
Select-Object VMName, CreationTime
}
此脚本向我显示了最近$DateToCompare
天的所有VM名称和还原点的创建时间。但是,如何计算每个VM的还原点并将其导出为CSV?
答案 0 :(得分:1)
使用您发布的代码,变量$VMs
中只有$allRestorePoints
中最后一个VM的还原点。
要获取所有VM的还原点数,请列举所有VM的所有还原点,并按VM名称分组:
$restorePoints = $VMs | ForEach-Object {
Get-VBRRestorePoint -Name $_.Name |
Where-Object { $_.CreationTime -gt $DateToCompare }
} | Select-Object VMName, CreationTime
$restorePoints |
Group-Object VMName |
Select-Object Name, Count |
Export-Csv 'C:\output.csv' -NoType