Linux下的DNS配置

Linux下的DNS配置

在 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

相关内容