在 Linux 中,/etc/resolv.conf
当我们设置 DNS 时,由于管理 DNS 服务器的程序很多,经常会被覆盖。
如何正确设置DNS?
答案1
Linux下的DNS配置
Linux 上的 DNS 使用已完成C 库中的一组例程,提供对 Internet 域名系统 (DNS) 的访问。解析器配置文件 ( resolv.conf
) 包含解析器例程首次被进程调用时读取的信息。简而言之,每个请求 DNS 的进程都会读取/etc/resolv.conf
库。国家安全局位于其之上,并由 进行配置/etc/nsswitch.conf
。
Linux DNS 配置位于文件中/etc/resolv.conf
但有许多程序/服务想要自动管理和处理位于 的 DNS 配置文件/etc/resolv.conf
。在某些情况下,您可能希望自己管理此文件。每个管理 DNS 的程序/服务都有自己的配置文件,例如/etc/dnsmasq.conf
(对于 dnsmasq 服务),并在连接更改和/或其他事件时附加 DNS 配置...一个快速解决方案是锁定 DNS 配置文件,chattr +i /etc/resolv.conf
但不建议这样做在某些情况下,更好的解决方案是使用 DNS 正确设置所有程序/服务,例如(dnsmasq/network-manager/resolvconf/等)
夺回 DNS 的控制权
这是一份详尽的设置列表重新获得 resolv.conf 的控制权并避免将其覆盖(如何从 resolv.conf 以外的其他位置禁用/设置 DNS)请注意,resolvconf 是一个独立于 resolv.conf 的程序,也取决于您的系统/配置,您可能没有此处列出的一个或多个程序。
1.解析配置:
配置文件
cat /etc/resolvconf/resolv.conf.d/head
nameserver 8.8.4.4
cat /etc/resolvconf/resolv.conf.d/base
nameserver 8.8.4.4
更新配置
sudo resolvconf -u
禁用resolvconf
systemctl disable --now resolvconf.service
2.Dnsmasq服务:
配置文件
cat /etc/dnsmasq.conf
server=1.1.1.1
server=8.8.4.4
更新配置
sudo systemctl restart dnsmasq.service
3.网络管理员:
配置文件
/etc/NetworkManager/*
禁用 DNS
$ cat /etc/NetworkManager/conf.d/no-dns.conf
[main]
dns=none
启用 DNS
$ cat /etc/NetworkManager/conf.d/dns.conf
[main]
dns=default
[global-dns]
searches=example.com
[global-dns-domain-*]
使用已解决的服务
$ cat /usr/lib/NetworkManager/conf.d/resolved.conf
[main]
dns=systemd-resolved
使用resolvconf
$ cat /usr/lib/NetworkManager/conf.d/resolvconf.conf
[main]
rc-manager=resolvconf
更新配置
systemctl restart NetworkManager.service
4. 网络接口:
配置文件
$ cat /etc/network/interfaces
#nameservers
# or dns-search like so
# dns-search x.y
dns-nameservers 4.4.4.4 8.8.8.8
更新配置
reboot
5.DHCP客户端:
配置文件
$ cat /etc/dhcp3/dhclient.conf
supersede domain-name-servers <dns_ip_address1>,<dns_ip_address2>;
更新配置
reboot
6.Rdnssd服务:
禁用rdnssd
systemctl disable --now rdnssd.service
7、解决服务:
禁用已解决
systemctl disable --now systemd-resolved.service
8.网络配置:
配置文件
/etc/sysconfig/network/config
禁用网络配置
cat /etc/sysconfig/network/config
NETCONFIG_DNS_POLICY=""
更新配置
reboot
设置 DNS 服务器
/etc/resolv.conf
配置示例
#Cloudflare
nameserver 1.0.0.1
#Google
#nameserver 8.8.8.8
#nameserver 8.8.4.4
#Cloudflare
#nameserver 1.1.1.1
#Classic Config
#nameserver 192.168.1.1
#search lan
答案2
在 Fedora 36 上我做了:
# print existing DNS settings for all interfaces
$ resolvectl dns
# set new DNS
$ resolvectl dns enp0s22f6 8.8.8.8 8.8.4.4
# check again
$ resolvectl dns