вторник, 15 декабря 2015 г.

How to determine which VHDs are not used on our Hyper-V

[code]
On Error Resume Next
'
' Preparing....
'
Set objFSO=Createobject("Scripting.Filesystemobject")

strFolder="\\n1\c$\ClusterStorage"
strNodeList="n1|n2"
strReplaceTo="c:\"
'
' and go!!!
'
Wscript.Echo "Get list of .VHD and .AVHD files on ClusterShareVolume"
strFileList=Lcase(GetFSVHDList(strFolder))
arrFileList=Split(strFileList,"|")
Wscript.Echo "Done"
Wscript.Echo "Get list of associated VHD files in cluster"
strVHDList=lcase(GetVHDList)
arrVHDList=Split(strVHDList,"|")
Wscript.Echo "Done"
arrNodeList=Split(Lcase(strNodeList),"|")

'
' comparing output
'
For i=LBound(arrFileList) To UBound(arrFileList)
bFound=False
a=lcase(arrFileList(i))
For z=LBound(arrNodeList) To UBound(arrNodeList)
a=Replace(a,"\\" & LCase(arrNodeList(z)) & "\c$\",strReplaceTo)
Next
For j=LBound(arrVHDList) To UBound(arrVHDList)
b=lcase(arrVHDList(j))
If a=b Then bFound=True
Next
If bFound=False Then Wscript.Echo lcase(a)
Next
Wscript.Quit

'
' you can try to understand below lines but you don't need to
'
Function GetFSVHDList(strRootFolder)
On Error Resume Next
Set objFolder=objFSO.GetFolder(strRootFolder)
Set objSubFolders=objFolder.SubFolders
For Each objSubFolder In objSubFolders
strFileList=strFileList & GetFSVHDList(strRootFolder & "\" & objSubFolder.Name)
Next
strFileList=strFileList & GetFSFileList(strRootFolder)
GetFSVHDList=strFileList

End Function

Function GetFSFileList(strRootFolder)
On Error Resume Next
GetFSFileList=""
Set objGFSFLFolder=objFSO.GetFolder(strRootFolder)
Set objGFSFLFiles=objGFSFLFolder.Files
For Each objGFSFLFile In objGFSFLFiles
arrGFSFLFile=Split(UCase(objGFSFLFile.Name),".")
strGFSFLExt=arrGFSFLFile(Ubound(arrGFSFLFile))
If strGFSFLExt="VHD" Or strGFSFLExt="AVHD" Then
GetFSFileList=GetFSFileList & lcase(strRootFolder & "\" & objGFSFLFile.Name) & "|"
End If
Next
End Function

Function GetVHDList
On Error Resume Next
GetVHDList=""
arrNodeList=Split(strNodeList,"|")
For i=Lbound(arrNodeList) To Ubound(arrNodeList)
strComputer=arrNodeList(i)
Set objWMI = GetObject("winmgmts:\\" & strComputer & "\ROOT\virtualization")
strQuery="select * from Msvm_ComputerSystem"
Set col = objWMI.ExecQuery(strQuery)
For Each obj in col
If obj.Name<>obj.ElementName Then
strDisk=GetDisks (obj.Name,strComputer)
a=split(strDisk,"|")
For j=LBound(a) To UBound(a)
GetVHDList=GetVHDList & a(j) & "|"
Next
End If
Next
Next
End Function
Function GetDisks(strSystemName,strComputer)
On Error Resume Next
GetDisks=""
Set objWMIGD = GetObject("winmgmts:\\" & strComputer & "\ROOT\virtualization")
strQuery="SELECT * FROM Msvm_ResourceAllocationSettingData WHERE Parent Like '%" & strSystemName & "%' And ResourceSubType='Microsoft Virtual Hard Disk'"
Set colGD=objWMIGD.ExecQuery(strQuery)
For Each objGD In colGD
For Each objConn In objGD.Connection
GetDisks=GetDisks & objConn & "|"
Next
Next
If GetDisks="|" Then GetDisks="": Exit Function
If Len(GetDisks)>1 Then
If Right(GetDisks,1)="|" Then
GetDisks=Left(GetDisks,Len(GetDisks)-1)
End If
End If
End Function
[/code]

Комментариев нет:

Отправить комментарий