Update check-ping.ps1

This commit is contained in:
Markus Fleschutz 2023-06-03 08:51:05 +02:00
parent f8e95672d4
commit 5e38219fe7

View File

@ -2,12 +2,12 @@
.SYNOPSIS .SYNOPSIS
Checks the ping latency Checks the ping latency
.DESCRIPTION .DESCRIPTION
This PowerShell script checks the ping latency from the local computer to 10 popular hosts. This PowerShell script measures the ping roundtrip times from the local computer to 10 Internet servers.
.PARAMETER hosts .PARAMETER hosts
Specifies the hosts to check, seperated by commata (default is: amazon.com,bing.com,cnn.com,dropbox.com,facebook.com,github.com,google.com,live.com,twitter.com,youtube.com) Specifies the hosts to check, seperated by commata (default is: amazon.com,bing.com,cnn.com,dropbox.com,facebook.com,github.com,google.com,live.com,twitter.com,youtube.com)
.EXAMPLE .EXAMPLE
PS> ./check-ping PS> ./check-ping
Ping latency is 13ms...109ms with 29ms average (0 loss) Ping latency is 29ms average (13ms...109ms, 0 loss)
.LINK .LINK
https://github.com/fleschutz/PowerShell https://github.com/fleschutz/PowerShell
.NOTES .NOTES
@ -18,27 +18,26 @@ param([string]$hosts = "amazon.com,bing.com,cnn.com,dropbox.com,facebook.com,git
try { try {
Write-Host "✅ Ping latency is" -noNewline Write-Host "✅ Ping latency is" -noNewline
$HostsArray = $hosts.Split(",") $hostsArray = $hosts.Split(",")
$t = $hostsArray | foreach {
$t = $HostsArray | foreach {
(New-Object Net.NetworkInformation.Ping).SendPingAsync($_, 250) (New-Object Net.NetworkInformation.Ping).SendPingAsync($_, 250)
} }
[Threading.Tasks.Task]::WaitAll($t) [Threading.Tasks.Task]::WaitAll($t)
[int]$Min = 9999999 [int]$min = 9999999
[int]$Max = [int]$Avg = [int]$SuccessCount = [int]$LossCount = 0 [int]$max = [int]$avg = [int]$successCount = [int]$lossCount = 0
foreach($ping in $t.Result) { foreach($ping in $t.Result) {
if ($ping.Status -eq "Success") { if ($ping.Status -eq "Success") {
[int]$Latency = $ping.RoundtripTime [int]$latency = $ping.RoundtripTime
if ($Latency -lt $Min) { $Min = $Latency } if ($latency -lt $min) { $min = $Latency }
if ($Latency -gt $Max) { $Max = $Latency } if ($latency -gt $max) { $max = $Latency }
$Avg += $Latency $avg += $latency
$SuccessCount++ $successCount++
} else { } else {
$LossCount++ $lossCount++
} }
} }
$Avg /= $SuccessCount $avg /= $successCount
Write-Host " $($Min)ms...$($Max)ms with $($Avg)ms average ($LossCount loss)" Write-Host " $($avg)ms average ($($min)ms...$($max)ms, $lossCount loss)"
exit 0 # success exit 0 # success
} catch { } catch {
"⚠️ Error in line $($_.InvocationInfo.ScriptLineNumber): $($Error[0])" "⚠️ Error in line $($_.InvocationInfo.ScriptLineNumber): $($Error[0])"