/etc/resolv.conf
で定義されていることは知っていますが、ない場合はどうなりますか?具体的には、DHCPから返されたDNSサーバーをどのように見つけますか?
GNOMEでは、NetworkManagerアプレットを使用して任意の接続のプライマリDNSを確認できます。コマンドラインから同じようにするにはどうすればよいでしょうか。
通常、dhclient.leasesファイルは/var/lib/dhcp3/dhclient.leases
にあります。次のコマンドを入力します。
less /var/lib/dhcp3/dhclient.leases
OR
cat /var/lib/dhcp3/dhclient.leases
OR
DHCPサーバーのアドレスを取得するには、grepコマンドを使用するだけです。次のように入力します。
grep dhcp-server-identifier /var/lib/dhcp3/dhclient.leases
OR
dhclient eth0
最近、この問題が発生しました。DNSサーバーを設定していないため、dhcpcd
が誤って構成されていました。次のコマンドを使用して、DHCPで使用可能なネームサーバーを照会できることがわかりました。
Sudo dhcpcd -o domain_name_servers -T
このコマンドは、一連のネットワーク接続情報を出力します。 new_domain_name_servers
で始まる行を探します。
ここからネームサーバーを手動で設定することができました。
DHCPリース情報は/var/lib/dhclient/dhclient-eth0.leases
で見つかりました。誰かが/var/lib/dhcp3/dhclient.leases
で見つけられない場合があります。
まあ、なぜそれを掘るのではないのですか?
marcus@marcus ~ $ Dig google.de
; <<>> Dig 9.4.3-P3 <<>> google.de
;; global options: printcmd
;; Got answer:
;; ->>HEADER<<- opcode: QUERY, status: NOERROR, id: 27579
;; flags: qr rd ra; QUERY: 1, ANSWER: 3, AUTHORITY: 6, ADDITIONAL: 0
;; QUESTION SECTION:
;google.de. IN A
;; ANSWER SECTION:
google.de. 1785 IN A 209.85.229.104
google.de. 1785 IN A 216.239.59.104
google.de. 1785 IN A 74.125.77.104
;; AUTHORITY SECTION:
de. 23431 IN NS L.DE.NET.
de. 23431 IN NS Z.NIC.de.
de. 23431 IN NS F.NIC.de.
de. 23431 IN NS C.DE.NET.
de. 23431 IN NS S.DE.NET.
de. 23431 IN NS A.NIC.de.
;; Query time: 1 msec
;; SERVER: 192.168.1.15#53(192.168.1.15)
;; WHEN: Thu Sep 17 19:33:39 2009
;; MSG SIZE rcvd: 181
最後の行を見てください:;;サーバー:192.168.1.15#53(192.168.1.15)
/etc/resolv.confに何もない場合、DNS解決(つまり、/ etc/nsswitch.confで定義されているdnsを使用した解決)は機能しません。これは、Dig、Host、およびlibcルーチンがDNS解決を行うために使用するものです。このファイルで何も指定されていない場合、DNS解決は機能しません(NISなどの別のホスト解決方法が構成されている場合、ホスト解決は他の方法で機能する可能性があります(これはありそうもないことです))。
このコマンドは、ネット上のDNSサーバーを表示します
掘る| grepサーバー:| awk -F# '{print $ 1}' | awk -F: '{print $ 2}'
172.17.0.1
読んだ /etc/resolv.conf
。それで全部です。
man resolv.conf
も便利です。
DHCPサーバーを照会するもう1つのソリューション:
Sudo nmap --script broadcast-dhcp-discover
出力から、DHCPサーバーが提供するネームサーバーがわかります。
Starting Nmap 7.60 ( https://nmap.org ) at 2019-12-12 23:50 UTC
Pre-scan script results:
| broadcast-dhcp-discover:
| Response 1 of 1:
| IP Offered: 144.123.211.44
| DHCP Message Type: DHCPOFFER
| Server Identifier: 144.123.99.200
| IP Address Lease Time: 5m00s
| Subnet Mask: 255.255.0.0
| Router: 144.123.99.200
| Domain Name Server: 144.123.99.200
|_ Domain Name: localdomain
最近のディストリビューションでは次のようになります
ps aux | grep dhcli | grep -v grep
root 367 0.0 0.0 16128 3076 ? S Apr30 0:00 /sbin/dhclient -d -q -sf /usr/lib/NetworkManager/nm-dhcp-helper -pf /var/run/dhclient-enp3s0.pid -lf /var/lib/NetworkManager/dhclient-324caec3-58f9-3f00-bff4-2f8bd7d2aafa-enp3s0.lease -cf /var/lib/NetworkManager/dhclient-enp3s0.conf enp3s0
tail -16 /var/lib/NetworkManager/dhclient-324caec3-58f9-3f00-bff4-2f8bd7d2aafa-enp3s0.lease
lease {
interface "enp3s0";
fixed-address 10.191.104.3;
option subnet-mask 255.255.255.0;
option routers 10.191.104.254;
option dhcp-lease-time 86400;
option dhcp-message-type 5;
option domain-name-servers 91.193.220.3,91.193.220.7;
option dhcp-server-identifier 91.193.220.3;
option ntp-servers 91.193.220.6;
option broadcast-address 10.191.104.255;
option domain-name "myISP.ru";
renew 1 2017/05/01 12:56:02;
rebind 2 2017/05/02 00:27:11;
expire 2 2017/05/02 03:27:11;
}
ここで、91.193.220.7はISPのDNSサーバーです
nslookup serverfault.com 91.193.220.7
Server: 91.193.220.7
Address: 91.193.220.7#53
Non-authoritative answer:
Name: serverfault.com
Address: 151.101.1.69
Name: serverfault.com
Address: 151.101.65.69
Name: serverfault.com
Address: 151.101.193.69
Name: serverfault.com
Address: 151.101.129.69