解析-DnsName Inside测试-连接 [英] Resolve-DnsName inside Test-Connection
本文介绍了解析-DnsName Inside测试-连接的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!
问题描述
我想知道如何从Test-Connection
脚本返回Resolve-DnsName
输出并将其添加到我创建的CSV中。
我想要从中捕获名称、类型、TTL、部分。
仅在ping失败时调用Resolve-DnsName
。
$servers = Get-Content "servers.txt"
$collection = $()
foreach ($server in $servers)
{
$status = @{ "ServerName" = $server; "TimeStamp" = (Get-Date -f s) }
$result = Test-Connection $server -Count 1 -ErrorAction SilentlyContinue
if ($result)
{
$status.Results = "Up"
$status.IP = ($result.IPV4Address).IPAddressToString
}
else
{
$status.Results = "Down"
$status.IP = "N/A"
$status.DNS = if (-not(Resolve-DnsName -Name $server -ErrorAction SilentlyContinue))
{
Write-Output -Verbose "$server -- Not Resolving"
}
else
{
"$server resolving"
}
}
New-Object -TypeName PSObject -Property $status -OutVariable serverStatus
$collection += $serverStatus
}
$collection | Export-Csv -LiteralPath .ServerStatus3.csv -NoTypeInformation
但CSV中未添加任何新内容。
推荐答案
您遇到了PowerShell问题。PowerShell根据处理的第一个对象确定表格/CSV输出中显示的列。如果该对象没有属性DNS
,则该列不会显示在输出中,即使列表中其他对象确实有该属性也是如此。如果其他对象没有第一个对象中存在的属性,则它们将显示为空值。
演示:
PS C:> $a = (New-Object -Type PSObject -Property @{'a'=1; 'b'=2}), >> (New-Object -Type PSObject -Property @{'a'=3; 'b'=4; 'c'=5}), >> (New-Object -Type PSObject -Property @{'b'=6; 'c'=7}) >> PS C:> $a | Format-Table -AutoSize a b - - 1 2 3 4 6 PS C:> $a[1..2] | Format-Table -AutoSize c b a - - - 5 4 3 7 6
如果要生成表格输出始终使用相同的属性集统一创建对象。选择合理的默认设置甚至可以减少总的代码量。
$collection = foreach ($server in $servers) {
$status = New-Object -Type PSObject -Property @{
'ServerName' = $server
'TimeStamp' = Get-Date -f s
'Results' = 'Down'
'IP' = 'N/A'
'HasDNS' = [bool](Resolve-DnsName -Name $server -EA SilentlyContinue)
}
$result = Test-Connection $server -Count 1 -EA SilentlyContinue
if ($result) {
$status.Results = 'Up'
$status.IP = ($result.IPV4Address).IPAddressToString
}
$status
}
这篇关于解析-DnsName Inside测试-连接的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!
查看全文