Linux系统如何使用命令行设置DNS服务器的详细步骤?

在Linux系统中,DNS(域名系统)配置的正确性直接影响网络访问能力,通过命令行设置DNS是系统管理和运维中的基础技能,Linux系统设置DNS的方式因发行版和网络管理工具的不同而有所差异,本文将详细介绍常见配置方法,包括临时修改、永久配置及不同发行版的适配方案,并附上验证方法和注意事项。

linux如何用命令行设置dns

直接编辑/etc/resolv.conf文件(临时/永久配置)

/etc/resolv.conf是Linux系统中存放DNS配置的核心文件,记录了系统使用的DNS服务器地址,直接编辑此文件是最简单的方式,但需注意部分系统下该文件可能被网络管理工具(如NetworkManager、systemd-resolved)动态覆盖,导致修改不持久。

查看当前DNS配置

使用catless命令查看文件内容:

cat /etc/resolv.conf

输出示例:

# Generated by NetworkManager
nameserver 192.168.1.1
nameserver 8.8.8.8

其中nameserver行指定了DNS服务器地址,可配置多个(按优先级从上到下生效)。

修改DNS配置

使用文本编辑器(如vinano)打开文件:

sudo vi /etc/resolv.conf

在文件中添加或修改nameserver行,例如配置公共DNS(如Google DNS:8.8.8、Cloudflare DNS:1.1.1)或内网DNS:

nameserver 8.8.8.8
nameserver 1.1.1.1
nameserver 192.168.1.1  # 内网DNS,优先级低于前两者

保存退出(vi中按Esc后输入wq)。

永久生效的注意事项

  • NetworkManager管理(Ubuntu桌面版/CentOS 7+):直接编辑/etc/resolv.conf会被NetworkManager覆盖,需通过nmcli工具修改(见下文)。
  • systemd-resolved管理(Ubuntu 18.04+ Server):该工具会维护/etc/resolv.conf,建议通过修改resolved.conf配置或创建.network文件(见后文)。
  • 传统系统(如CentOS 6):直接编辑/etc/resolv.conf可永久生效,但需确保网络服务未使用动态管理工具。

使用NetworkManager的nmcli命令(Ubuntu/CentOS推荐)

NetworkManager是现代Linux发行版(如Ubuntu、CentOS 7+)默认的网络管理工具,通过nmcli命令可安全、永久地修改DNS配置,避免直接编辑文件被覆盖的问题。

查看当前网络连接

nmcli connection show

输出示例:

NAME    UUID                                  TYPE      DEVICE
ens33   12345678-1234-1234-1234-123456789012  ethernet  ens33

记录当前活动的连接名称(如ens33)。

linux如何用命令行设置dns

修改DNS配置

为指定连接添加DNS服务器,例如添加8.8.81.1.1

sudo nmcli connection modify "ens33" ipv4.dns "8.8.8.8 1.1.1.1"

若需配置IPv6 DNS,添加ipv6.dns参数:

sudo nmcli connection modify "ens33" ipv6.dns "2001:4860:4860::8888"

重启网络连接使配置生效

sudo nmcli connection down "ens33" && sudo nmcli connection up "ens33"

验证配置

检查/etc/resolv.conf是否更新,或使用nmcli查看DNS设置:

nmcli connection show "ens33" | grep dns

使用systemd-networkd配置文件(Ubuntu Server适用)

对于使用systemd-networkd作为网络管理工具的系统(如Ubuntu Server 18.04+),可通过创建或修改.network文件实现DNS永久配置。

创建网络配置文件

以网卡ens33为例,在/etc/systemd/network/目录下创建配置文件(如ens33.network):

sudo vi /etc/systemd/network/ens33.network

配置DNS和网卡信息

在文件中添加以下内容:

[Match]
Name=ens33
[Network]
DNS=8.8.8.8 1.1.1.1
Domains=example.com
DHCP=no
Address=192.168.1.100/24
Gateway=192.168.1.1

重启网络服务

sudo systemctl restart systemd-networkd

验证配置

检查/etc/resolv.conf是否包含配置的DNS服务器,或使用resolvectl status命令:

resolvctl status

传统ifcfg文件配置(CentOS/RHEL 6/7)

在较老的CentOS/RHEL系统中(如6、7版本),网络配置通过ifcfg文件管理,需在网卡配置文件中添加DNS相关参数。

编辑网卡配置文件

以网卡eth0为例,编辑/etc/sysconfig/network-scripts/ifcfg-eth0

sudo vi /etc/sysconfig/network-scripts/ifcfg-eth0

添加DNS配置

在文件中添加或修改以下参数:

linux如何用命令行设置dns

DNS1=8.8.8.8
DNS2=1.1.1.1
DOMAIN=example.com

重启网络服务

sudo systemctl restart network

验证配置

检查/etc/resolv.conf是否更新,或使用nmcli(若系统已安装NetworkManager)查看DNS设置。

不同发行版DNS配置方式对比

发行版/系统 推荐配置方式 配置文件/命令 重启服务 持久性说明
Ubuntu桌面版 nmcli命令 nmcli connection modify nmcli connection up/down 永久生效,不会被NetworkManager覆盖
CentOS 7+/RHEL 7+ nmcli命令 nmcli connection modify nmcli connection up/down 永久生效
Ubuntu Server 18.04+ systemd-networkd配置文件 /etc/systemd/network/*.network systemctl restart systemd-networkd 永久生效
CentOS 6/RHEL 6 ifcfg文件 /etc/sysconfig/network-scripts/ifcfg-* service network restart 永久生效

验证DNS配置是否生效

配置完成后,可通过以下命令验证DNS解析是否正常:

  1. 使用nslookup命令
    nslookup www.baidu.com

    若返回正确的IP地址(如181.38.148),则DNS配置生效。

  2. 使用dig命令
    dig www.baidu.com

    查看ANSWER SECTION中的IP地址是否正确。

  3. 检查resolv.conf文件
    cat /etc/resolv.conf

    确认nameserver行包含配置的DNS服务器。

注意事项

  1. 多DNS服务器优先级/etc/resolv.conf或网络配置文件中,nameserver按从上到下的顺序使用,若第一个DNS不可用,会自动尝试下一个。
  2. 避免直接修改关键文件:在NetworkManager或systemd-resolved管理的系统中,直接修改/etc/resolv.conf可能被覆盖,建议使用对应工具的命令或配置文件。
  3. 内网DNS与公共DNS结合:企业环境中通常建议同时配置内网DNS(如168.1.1)和公共DNS(如8.8.8),确保内网服务解析优先,同时提供外部域名解析兜底。

相关问答FAQs

Q1:修改DNS后不生效,如何排查?
A:可按以下步骤排查:

  1. 检查/etc/resolv.conf是否包含配置的DNS服务器,若内容被清空或还原,说明被网络管理工具覆盖,需改用对应工具的配置方式(如nmclisystemd-networkd)。
  2. 使用systemctl status network(或NetworkManagersystemd-networkd)检查网络服务状态,确保服务正常运行。
  3. 使用nslookupdig命令测试DNS解析,若仍失败,可能是防火墙(如iptablesfirewalld)阻止了DNS查询端口(53),需放行相关规则。
  4. 检查网卡配置是否正确(如IP地址、网关),确保网络连通性。

Q2:如何设置多个DNS服务器并指定优先级?
A:在Linux中,DNS服务器的优先级由配置文件中的顺序决定,越靠前的优先级越高,不同配置方式下设置方法如下:

  • 直接编辑/etc/resolv.conf:按优先级从上到下添加nameserver行,
    nameserver 192.168.1.1  # 内网DNS,优先级最高
    nameserver 8.8.8.8      # 公共DNS,次优先
    nameserver 1.1.1.1      # 备用DNS
  • 使用nmcli命令:通过空格分隔多个DNS地址,系统会按顺序使用:
    sudo nmcli connection modify "ens33" ipv4.dns "192.168.1.1 8.8.8.8 1.1.1.1"
  • systemd-networkd配置文件:在DNS参数中按空格分隔多个地址:
    DNS=192.168.1.1 8.8.8.8 1.1.1.1

    配置完成后重启网络服务,系统会按顺序依次尝试DNS服务器,确保解析的高可用性。

原创文章,发布者:酷番叔,转转请注明出处:https://cloud.kd.cn/ask/32603.html

(0)
酷番叔酷番叔
上一篇 2025年9月29日 18:41
下一篇 2025年9月29日 18:50

相关推荐

  • jacob如何在Linux环境中正确部署?

    Jacob(Java-COM Bridge)是一个用于Java程序调用Windows组件对象模型(COM)组件的库,但由于COM技术是Windows特有的,直接在Linux环境中部署Jacob存在原生不兼容的问题,要实现类似功能,需通过模拟环境、替代方案或间接调用等策略,以下是详细的部署步骤及方案分析,理解Ja……

    2025年8月24日
    3200
  • Linux系统运行的核心机制是什么?

    Linux是一个开源的类Unix操作系统,其运行机制基于内核与用户空间的协同工作,通过分层架构和模块化设计实现资源管理、程序执行和用户交互,要理解Linux如何运行,需从系统架构、启动流程、内核功能、用户空间交互等多个维度展开,Linux系统架构:内核空间与用户空间的协同Linux采用分层架构,核心分为内核空间……

    2025年8月30日
    3200
  • Linux6.5系统安装软件的具体方法步骤是什么?

    Linux作为开源操作系统,软件安装是其核心操作之一,与Windows的exe或macOS的dmg不同,Linux依赖包管理器统一管理软件依赖、版本和更新,确保系统稳定,Linux6.5内核作为较新版本,广泛应用于主流发行版(如Debian 12、Rocky Linux 9等),本文将详细介绍基于该内核系统的软……

    2025年9月10日
    2000
  • Linux如何安装QQ?3种实测方法

    sudo apt update && sudo apt upgrade -y # Debian/Ubuntusudo dnf update -y # Fedora官方原生QQ(功能精简)腾讯官方提供Linux版QQ,但功能较基础(截至2024年最新版):下载安装包官网下载地址 选择对应架构:In……

    2025年7月23日
    4600
  • Linux tmp目录性能不足?安全优化指南

    为什么需要调整/tmp?空间不足:默认/tmp可能位于根分区,易导致磁盘写满,性能优化:将/tmp挂载到内存(tmpfs)可加速读写,安全性:严格的文件权限和定期清理防止敏感信息残留,调整方法详解方法1:挂载为tmpfs(内存文件系统)适用场景:需要高速读写的临时文件(如编译任务),操作步骤:编辑配置文件: s……

    2025年6月17日
    5600

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

联系我们

400-880-8834

在线咨询: QQ交谈

邮件:HI@E.KD.CN

关注微信