回答:
Powershellを使用すると、次のコマンドを使用できます。
Get-WmiObject -Class win32_logicalDisk -ComputerName server1, server2, server3, etc | Select-Object pscomputername, deviceid, freespace, size
server1、server2などをリモートサーバー名またはIPに置き換えます。
出力は次のようになります。
必要に応じて、| Export-Csv -Path .\drives.csv
スクリプトの最後に追加して、Excelで使用するためにファイルをコンマ区切り値(CSV)ファイルに出力できます。その場合、Excelを開くときに、Excelのドライブサイズの列を数値としてフォーマットする必要があります。
笑いのために、Active Directoryのすべてのサーバーでタスクを実行するこのPowerShellスクリプトを作成しました。
$ErrorActionPreference= 'silentlycontinue'
Get-ADComputer -Filter 'OperatingSystem -like "*Server*"' -Properties * | Select-Object Name |
ForEach-Object {
If (Test-Connection $_.Name -Count 1){
Get-WmiObject -Class win32_logicalDisk -ComputerName $_.Name |
Select-Object pscomputername, deviceid, freespace, size
}
else {
Write-host $_.Name " Connection Error"
}
}
次のコマンドを使用しfsutil
ます。
fsutil volume diskfree C:
fsutil volume diskfree \\server\share
出力は次のようになります。
Total # of free bytes : 851127304192
Total # of bytes : 2147480485888
Total # of avail free bytes : 851127304192
空きバイトのある行のみを取得するには、次を使用できます。
fsutil volume diskfree C: | find /i "avail free"
みんなfsutilとtelnetのアイデアを使った解決策もありました。
<package>
<job id="vbs">
<script language="VBScript">
set WshShell = WScript.CreateObject("WScript.Shell")
WshShell.Run "telnet 182.56.32.23 -l work"
WScript.Sleep 500
WshShell.AppActivate "Telnet"
WScript.Sleep 500
WshShell.SendKeys "y"
WshShell.SendKeys "~"
WScript.Sleep 500
WshShell.SendKeys "helloworld"
WScript.Sleep 500
WshShell.SendKeys "~"
WScript.Sleep 500
WshShell.SendKeys "C:\Users\work2\Desktop\diskcheck.bat"
WScript.Sleep 200
WshShell.SendKeys "~"
</script>
</job>
</package>
diskcheck.bat:
fsutilボリュームdiskfree C: 出力: 空きバイトの合計数:17084395520 合計バイト数:249145847808 空きバイトの合計数:17084395520
Function GetRemoteDiskSpace (
[String]$TargetComputer,
[String]$Drive
)
{
$Drive = New-PSDrive -Name K -PSProvider FileSystem -Root "\\$TargetComputer\$Drive$" -Persist
$Info = Get-PSDrive $Drive
$Free = $Info.Free /1GB
Remove-PSDrive -Name $drive -PSProvider FileSystem
return $Free
}