У меня есть список серверов, для них я использую команды Resolve -DnsName
, эта команда имеет разные параметры, и чтобы получить все данные, которые мне нужны (NS, MX, CNAME, A) записи, мне нужно выполнить несколько команд.
$servers = get-content "C:\Users\Olehsa\Desktop\ttt.txt"
$a1 = foreach ($server in $servers) {
[System.Net.Dns]::resolve($server)
}
После каждой команды у меня есть список из 1-3 столбцов.
#NS
$a2 = foreach ($server in $servers) {
Resolve-DnsName -Name $server -Type NS -DnsOnly | select PrimaryServer, NameHost,NameExchange,Strings + $a3
}
#MX
$a3 = foreach($server in $servers) {
Resolve-DnsName -Name $server -Type MX -DnsOnly | select NameExchange
}
#TXT
$a4 = foreach($server in $servers) {
Resolve-DnsName -Name $server -Type TXT | select Strings
}
Я получаю эти данные:
HostName Aliases AddressList
-------- ------- -----------
google.com {} {172.217.22.46}
и это :
NameHost NameExchange
------------- --------
ns1.google.com
ns4.google.com
ns3.google.com
ns2.google.com
И вопрос: как мне объединить этот большой список с несколькими столбцами?
P.s. Без использования PS-объектов, потому что если я его использую, я помещаю все данные в 1 ячейку. У меня есть список с 3 столбцами, мне нужно добавить еще один столбец с
Я бы поместил это в один ForEach
и
при получении нескольких результатов для одного поля -Join
их
## Q:\Test\2018\09\21\SF_932023.ps1
$servers = get-content "C:\Users\Olehsa\Desktop\ttt.txt"
$result = foreach ($server in $servers) {
[PSCustomObject]@{
Server = $server
NameHost = ((Resolve-DnsName -Name $server -Type NS -DnsOnly).NameHost|Sort) -Join ', '
NameExchange = ((Resolve-DnsName -Name $server -Type MX -DnsOnly).NameExchange|Sort) -Join ', '
Strings = ((Resolve-DnsName -Name $server -Type TXT).Strings) -Join ', '
}
}
$result|fl
Пример вывода:
Server : google.com
NameHost : ns1.google.com, ns2.google.com, ns3.google.com, ns4.google.com
NameExchange : alt1.aspmx.l.google.com, alt2.aspmx.l.google.com, alt3.aspmx.l.google.com, alt4.aspmx.l.google.com, aspmx.l.google.com
Strings : docusign=05958488-4752-4ef2-95eb-aa7ba8a3bd0e, facebook-domain-verification=22rm551cu4k0ab0bxsw536tlds4h95, v=spf1 include:_spf.google.com ~all