网站打不开是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系统中,如何具体查看DB2数据库的端口占用及监听信息?

    在Linux环境下管理DB2数据库时,查看端口信息是日常运维和故障排查的重要环节,DB2数据库的端口用于客户端连接、实例间通信以及管理工具访问,正确识别端口状态不仅能帮助确认服务是否正常运行,还能避免因端口冲突或未开放导致连接失败,本文将详细介绍在Linux系统中查看DB2端口的多种方法,包括通过DB2命令、系……

    2025年9月25日
    12500
  • linux如何获取管理员

    Linux 中,通常可通过切换到 root 用户(如用 su 命令输入密码)

    2025年8月18日
    13200
  • Linux如何支持XFS文件系统?配置与使用方法详解

    Linux作为开源操作系统,对多种文件系统的支持是其灵活性的重要体现,其中XFS凭借高性能、高可靠性和强大的可扩展性,成为企业级应用、大数据存储及高性能计算场景的首选文件系统之一,Linux对XFS的支持是一个完整的生态体系,涵盖内核层、用户工具层和应用适配层,确保XFS能够稳定运行并发挥其性能优势,内核层支持……

    2025年10月2日
    12200
  • 如何使用ip link命令优化网络?

    在Linux系统中,获取网络接口的MAC地址(物理地址)是网络管理、故障排查或安全配置的常见需求,以下是几种可靠且高效的方法,适用于大多数Linux发行版(如Ubuntu、CentOS、Debian等),所有操作均需在终端中执行:最现代且官方推荐的工具,输出简洁易读:ip link show操作步骤:打开终端……

    2025年7月19日
    14400
  • 在Linux操作系统中如何正确执行Windows的bat文件?

    在Linux操作系统中,直接执行Windows批处理文件(.bat)会遇到兼容性问题,因为Linux和Windows的命令行环境、命令语法及文件系统结构存在显著差异,Windows批处理文件是基于CMD(命令提示符)的脚本,使用Windows特有的命令语法(如dir、copy、del等),而Linux默认使用S……

    2025年8月24日
    12700

发表回复

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

联系我们

400-880-8834

在线咨询: QQ交谈

邮件:HI@E.KD.CN

关注微信