Какая команда позволяет узнать имя компьютера по его IP-адресу?
Я всегда забываю, что это за команда, но я знаю, что она существует в Windows, и предполагаю, что она существует в командной строке * nix.
копать землю и хозяин должно быть то, что вы ищете;)
http://www.unix.com/unix-dummies-questions-answers/9866-nslookup-linux.html
В системе * nix вы можете выполнить эту команду: dig -x [address]
В качестве альтернативы вы можете добавить +short
в конце dig
команда для вывода только результата DNS.
В Windows, используйте nslookup
РЕДАКТИРОВАТЬ: nslookup тоже работает в системах * nix. Дополнительная информация о команде nslookup, не заменялась ли она с недавнего времени: http://linuxreviews.org/man/nslookup/
В * nix вы можете использовать:
dig -x [address]
В большинстве известных мне систем Linux вы можете использовать:
nslookup <ip-number EX: 127.0.0.1>
будет работать в командной строке.
Если подумать, разве nslookup не доступен в Windows XP?
На этот вопрос уже есть миллион ответов, но я добавлю еще один. Вот небольшая функция, которую я написал для простого выполнения обратного DNS с помощью dig. Добавьте это в свой ~/.bashrc
файл, перезагрузите оболочку, а затем вы можете выполнять обратный поиск DNS с помощью revdns 1.2.3.4
:
function revdns() {
octets=""
addr="in-addr.arpa"
# split the IP address into an array of octets
IFS="." read -r -a octets <<< "$1"
# add each octet to our $addr string in reverse order
for octet in "${octets[@]}"; do
addr=$octet"."$addr
done
# run a DNS pointer lookup with dig
# `+short` makes dig's output very terse (un-verbose)
# `"${@:2}"` passes any extra params from this command to dig
dig ptr +short $addr "${@:2}"
}
Обратный поиск DNS выполняется путем проверки записей указателя (PTR). Если вы хотите сделать обратный DNS для «1.2.3.4», вам необходимо найти записи указателя для «4.3.2.1.in-addr.arpa». Моя функция принимает IP-адрес, меняет порядок октетов на обратный (т.е. меняет его с 1.2.3.4 на 4.3.2.1), а затем использует dig
для выполнения только что описанного поиска PTR.
Вы, конечно, можете просто использовать nslookup 1.2.3.4
если он у вас есть, но я предпочитаю это решение на основе раскопок, потому что оно использует DNS-серверы ОС вместо серверов, предоставляемых nslookup (кстати, если вы хотите, вы можете добавить дополнительные флаги копания при вызове revdns
, и они пройдут копать)
Прямой поиск с помощью host
:
$ host google-public-dns-b.google.com.
google-public-dns-b.google.com has address 8.8.4.4
google-public-dns-b.google.com has IPv6 address 2001:4860:4860::8844
Обратный поиск с помощью host
:
$ host 8.8.4.4
4.4.8.8.in-addr.arpa domain name pointer google-public-dns-b.google.com.
Прямой поиск с помощью dig
:
$ dig google-public-dns-b.google.com. +short
8.8.4.4
Обратный поиск с помощью dig
:
$ dig -x 8.8.4.4 +short
google-public-dns-b.google.com.
Мне хорошо известно, что dig / host / nslookup являются стандартными инструментами для них, но я храню их для проверки разрешения ОС (по сути, для проверки правильности работы nsswitch.conf):
gethostbyname:
#!/usr/bin/perl
use Socket;
my @t = gethostbyname($ARGV[0]);
print "\$name = $t[0]\n"; shift(@t);
print "\$aliases = $t[0]\n"; shift(@t);
print "\$addrtype = $t[0]\n"; shift(@t);
print "\$length = $t[0]\n"; shift(@t);
foreach (@t) {
print " = ", inet_ntoa($_), "\n";
}
gethostbyaddr:
#!/usr/bin/perl
use Socket;
my @t = gethostbyaddr(inet_aton($ARGV[0]), AF_INET);
print "\$name = $t[0]\n"; shift(@t);
print "\$aliases = $t[0]\n"; shift(@t);
print "\$addrtype = $t[0]\n"; shift(@t);
print "\$length = $t[0]\n"; shift(@t);
foreach (@t) {
print " = ", inet_ntoa($_), "\n";
}
пример:
g3 0 /home/jj33/swap > gethostbyname www.google.com
$name = www.l.google.com
$aliases = www.google.com
$addrtype = 2
$length = 4
= 72.14.205.147
= 72.14.205.103
= 72.14.205.104
= 72.14.205.99
g3 0 /home/jj33/swap > gethostbyaddr 72.14.205.147
$name = qb-in-f147.google.com
$aliases =
$addrtype = 2
$length = 4
= 72.14.205.147
В Windows я привык использовать:
ping -a <ip address>
так как это также будет отражать данные из вашего hosts
файл и WINS и так далее.
Если вы используете nslookup, то это (при условии, что 192.168.0.1 в качестве рассматриваемого IP-адреса)
> set type=ptr
> 1.0.168.192.in-addr.arpa
РЕДАКТИРОВАТЬ: Помните, что обратный поиск работает только в том случае, если для IP-адреса создана запись PTR, и не гарантируется возврат искомого имени хоста. Полностью зависит от того, как DNS настроен и поддерживается в вашей ситуации.
Powershell:
[net.dns]::gethostentry("69.59.196.212").HostName
Ну, какой-то дружелюбный человек только что написал, что nslookup - это команда, и он прав. Он работает как в Unix, так и в Windows. Не знаю, почему вы удалили свой ответ, но вы правы, сэр.
nbtstat -a <IP-адрес>
Я предпочитаю копать из командной строки для Windows (доступно здесь: http://members.shaw.ca/nicholas.fong/dig/) на nslookup в любой день.
Если вам нужно тестировать / администрировать DNS с рабочей станции Windows, возьмите этот инструмент. Затем:
C:\dig>dig -x <IP Address>
... также не забудьте добавить c: \ dig к своему пути!
Это мой взгляд на более полный обратный поиск DNS. Надеюсь, это пригодится будущим зрителям этой страницы.
for ip in {1..254..1}; do dig -x 1.1.1.$ip | grep $ip >> dns.txt; done;