0

0

Linux DNS 配置错误引发的访问问题

冷漠man

冷漠man

发布时间:2026-02-12 21:33:27

|

958人浏览过

|

来源于php中文网

原创

应修改 /etc/systemd/resolved.conf 中的 nameservers= 行并重启 systemd-resolved,而非手动编辑 /etc/resolv.conf;同时确保 networkmanager 配置为 dns=systemd-resolved 或正确设置 ipv4.ignore-auto-dns=true 以避免 dhcp 覆盖。

linux dns 配置错误引发的访问问题

resolv.conf 被 systemd-resolved 覆盖怎么办

Linux 发行版(尤其是 Ubuntu 20.04+、Fedora、Debian 12+)默认启用 systemd-resolved,它会接管 DNS 解析,并通过符号链接把 /etc/resolv.conf 指向自己的动态文件。你手动改了 /etc/resolv.conf,重启或网络重连后又变回 nameserver 127.0.0.53 —— 这不是权限问题,是服务在“守规矩”。

真正该改的是 systemd-resolved 的配置,而不是硬写死 /etc/resolv.conf

  • 编辑 /etc/systemd/resolved.conf,取消注释并修改 Nameservers= 行,比如:Nameservers=8.8.8.8 1.1.1.1
  • 运行 sudo systemctl restart systemd-resolved
  • 验证:执行 resolvectl status,确认 Global 部分显示你配的 DNS;cat /etc/resolv.conf 应仍指向 /run/systemd/resolve/stub-resolv.conf,但解析已生效

硬删符号链接再建静态文件,会导致 systemd-resolved 功能异常(如 LLMNR/mDNS 失效),且 NetworkManager 可能再次覆盖。

NetworkManager 写死 DNS 后不生效的典型原因

你在 GUI 网络设置里填了 DNS,或者用 nmtui 配了 ipv4.dns,但 dig google.com 还是走错服务器 —— 很可能因为 DNS 模式没设对。

NetworkManager 默认使用 dns=systemd-resolved(转发给 systemd-resolved),但如果你手动改过 /etc/resolv.conf 或停用了 systemd-resolved,它就退回到 dns=default,此时实际由 DHCP 提供的 DNS 覆盖你的手动配置。

解决方法(二选一):

  • 保持 systemd-resolved 启用:确保 /etc/NetworkManager/conf.d/99-dns.conf 中有 dns=systemd-resolved,然后重启 NetworkManager
  • 彻底绕过它:在连接配置中加 ipv4.ignore-auto-dns=trueipv4.dns-priority=-100,再设 ipv4.dns,最后 nmcli connection reload && nmcli connection up <conn-name></conn-name>

注意:仅设 ipv4.dns 不够,必须配合 ignore-auto-dns,否则 DHCP 的 DNS 优先级更高。

LanguagePro
LanguagePro

LanguagePro是一款强大的AI写作助手,可以帮助你更好、更快、更有效地写作。

下载

容器或 curl/wget 访问失败,但 host/nslookup 正常

hostnslookup 直接走系统 DNS 配置,而 curlwget、Docker 容器默认用 libc 的 getaddrinfo(),受 /etc/nsswitch.conf 和 glibc 缓存影响;容器更可能继承宿主机的 /etc/resolv.conf,但被 --dns 或 CNI 插件覆盖。

排查重点:

  • getent hosts google.com:如果失败,说明 glibc 层解析卡住,检查 /etc/nsswitch.confhosts: 行是否含 dns,且顺序合理(比如别写成 files [!UNAVAIL=return] dns
  • curl -v http://google.com 输出里的 * Trying 行:看它连的是哪个 IP,确认是不是解析错了,还是连通性问题
  • Docker 容器内执行 cat /etc/resolv.conf:若内容是 127.0.0.11(dockerd 内置 DNS),需确认 dockerd 是否配置了 --dns,或容器启动时加了 --dns 参数

常见陷阱:在容器里改 /etc/resolv.conf 是临时的,下次启动就丢;应通过 docker run --dns/etc/docker/daemon.json 全局配置。

systemd-resolved 日志里反复出现 “Failed to send packet: Operation not permitted”

这个错误通常出现在启用了 systemd-resolved 但同时又运行了另一个本地 DNS 服务(比如 dnsmasqunboundbind9)监听 127.0.0.1:53。systemd-resolved 尝试向自己配置的上游发包时,被本地服务拦截并拒绝。

本质是端口冲突和职责重叠:

  • 检查谁占着 53 端口:sudo ss -tulpn | grep ':53'
  • 如果看到 dnsmasqunbound,停掉它:sudo systemctl stop dnsmasq,再禁用:sudo systemctl disable dnsmasq
  • 不要让多个本地 DNS 服务共存;如果真需要自建 DNS,请关闭 systemd-resolved 并确保 /etc/resolv.conf 指向你的服务(如 127.0.0.1),同时 NetworkManager 设为 dns=none

这个错误不会直接导致解析失败,但会让日志刷屏、掩盖真实问题,而且上游查询可能静默超时。

DNS 配置真正的复杂点不在“怎么写”,而在“谁在管”——systemd-resolvedNetworkManagerdhcpcddockerd、甚至云平台的 metadata 服务,都可能悄悄改写同一个文件或覆盖同一层解析逻辑。盯住 resolvectl statusnmcli device show,比反复改 /etc/resolv.conf 有用得多。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
json数据格式
json数据格式

JSON是一种轻量级的数据交换格式。本专题为大家带来json数据格式相关文章,帮助大家解决问题。

436

2023.08.07

json是什么
json是什么

JSON是一种轻量级的数据交换格式,具有简洁、易读、跨平台和语言的特点,JSON数据是通过键值对的方式进行组织,其中键是字符串,值可以是字符串、数值、布尔值、数组、对象或者null,在Web开发、数据交换和配置文件等方面得到广泛应用。本专题为大家提供json相关的文章、下载、课程内容,供大家免费下载体验。

544

2023.08.23

jquery怎么操作json
jquery怎么操作json

操作的方法有:1、“$.parseJSON(jsonString)”2、“$.getJSON(url, data, success)”;3、“$.each(obj, callback)”;4、“$.ajax()”。更多jquery怎么操作json的详细内容,可以访问本专题下面的文章。

317

2023.10.13

go语言处理json数据方法
go语言处理json数据方法

本专题整合了go语言中处理json数据方法,阅读专题下面的文章了解更多详细内容。

81

2025.09.10

curl_exec
curl_exec

curl_exec函数是PHP cURL函数列表中的一种,它的功能是执行一个cURL会话。给大家总结了一下php curl_exec函数的一些用法实例,这个函数应该在初始化一个cURL会话并且全部的选项都被设置后被调用。他的返回值成功时返回TRUE, 或者在失败时返回FALSE。

450

2023.06.14

linux常见下载安装工具
linux常见下载安装工具

linux常见下载安装工具有APT、YUM、DNF、Snapcraft、Flatpak、AppImage、Wget、Curl等。想了解更多linux常见下载安装工具相关内容,可以阅读本专题下面的文章。

179

2023.10.30

default gateway怎么配置
default gateway怎么配置

配置default gateway的步骤:1、了解网络环境;2、获取路由器IP地址;3、登录路由器管理界面;4、找到并配置WAN口设置;5、配置默认网关;6、保存设置并退出;7、检查网络连接是否正常。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

226

2023.12.07

k8s和docker区别
k8s和docker区别

k8s和docker区别有抽象层次不同、管理范围不同、功能不同、应用程序生命周期管理不同、缩放能力不同、高可用性等等区别。本专题为大家提供k8s和docker区别相关的各种文章、以及下载和课程。

264

2023.07.24

c语言 数据类型
c语言 数据类型

本专题整合了c语言数据类型相关内容,阅读专题下面的文章了解更多详细内容。

4

2026.02.12

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
PostgreSQL 教程
PostgreSQL 教程

共48课时 | 9万人学习

Git 教程
Git 教程

共21课时 | 3.6万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号