网站打不开是DNS的锅?

在Linux系统中配置DNS是确保网络连接正常的关键步骤,以下将详细介绍多种配置方法,涵盖主流发行版(如Ubuntu、CentOS、Debian等),并强调安全性和最佳实践,所有操作均需root权限(使用sudo或切换root用户)。

  • DNS作用:将域名(如www.example.com)解析为IP地址(如0.2.1)。
  • 配置文件
    • /etc/resolv.conf:传统DNS配置文件(可能被覆盖)。
    • /etc/systemd/resolved.conf:systemd系统的DNS配置。
    • /etc/NetworkManager/NetworkManager.conf:NetworkManager服务配置。
    • /etc/netplan/*.yaml:Ubuntu 18.04+的Netplan配置。

配置方法详解

方法1:临时修改(重启失效)

编辑/etc/resolv.conf(适用于临时测试):

sudo nano /etc/resolv.conf

添加DNS服务器(例如Cloudflare和Google DNS):

nameserver 1.1.1.1
nameserver 8.8.8.8

注意:某些服务(如NetworkManager)会覆盖此文件,需结合以下永久配置。


方法2:永久配置(推荐)

1 使用NetworkManager(图形界面/命令行)

  • 图形界面(Ubuntu/CentOS GNOME):
    1. 打开设置网络 → 选择连接 → IPv4/IPv6
    2. 关闭自动获取DNS,手动输入DNS地址(如1.1.1,8.8.8.8)。
  • 命令行
    nmcli con mod "连接名" ipv4.dns "1.1.1.1 8.8.8.8"
    nmcli con up "连接名"  # 应用配置

2 使用systemd-resolved(Ubuntu/Debian)

  1. 编辑配置文件:
    sudo nano /etc/systemd/resolved.conf
  2. 取消注释并修改:
    [Resolve]
    DNS=1.1.1.1 8.8.8.8
    Domains=example.com
  3. 重启服务:
    sudo systemctl restart systemd-resolved
  4. 验证状态:
    systemd-resolve --status

3 使用Netplan(Ubuntu 18.04+)

  1. 编辑YAML文件(如/etc/netplan/01-netcfg.yaml):
    network:
      version: 2
      ethernets:
        eth0:
          dhcp4: no
          addresses: [192.168.1.10/24]
          gateway4: 192.168.1.1
          nameservers:
            addresses: [1.1.1.1, 8.8.8.8]
            search: [example.com]
  2. 应用配置:
    sudo netplan apply

4 传统配置(Debian/CentOS)

  • 文件路径/etc/network/interfaces(Debian)或/etc/sysconfig/network-scripts/ifcfg-eth0(CentOS 7)。
  • 示例(Debian)
    iface eth0 inet static
      address 192.168.1.10
      netmask 255.255.255.0
      gateway 192.168.1.1
      dns-nameservers 1.1.1.1 8.8.8.8
      dns-search example.com
  • 重启网络服务:
    sudo systemctl restart networking  # Debian
    sudo systemctl restart network     # CentOS 7

验证DNS配置

  1. 检查生效的DNS
    cat /etc/resolv.conf  # 注意:可能被覆盖
    systemd-resolve --status  # systemd系统
  2. 测试解析
    nslookup google.com
    dig google.com +short
    ping -c 3 google.com

常见问题解决

  • DNS被覆盖:若/etc/resolv.conf被重置,检查:
    • NetworkManager的dns=none选项(在/etc/NetworkManager/NetworkManager.conf中)。
    • 禁用resolvconf服务:sudo systemctl stop resolvconf.service
  • 解析缓慢:优化DNS顺序或更换公共DNS(如1.1.18.8.8更快)。
  • 安全建议
    • 使用加密DNS(DoH/DoT),如cloudflare-dns.com
    • 避免公共Wi-Fi中使用默认DNS(防劫持)。

最佳实践

  1. 主备DNS分离:配置至少两个DNS(如主用Cloudflare,备用Google)。
  2. 本地缓存加速:安装dnsmasqsystemd-resolved提升解析速度。
  3. 企业环境:优先使用内部DNS服务器,保障域名解析安全。

引用说明基于Linux官方文档(kernel.org)、Ubuntu Manpage(manpages.ubuntu.com)及Cloudflare公共DNS指南(1.1.1),配置前请备份原始文件,操作需符合企业安全策略。

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

(0)
酷番叔酷番叔
上一篇 2025年7月24日 06:50
下一篇 2025年7月24日 07:01

相关推荐

  • Linux如何挂载U盘

    检测U盘设备插入U盘,执行命令识别设备:sudo fdisk -l观察输出结果,通常U盘显示为 /dev/sdb 或 /dev/sdc(末尾的 sdb1、sdc1 表示分区),通过容量和分区类型(如 FAT32、NTFS)确认U盘标识,使用lsblk快速查看:lsblk输出示例: sdb 8:16 1 14.9……

    2025年7月9日
    3500
  • Linux中Java工程如何创建?从环境搭建到完整工程管理?

    在Linux环境下搭建Java工程是Java开发者的基础技能,本文将详细介绍从环境准备到项目创建、配置管理及构建运行的完整流程,涵盖Maven和Gradle两种主流构建工具的使用方法,帮助开发者高效完成Java工程的初始化工作,环境准备:安装JDK与构建工具安装JDKJava工程运行依赖Java开发工具包(JD……

    2025年8月23日
    1500
  • 如何专业查看Linux硬盘信息?

    基础命令:快速获取硬盘概览lsblk(推荐首选)列出所有块设备(硬盘、分区)的树状结构:lsblk输出解读:NAME(设备名,如sda)、SIZE(容量)、TYPE(disk/part)、MOUNTPOINT(挂载点),优势:无需root权限,清晰展示设备层级关系,df(查看磁盘使用率)显示文件系统的磁盘空间占……

    2025年7月31日
    2300
  • 如何快速掌握最常用ps命令?

    在Linux系统中,进程之间通过父子关系形成树状结构,每个进程(除初始进程init或systemd外)都由另一个进程创建,创建者称为父进程(Parent Process),了解父进程对排查问题(如异常进程来源)、管理服务依赖或分析系统行为至关重要,以下是几种查看进程父进程的详细方法:ps(Process Sta……

    2025年7月9日
    3400
  • 如何查看Linux系统时间?常用命令与方法有哪些?

    在Linux系统中,查看系统时间有多种方式,涵盖命令行工具、系统文件及图形界面等,用户可根据需求选择合适的方法,以下从常用命令、底层文件及图形操作三方面详细介绍,并附上命令对比表格及常见问题解答,命令行工具查看系统时间命令行是Linux系统中最常用的操作方式,通过简单指令即可快速获取时间信息,以下是几种核心命令……

    2025年8月29日
    1500

发表回复

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

联系我们

400-880-8834

在线咨询: QQ交谈

邮件:HI@E.KD.CN

关注微信