我想了解Measure-DedupFileMetadata是如何工作的,所以我可以recursion地通过一些文件夹来报告实际使用了多less空间。 我不知道如何解释输出。
如果我正确理解文档,DedupDistinctSize应该告诉我,如果我删除这些文件(垃圾回收之后),释放多less空间。 这些数字对于我的大部分文件夹都显示正确。 但是在没有重复数据删除的文件夹上,它显示0。
我也不知道如何理解SizeOnDisk信息。
这是两个文件夹的输出:
Path : {E:\veeam\folder1} Volume : E: VolumeId : \\?\Volume{77da8d6d-1416-4d2a-8c85-75c91f980398} FilesCount : 19 OptimizedFilesCount : 3 Size : 2.38 TB SizeOnDisk : 1.81 TB DedupSize : 491.38 GB DedupChunkCount : 6786488 DedupDistinctSize : 475.59 GB DedupDistinctChunkCount : 6561011 Path : {E:\veeam\folder2} Volume : E: VolumeId : \\?\Volume{77da8d6d-1416-4d2a-8c85-75c91f980398} FilesCount : 18 OptimizedFilesCount : 0 Size : 332.7 GB SizeOnDisk : 332.7 GB DedupSize : 0 B DedupChunkCount : 0 DedupDistinctSize : 0 B DedupDistinctChunkCount : 0
我已经通过删除各种types的数据做了一些testing,我的结论是实际使用的空间是SizeOnDisk + DedupDistinctSize。
所以为了使它看起来很漂亮并以GB显示,请使用计算属性:
Measure-DedupFileMetadata -Path e:\folder1 | Select Path, @{label="TotalGB"; expression={[math]::Round(($_.SizeOnDisk + $_.DedupDistinctSize) / 1GB, 0)}}
以下是如何编写脚本并在文本文件中创buildsorting表:
$Folders = @() foreach ($folder in (Get-ChildItem -Path E:\ -Directory)) { Write-Host -NoNewline "Calcuating $($folder.FullName): " $Result = Measure-DedupFileMetadata -ErrorAction Continue -Path $folder.FullName $Folders += $Result Write-Host $Result.DedupDistinctSize } $Folders | Select {$_.Path[0]}, @{label='DedupDistinctSizeGB'; expression={[math]::Round($_.DedupDistinctSize / 1GB, 0)}}, @{label='SizeOnDiskGB'; expression={[math]::Round($_.SizeOnDisk / 1GB, 0)}}, @{label="TotalGB"; expression={[math]::Round(($_.SizeOnDisk + $_.DedupDistinctSize) / 1GB, 0)}} | Sort TotalGB -Descending | Format-Table -AutoSize | Out-File -FilePath 'Dedup_Summary.txt' -Append
输出如下所示:
$_.Path[0] DedupDistinctSizeGB SizeonDiskGB TotalGB ---------- ------------------- ------------ ------- E:\veeam\xxxxxxx 3868 2178 6045 E:\veeam\xxxxx 840 3712 4553 E:\veeam\xxx 801 3244 4044 E:\veeam\xxxxxxxxxx 683 1213 1896 E:\veeam\xxxxxxxxxxxxxx 41 1636 1678 E:\StorageCraft\xxxxxxx 1537 56 1593
我不确定为什么这个命令太慢了,但是花了超过一个星期的时间在50TB的容量上运行。