リモートサーバー上のディスクスペースをクエリする最良の方法

StackOverflow https://stackoverflow.com/questions/56715

  •  09-06-2019
  •  | 
  •  

質問

すべてのドライブをクエリし、探しているドライブが見つかるまでループすることで、リモート サーバー上の空き領域を確保しようとしています。
これを行うより良い方法はありますか?

Dim oConn As New ConnectionOptions
Dim sNameSpace As String = "\\mnb-content2\root\cimv2"
Dim oMS As New ManagementScope(sNameSpace, oConn)

Dim oQuery As System.Management.ObjectQuery = New System.Management.ObjectQuery("select FreeSpace,Size,Name from Win32_LogicalDisk where DriveType=3")
Dim oSearcher As ManagementObjectSearcher = New ManagementObjectSearcher(oMS, oQuery)

Dim oReturnCollection As ManagementObjectCollection = oSearcher.Get()
Dim oReturn As ManagementObject

For Each oReturn In oReturnCollection
    'Disk name
    Console.WriteLine("Name : " + oReturn("Name").ToString())
    'Free Space in bytes
    Dim sFreespace As String = oReturn("FreeSpace").ToString()
    If Left(oReturn("Name").ToString(), 1) = "Y" Then
        Console.WriteLine(sFreespace)
    End If
Next
役に立ちましたか?

解決

WMI クエリを name='Y' の場合のみプルバックするようにしてはどうでしょうか?

それで:

Dim oQuery As System.Management.ObjectQuery = New System.Management.ObjectQuery("select FreeSpace,Size,Name from Win32_LogicalDisk where DriveType=3 AND name='Y'")
ライセンス: CC-BY-SA帰属
所属していません StackOverflow
scroll top