Whoisスクリプトで使用するWHOISサーバーの信頼できる最新のリストを探しています。
リストは頻繁に変更されるため、スクリプトを頻繁に更新する必要がなく、参照できるリソースがあればいいでしょう。
TLDのwhoisサーバーを見つけるには、いくつかのよく知られている方法があります。IANAデータベースは、質問が要求するものにおそらく最も近いですが、実際により役立つ他のソースがあります。
参照 http://www.iana.org/domains/root/db またはTLDのwhois.iana.org
にあるwhoisデータベースを検索します。各エントリには、whoisサーバーを指定するフィールドがあります。
例:
$ whois -h whois.iana.org com
[Querying whois.iana.org]
[whois.iana.org]
% IANA WHOIS server
% for more information on IANA, visit http://www.iana.org
% This query returned 1 object
domain: COM
organisation: VeriSign Global Registry Services
address: 12061 Bluemont Way
address: Reston Virginia 20190
address: United States
contact: administrative
name: Registry Customer Service
organisation: VeriSign Global Registry Services
address: 12061 Bluemont Way
address: Reston Virginia 20190
address: United States
phone: +1 703 925-6999
fax-no: +1 703 948 3978
e-mail: [email protected]
contact: technical
name: Registry Customer Service
organisation: VeriSign Global Registry Services
address: 12061 Bluemont Way
address: Reston Virginia 20190
address: United States
phone: +1 703 925-6999
fax-no: +1 703 948 3978
e-mail: [email protected]
nserver: A.GTLD-SERVERS.NET 192.5.6.30 2001:503:a83e:0:0:0:2:30
nserver: B.GTLD-SERVERS.NET 192.33.14.30 2001:503:231d:0:0:0:2:30
nserver: C.GTLD-SERVERS.NET 192.26.92.30
nserver: D.GTLD-SERVERS.NET 192.31.80.30
nserver: E.GTLD-SERVERS.NET 192.12.94.30
nserver: F.GTLD-SERVERS.NET 192.35.51.30
nserver: G.GTLD-SERVERS.NET 192.42.93.30
nserver: H.GTLD-SERVERS.NET 192.54.112.30
nserver: I.GTLD-SERVERS.NET 192.43.172.30
nserver: J.GTLD-SERVERS.NET 192.48.79.30
nserver: K.GTLD-SERVERS.NET 192.52.178.30
nserver: L.GTLD-SERVERS.NET 192.41.162.30
nserver: M.GTLD-SERVERS.NET 192.55.83.30
ds-rdata: 30909 8 2 E2D3C916F6DEEAC73294E8268FB5885044A833FC5459588F4A9184CFC41A5766
whois: whois.verisign-grs.com
status: ACTIVE
remarks: Registration information: http://www.verisign-grs.com
created: 1985-01-01
changed: 2012-02-15
source: IANA
$
名前tld.whois-servers.net
は、適切なwhoisサーバーへのCNAME
です。これを実際に管理している人はいくらか不明確ですが、ほとんどすべてのwhoisクライアント(および一部のクライアントはこのサービスをデフォルトで使用しています)でこれを使用するのは非常に簡単であるため、かなり人気があるようです。
例:
$ Dig com.whois-servers.net +noall +answer
; <<>> Dig 9.9.4-P2-RedHat-9.9.4-15.P2.fc20 <<>> com.whois-servers.net +noall +answer
;; global options: +cmd
com.whois-servers.net. 600 IN CNAME whois.verisign-grs.com.
whois.verisign-grs.com. 5 IN A 199.7.55.74
$
多くのレジストリでは、関連するゾーンの _nicname._tcp
SRV
レコード として、DNSのwhoisサーバーのアドレスを直接公開しています。
例:
$ Dig _nicname._tcp.us SRV +noall +answer
; <<>> Dig 9.9.4-P2-RedHat-9.9.4-15.P2.fc20 <<>> _nicname._tcp.us SRV +noall +answer
;; global options: +cmd
_nicname._tcp.us. 518344 IN SRV 0 0 43 whois.nic.us.
$
[〜#〜] iana [〜#〜] と [〜#〜] psl [〜#〜] のリストを、whoisサーバーを含むXMLファイルに定期的にコンパイルします、レジストラ、第2レベルドメイン、および可能であれば、可用性の正規表現: https://github.com/whois-server-list/whois-server-list
最近、WHOISをいじってみましたが、公開されているwhoisパッケージ[CentOSのjwhois]の一部は、事前にパッケージ化されたTLD WHOISサーバーのリストに依存しているようです。これは、大部分のTLDで問題ありませんが、.horse
のような難解なgTLDの急増の問題です。
100%信頼できる方法は、IANAのWHOISサーバーwhois.iana.org
でTLDを検索し、whois:
エントリを解析して、ドメインの情報についてthatサーバーにクエリを実行することです。例えば:
foo@bar:~ $ echo -e "horse\r\n" | nc -i 1 whois.iana.org 43
% IANA WHOIS server
% for more information on IANA, visit http://www.iana.org
% This query returned 1 object
domain: HORSE
[snip]
whois: whois-dub.mm-registry.com
[snip]
Connection closed by foreign Host.
その後:
foo@bar:~ $ echo -e "dord.horse\r\n" | nc -i 1 whois-dub.mm-registry.com 43
Domain Name: dord.horse
Domain ID: 1742946-MMd1
WHOIS Server: whois-dub.mm-registry.com
[snip]
この方法を使用している場合は、IANAサーバーからの応答を丁寧にキャッシュして少なくとも48時間キャッシュする必要があります。それが変更されることはめったになく、IANAのサーバーには大きな負荷がかかる傾向があるためです。
Ruby WHOISライブラリ https://github.com/weppos/whois/blob/master/data/tld.json のWHOISサーバーのリストを管理しています==
すべての既存サーバーのリストが含まれています。
Rubyライブラリは異なるレベルで解析を実行するため、ドメインが使用可能な場合の応答は含まれません。また、すべてのレジストリが文字列メッセージを使用してドメインが使用できないことを通知するわけではないことに注意してください。
このスクリプトを使用して、IANAからwhoisサーバーを取得できます。大騒ぎで作成されました。ゾーンとwhoisサーバーのJSONリストに出力されます。
<style>
body {
font: normal 10px verdana, sans-serif;
color: #333;
}
</style>
<?
$zones = array('ac','am','asia','at','be','biz','biz.ua','biz.ua','br.com','bz','cc','ch','co','co.am','co.in','co.ua','co.ua','om','com.am','com.kz','com.ua','cx','cz','de.com','eu','eu.com','firm.in','fm','gen.in','im','in','ind.in','info','io','kiev.ua','kz','la','lc','li','lt','lu','md','me','mn','mobi','ms','mx','name','net','net.am','net.in','org','org.am','org.in','org.kz','ph','pl','pp.ua','pro','pw','pw','ru','ru.com','so','su','su','su','tel','tv','tw','us','uy.com','vc','ws','xxx','za.cm','xn--p1ai');
$count = count($zones);
echo '<h1>Whois tool</h1>';
echo '<pre>
{
';
for($i=0;$i<$count;$i++) {
$root_server = 'whois.iana.org';
$zone = $zones[$i];
$domain = 'nuceti75.'.$zones[$i];
//echo "<h2>$domain - $current_domain</h2>";
$fp = fsockopen($root_server, 43);
if (!$fp) echo "Connection error: $root_server \r\n";
else {
fputs($fp, $zone."\r\n");
while (!feof($fp)) {
$root_answer .= fgets($fp, 128);
}
preg_match("~whois:\s(.+)~i", $root_answer, $result);
$current_server = trim($result[1]);
fclose($fp);
}
//echo "<pre>$root_answer</pre>";
//echo "<b>Whois server for this TLD:</b> $current_server";
$fh = fsockopen($current_server, 43);
if (!$fh) echo "Connection error: $current_server ($zone) \r\n";
else {
fputs($fh, $domain."\r\n");
while (!feof($fh)) {
$current_answer .= fgets($fh, 128);
}
fclose($fh);
}
//echo "<pre>$current_answer</pre>";
echo "\"$zone\": \"$current_server\",\r\n";
unset($root_answer);
unset($current_answer);
unset($result);
}
echo '
}
</pre>';
?>
これらのリストは必要ありません。 whois(1)は、これを理解できるほど賢いです。
Manページの場合:
By default whois constructs the name of a whois server to use
from the top-level domain (TLD) of the supplied (single) argu-
ment, and appending ".whois-servers.net". This effectively
allows a suitable whois server to be selected automatically for a
large number of TLDs.
Whoisは一般的にかなり信頼できます。ドメインで失敗したことを思い出したことはありません。