我最近安装了 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
线路中删除。之后,解析应该恢复正常。