我最近安装了我的 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 中的错误?
mdns4_minimal [NOTFOUND=return]
爱普生打印机的多播 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
行中删除。在那之后,解决应该恢复正常。