PowerShell/Scripts/check-dns-resolution.ps1

40 lines
1.1 KiB
PowerShell
Raw Normal View History

2021-09-27 10:38:12 +02:00
<#
2021-07-13 21:10:02 +02:00
.SYNOPSIS
2021-09-24 17:19:49 +02:00
Checks the DNS resolution with frequently used domain names
2021-10-04 21:29:23 +02:00
.DESCRIPTION
2021-10-12 21:51:51 +02:00
This script checks the DNS resolution with frequently used domain names.
2021-07-13 21:10:02 +02:00
.EXAMPLE
2021-09-24 17:19:49 +02:00
PS> ./check-dns-resolution
2021-10-04 17:42:06 +02:00
11.8 domains/sec (177 domains resolved in 15 sec)
2021-07-13 21:10:02 +02:00
.LINK
https://github.com/fleschutz/PowerShell
.NOTES
2021-08-29 17:50:03 +02:00
Author: Markus Fleschutz · License: CC0
2020-12-29 15:14:21 +01:00
#>
2020-09-29 20:05:52 +02:00
2020-10-05 13:12:12 +02:00
try {
2021-04-15 08:41:37 +02:00
$StopWatch = [system.diagnostics.stopwatch]::startNew()
2021-04-21 16:20:49 +02:00
write-progress "Reading Data/domain-names.csv..."
2021-04-15 08:41:37 +02:00
2021-03-29 16:34:51 +02:00
$PathToRepo = "$PSScriptRoot/.."
2020-12-29 15:48:24 +01:00
$Table = import-csv "$PathToRepo/Data/domain-names.csv"
2020-12-14 15:06:09 +01:00
2020-10-05 13:12:12 +02:00
foreach($Row in $Table) {
2021-03-29 16:34:51 +02:00
write-progress "Resolving $($Row.Domain) ..."
2021-03-30 09:34:52 +02:00
if ($IsLinux) {
$Ignore = nslookup $Row.Domain
} else {
$Ignore = resolve-dnsName $Row.Domain
}
2020-10-05 13:12:12 +02:00
}
$Count = $Table.Length
2021-04-14 16:18:23 +02:00
2021-04-21 16:43:08 +02:00
[int]$Elapsed = $StopWatch.Elapsed.TotalSeconds
2021-04-21 16:20:49 +02:00
$Average = [math]::round($Count / $Elapsed, 1)
2021-10-19 09:43:25 +02:00
"✔️ DNS resolves $Average domains/sec ($Count in $Elapsed sec)"
2021-09-27 10:09:45 +02:00
exit 0 # success
2020-12-09 10:30:55 +01:00
} catch {
2021-09-16 20:19:10 +02:00
"⚠️ Error: $($Error[0]) ($($MyInvocation.MyCommand.Name):$($_.InvocationInfo.ScriptLineNumber))"
2020-12-09 10:30:55 +01:00
exit 1
}