在Linux系统中,域名解析是将人类可读的域名(如www.example.com)转换为机器可读的IP地址(如192.0.2.1)的过程,这一功能主要通过DNS(Domain Name System)协议实现,而Linux系统提供了多种方式配置域名解析,包括本地hosts文件、DNS客户端配置以及网络管理工具等,以下从核心配置文件、工具使用到实际场景逐步说明。

本地域名解析配置:/etc/hosts文件
/etc/hosts是Linux系统中最早的域名解析机制,用于本地静态域名与IP的映射,它优先级高于DNS查询,系统会先检查该文件,若未找到记录再向DNS服务器发起请求。
文件格式与示例:
IP地址 主机名/域名 [别名...] 127.0.0.1 localhost.localdomain localhost 192.168.1.100 server1.example.com server1 ::1 localhost6.localdomain6 localhost6
配置步骤:
- 以root权限编辑文件:
sudo vi /etc/hosts - 添加或修改映射关系,每行一条记录,格式需严格对齐。
- 保存后立即生效,无需重启服务。
适用场景:
- 局域网内服务器快速访问(如避免DNS延迟)。
- 测试环境域名模拟(如将开发域名指向本地IP)。
- 屏蔽特定域名(将恶意域名指向0.0.0.0)。
DNS服务器配置:/etc/resolv.conf
/etc/resolv.conf是系统DNS客户端的核心配置文件,用于指定DNS服务器的地址、域名搜索后缀等参数。
关键字段说明:

| 字段 | 作用 | 示例 |
|---|---|---|
| nameserver | 指定DNS服务器IP,最多可配置3个(按顺序查询) | nameserver 8.8.8.8 |
| search | 定义域名搜索后缀(查询短主机名时自动补全) | search example.com local |
| domain | 设置本地域名(若search未指定,则使用此值作为默认后缀) | domain example.com |
| options | 调整DNS解析行为(如超时时间、重试次数等) | options timeout:2 attempts:3 |
配置示例:
nameserver 114.114.114.114 # 国内公共DNS nameserver 8.8.8.8 # Google DNS search example.com local # 查询"web"时,依次尝试web.example.com、web.local options timeout:1 rotate # 超时1秒,轮询DNS服务器
注意事项:
- 直接修改
/etc/resolv.conf在部分系统(如Ubuntu 18.04+)中可能被网络管理工具覆盖,需通过特定工具持久化配置(后文详述)。 nameserver优先级:文件中从上到下依次查询,建议将最快、最稳定的DNS服务器置于首位。
现代网络管理工具的DNS配置
为避免/etc/resolv.conf被覆盖,现代Linux发行版推荐通过网络管理工具(如NetworkManager、systemd-networkd)配置DNS。
NetworkManager(适用于桌面/服务器场景)
通过nmcli命令或配置文件修改DNS设置:
# 查看当前网络连接 nmcli connection show # 修改指定连接的DNS服务器(如连接名为"eth0") sudo nmcli connection modify eth0 ipv4.dns "8.8.8.8 114.114.114.114" sudo nmcli connection modify eth0 ipv4.dns-search "example.com" # 激活配置 sudo nmcli connection up eth0
systemd-networkd(适用于轻量级服务器)
编辑网络配置文件(如/etc/systemd/network/20-wired.network):
[Match] Name=eth0 [Network] DNS=8.8.8.8 114.114.114.114 Domains=example.com
保存后重启服务:sudo systemctl restart systemd-networkd

DNS解析测试与验证
配置完成后,可通过以下工具验证解析是否生效:
ping:测试域名连通性(ping www.example.com)。nslookup:交互式查询DNS记录(nslookup www.example.com)。dig:获取详细DNS解析信息(dig www.example.com)。host:简洁查询域名IP(host www.example.com)。
相关问答FAQs
Q1:修改/etc/resolv.conf后重启网络,配置被还原怎么办?
A1:此问题通常由网络管理工具(如NetworkManager、systemd-resolved)自动覆盖导致,解决方法:
- 若使用NetworkManager,通过
nmcli命令修改DNS配置(如前文所述),或编辑对应连接的配置文件(在/etc/NetworkManager/system-connections/目录下)。 - 若使用systemd-resolved,需修改
/etc/systemd/resolved.conf文件,在[Resolve]段添加DNS=8.8.8.8和Domains=example.com,然后执行sudo systemctl restart systemd-resolved,并确保/etc/resolv.conf为符号链接(ls -l /etc/resolv.conf应指向../run/systemd/resolve/stub-resolv.conf)。
Q2:如何为Linux系统配置DNS域名解析的缓存?
A2:Linux默认不内置DNS缓存,可通过安装第三方服务实现:
systemd-resolved:多数现代系统已预装,启用缓存需修改/etc/systemd/resolved.conf,取消Cache=yes的注释,重启服务后生效,可通过resolvectl status查看缓存统计。dnsmasq:轻量级DNS缓存服务器,安装后(sudo apt install dnsmasq)编辑/etc/dnsmasq.conf,添加listen-address=127.0.0.1和cache-size=1000,重启服务(sudo systemctl restart dnsmasq),并将/etc/resolv.conf的首个nameserver设为0.0.1。nscd(Name Service Cache Daemon):适用于/etc/hosts和DNS缓存,安装后(sudo apt install nscd)编辑/etc/nscd.conf,启用enable-cache hosts yes和enable-cache hosts yes,重启服务即可。
原创文章,发布者:酷番叔,转转请注明出处:https://cloud.kd.cn/ask/14039.html