用于实施备份保留策略的脚本

问题描述 投票:0回答:2

我需要一个可以查看备份文件夹的脚本(我们对机器进行完整备份),并确保我们永远不会为每台计算机存储超过两个最新备份。我目前正在开发一个powershell循环,它应该将每个文件名与备份文件夹中的每个其他文件进行比较。每台计算机都有多个备份文件,可以通过匹配的前缀和由分隔字符分隔的唯一ID号来标识。

prefix =机器名称和唯一ID表示每个备份。

我正在设置外环并跑到墙上。我正在$array中存储要检查的文件列表。

我有一个嵌套的for循环,我想要检查每个文件对阵列中的每个其他文件。我有一个查询应该重建数组并在每次迭代时排除当前的引用文件。

for ($i=0; $i -lt 5; $i++) { 

$ array = Get-ChildItem -Path C:\ Users \ Aaron.Trujillo \ Desktop \ test $ array = Get-ChildItem -Path C:\ Users \ Aaron.Trujillo \ Desktop \ test -Exclude $ array [$ i]

for ($j=0; $j -lt 5; $j++){ 
    Write-Host "i: $i  j: $j"
    Write-Host "Array i: $($array[$i].name)  Array j: $($array[$j].name)"

    if($array[$i].name -ne $array[$j].name)
    {
        Write-Host "truthval=false"
        $truthval="false"
    } 

    else
    {
        Write-Host "truthval=true"
        $truthval = "true"
    } 
}  

}

我期待这个循环将数组中的前五个文件相互比较(不包括当前参考文件)并更改每个文件的变量,但由于某种原因,参考文件不会被排除。

逻辑上肯定有问题,但我很难发现它。

powershell string-comparison
2个回答
0
投票

我看到你的代码存在一些缺陷。

  1. 由于$array可能由Get-ChildItem填充(在ntfs格式化驱动器上返回已排序的输出),嵌套循环根本不是必需的。 当用一个迭代时,只需与前导者/跟随者index +/- 1进行比较。
  2. 由于名称根据您的描述包含ID,因此它们总是不同的。因此,您必须在模糊分隔符处拆分名称,并检查机器名称是否相同。
  3. 你的if命令不发出任何东西,它只是在每次迭代时覆盖相同的变量。

使用@ Lee_Dailey分组的好主意,您可以动态分割名称并检查每组的计数,按LastWriteTime对每组进行排序,并保留最新的2。

所以给出了一个假设的文件树

> tree /F
A:.
└───Backup
        Alpha_8.bak
        Bravo_2.bak
        Bravo_5.bak
        Bravo_6.bak
        Bravo_7.bak
        Bravo_9.bak
        Charlie_1.bak
        Charlie_10.bak
        Charlie_3.bak
        Charlie_4.bak

这个小脚本:

$BackupDir = 'A:\Backup'
$Delim     = '_'

Get-ChildItem -Path $BackupDir -File | 
  Group-Object {($_.BaseName -split $Delim)[0]}

收益率:

Count Name                      Group
----- ----                      -----
    1 Alpha                     {Alpha_8.bak}
    5 Bravo                     {Bravo_2.bak, Bravo_5.bak, Bravo_6.bak, Bravo_7.bak...}
    4 Charlie                   {Charlie_1.bak, Charlie_10.bak, Charlie_3.bak, Charlie_4.bak}

然后,您可以通过任何方式迭代组并按组删除文件, 例如,删除每台机器上除2个最新(每个LastWriteTime定义)文件以外的所有文件:

Get-ChildItem -Path $BackupDir -File | 
  Group-Object {($_.BaseName -split $Delim)[0]} | ForEach-Object {
    $_.Group | Sort LastWriteTime -Desc | Select -skip 2 | Remove-Item -WhatIf
  }

如果输出看起来没问题,请删除尾随的-WhatIf


0
投票

我认为它是围绕$array[$j.name]的括号,即它应该是:

if($array[$i].name -ne $array[$j].name)

编辑:

要进行故障排除,请尝试手动输出您的信

for ($i=0; $i -lt 5; $i++) { 

    for ($j=$i+1; $j -lt 5; $j++){ 
        Write-Host "i: $i  j: $j"
        Write-Host "Array i: $($array[$i].name)  Array j: $($array[$j].name)"

        if($array[$i].name -ne $array[$j].name)
        {
            Write-Host "truthval=false"
            $truthval="false"
        } 

        else
        {
            Write-Host "truthval=true"
            $truthval = "true"
        } 
    }  
}
© www.soinside.com 2019 - 2024. All rights reserved.