Linux 解析的顺序是什么DNS
?我是否要阅读/etc/nsswitch.conf
,然后阅读hosts
,然后转到/etc/resolv.conf
DNS,然后转到网络连接DNS
?
我对此知之甚少,DNS
并且非常感谢任何可以帮助我理解的答案
答案1
Linux解析DNS的顺序是非常可配置。
首先阅读hosts:
中的行/etc/nsswitch.conf
。该行上的关键字指定了各种源的使用顺序。
可用的关键字集取决于您的 Linux 发行版。经典的有:
files
告诉系统读取/etc/hosts
dns
告诉系统使用 中指定的 DNS 服务器/etc/resolv.conf
。 (使用的新系统systemd-resolved
可能正在努力最终使这一点过时。)nis
或者nisplus
参考 NIS/NIS+ 系统的集中管理主机表(实际上已过时)compat
类似于files
,但也允许以前使用的旧 NIS 扩展语法/etc/nsswitch.conf
。 (实际上已过时)
现代系统可能添加了新的关键字,例如:
resolve
告诉系统使用systemd-resolved
.如果存在该关键字,则使用该resolvectl
命令查看实际的 DNS 服务器设置。如果dns
关键字也不存在,则该/etc/resolv.conf
文件可能是完全被忽视。mdns4_minimal
,mdns6_minimal
或者mdns_minimal
告诉系统尝试shortname.local
通过分别使用 IPv4、IPv6 或两者将 mDNS 数据包发送到适当的多播地址来解析该形式的短主机名或长名称。 IPv4 的多播地址为 224.0.0.251,IPv6 的多播地址为 ff02::fb,两种情况下的目标端口均为 5353/UDP。如果同一网络中的其他系统avahi-daemon
配置了另一个 mDNS 响应程序,这可能允许您使用本地网段中的主机名,而无需/etc/hosts
在每个系统上设置真正的 DNS 服务器或维护文件。myhostname
允许系统始终成功解析自己的主机名,即使没有/etc/hosts
配置 DNS 服务器,并且不存在网络连接。mymachines
允许系统自动解析已使用设置的虚拟机的主机名systemd-machined.service
可能还有其他关键字,因为/etc/nsswitch.conf
可以通过提供实现名称服务切换 API 的共享库来扩展系统,例如libnss_<keyword>.so*
.
nameserver 127.0.0.53
如果您看到中的行/etc/resolv.conf
,这也是一个systemd-resolved
正在使用的标志,您应该使用它resolvectl
来检查实际的 DNS 设置。
大多数程序使用C标准库的主机名解析函数(通常glibc
),但一些非常老的程序或专为DNS诊断而设计的程序将/etc/resolv.conf
直接读取。
通过使用关键字resolve
in /etc/nsswitch.conf
,C 标准库的主机名解析函数将直接路由到systemd-resolved
,并且nameserver 127.0.0.53
in/etc/resolv.conf
还可以重定向任何旧的/诊断程序以使用本地systemd-resolved
.
正在考虑替换关键字 and ,因为它们并不真正支持特定于连接的 DNS 服务器的概念:它们有一个内置的假设,即所有 DNS 服务器都知道相同的事情,因此如果一台 DNS 服务器说某件事不dns
知道/etc/resolv.conf
存在,他们认为没有理由向不同的 DNS 服务器询问第二意见。
systemd-resolved
允许配置特定于连接的 DNS 服务器,还允许将有关特定域的查询定向到特定于连接的 DNS 服务器。
(从技术上讲,如果 DNS 服务器响应“您请求的记录不存在”,则它是有效答案,而不是错误- 尽管这可能不是您想要的答案。只有像“我无法回答这个问题”或“我不被允许告诉你”这样的回答才是错误的。)