今天在服务器上拉取 docker 镜像时,死活都拉取不下来,更改了国内镜像源也依旧无法拉下来,最后就怀疑不是 docker 镜像源的问题,于是就干脆 ping 了一下某度,发现竟然是服务器上 DNS 解析的问题。
其中也遇到了一些问题,折腾了好几个小时,于是将解决方案分享给到大家,希望有类似问题时,对你们有所帮助。
问题起源
当我去 ping 某度时
ping www.baidu.com报错如下:
ping: www.baidu.com: Temporary failure in name resolution
为了验证是 DNS 的问题导致的,我们可以尝试直接先 ping IP 地址或者通过其他的命令行来验证

我们可以看到,当我们直接 ping IP 地址时,网络是通的,但是使用 nslookup baidu.com 来访问时,一直连接超时,那么多半就是 DNS 解析导致的无法上网。
以往的解决方案
我们知道,通常在 Ubuntu 系统中修改 dns 可以通过修改 /etc/resolv.conf 配置文件来解决,但是在 Ubuntu 24.04 LTS 系统中,我发现,不管怎么修改这个配置文件,域名解析都在往 127.0.0.53 这个地址发送

我们通过查看 /etc/resolv.conf 配置文件可以看到 /etc/resolv.conf 配置文件软连接到了 /run/systemd/resolve/stub-resolv.conf 配置文件,那么,我们直接修改 /run/systemd/resolve/stub-resolv.conf 是否就可以解决问题呢?然而,经过尝试,依旧不行。

那么,如何解决呢?
解决方案
先修改 DNS 配置
打开 /etc/systemd/resolved.conf 文件
vim /etc/systemd/resolved.conf在 /etc/systemd/resolved.conf 中修改 DNS 配置信息,比如我这里修改成了:
[Resolve]
DNS=1.1.1.1 233.6.6.6 114.114.114.114 8.8.8.8
备份旧的配置文件
# 直接备份一下,怕出问题
mv /etc/resolv.conf /etc/resolv.conf.alexbak建立软连接
ln -s /run/systemd/resolve/resolv.conf /etc/
现在的软连接关系就是这样

重启网络
systemctl restart systemd-resolved检验一下,发现可以正常访问了,大功告成!

查看缓存文件是否已经生效
cat /run/systemd/resolve/resolv.conf

