更改 nsswitch.conf 后出现随机 DNS 错误

更改 nsswitch.conf 后出现随机 DNS 错误

我最近安装了 EPSON L3150 打印机的驱动程序,大约在同一时间,我开始在某些应用程序(ssh、nextcloud-client)中出现奇怪的(随机的)DNS 名称解析错误,我只能通过重新启动服务来修复NetworkManager

systemctl restart NetworkManager

例如:

$ ssh example.mydomain
ssh: Could not resolve hostname example.mydomain: Name or service not known

另一个例子是 getent,它不返回任何内容并以代码 2 退出:

$ getent hosts example.mydomain

$ echo $?
2

但 nslookup 工作正常:

$ nslookup example.mydomain
...
Name:   example.mydomain
Address: 192.168.0.10

我将范围缩小到我的nsswitch.conf文件,我责怪我的打印机安装程序更改了它。我发现了一个nsswitch.conf.bak谎言nsswitch.conf,它是在我安装打印机驱动程序的同时创建的dnf install epson/*.rpm

该文件在主机行中进行了以下更改:

-hosts:      files dns myhostname
+hosts:      files myhostname mdns4_minimal [NOTFOUND=return] resolve [!UNAVAIL=return] dns

所以问题是,为什么“新”配置会如此随机地失败?我该如何预防?我认为仅仅恢复原始文件并不是一个解决方案,因为新文件似乎是自动生成的,它在顶部这样说:

由 authselect 于 2022 年 2 月 12 日星期六 18:53:06 生成

卸载驱动程序也不是解决方案。

编辑

罪魁祸首似乎是systemd-resolved。我的网络配置由 NetworkManager 管理,并且我设置了两个 DNS:

$ nmcli con show my-lan
...
ipv4.dns 192.168.0.1 8.8.8.8

似乎每当我的计算机从睡眠中醒来时,NetworkManager 都会回退到第二个 DNS:

$ systemd-resolve --status
...
Link 2 (enp39s0)
    Current Scopes: DNS LLMNR/IPv4 LLMNR/IPv6
         Protocols: +DefaultRoute +LLMNR -mDNS -DNSOverTLS DNSSEC=no/unsupported
Current DNS Server: 8.8.8.8
       DNS Servers: 192.168.0.1 8.8.8.8
        DNS Domain: mydomain

因此导致systemd-resolve example.mydomain失败(因为 8.8.8.8 无法解析我的域):

查询:解析调用失败:找不到“example.mydomain”

我猜这是 NetworkManager 中的一个错误?

答案1

mdns4_minimal [NOTFOUND=return]Epson 打印机需要多播 DNS。

resolve [!UNAVAIL=return]通过启用名称解析systemd-resolved(请参阅https://www.freedesktop.org/software/systemd/man/nss-resolve.html)。

如果命令systemctl status systemd-resolved返回,Unit systemd-resolved.service could not be found.您可以安全地resolve [!UNAVAIL=return]hosts线路中删除。之后,解析应该恢复正常。

相关内容