当前位置: 首页 > news >正文

Linux云服务器如何手动配置DNS?

bb1d7f3b36e2f7131aac0467fd5a99de

Linux云服务器上手动配置 DNS(域名系统) 是确保服务器能够正常解析域名的重要步骤。以下是详细的配置方法,包括系统文件的修改和常见问题的解决方案。


1. 为什么需要手动配置 DNS?

默认情况下,云服务器会自动使用云服务商提供的 DNS 服务(如阿里云、腾讯云、AWS 等)。有时需要手动配置 DNS 的情况包括:

  • 使用自定义 DNS 服务器(如 Google DNS、Cloudflare DNS)。
  • 需要更快、更稳定的域名解析。
  • 解决 DNS 解析失败或缓慢的问题。
  • 配置域名解析服务(如本地 DNS 缓存服务器)。

2. 手动配置 DNS 的方法

以下是配置 DNS 的两种常见方式:

方法 1:修改 /etc/resolv.conf 文件

2.1 什么是 /etc/resolv.conf

/etc/resolv.conf 是一个用于配置 DNS 解析的文件,其中包含 DNS 服务器的 IP 地址。

2.2 配置步骤

  1. 检查当前的 DNS 配置
    查看当前 DNS 配置:

    bash
     
    cat /etc/resolv.conf

    示例输出:

    plaintext
     
    nameserver 8.8.8.8
    nameserver 8.8.4.4

    每一行的 nameserver 表示一个 DNS 服务器的 IP 地址。

  2. 编辑 /etc/resolv.conf 文件
    使用文本编辑器打开文件:

    bash
     
    sudo nano /etc/resolv.conf

    或:

    bash
     
    sudo vi /etc/resolv.conf
  3. 添加或修改 DNS 服务器地址
    替换或添加以下内容:

    plaintext
     
    nameserver 8.8.8.8        # Google Public DNS
    nameserver 8.8.4.4        # Google Secondary DNS
    nameserver 1.1.1.1        # Cloudflare DNS
    nameserver 9.9.9.9        # Quad9 DNS
  4. 保存文件

    • Nano:按 Ctrl+O 保存,按 Ctrl+X 退出。
    • Vi:输入 :wq 保存并退出。
  5. 测试 DNS 是否正常工作
    使用 pingnslookup 测试域名解析:

    bash
     
    ping google.com
    nslookup google.com

2.3 注意事项

  • 某些 Linux 系统(如 Ubuntu 18.04+)使用 systemd-resolved 管理 DNS,直接修改 /etc/resolv.conf 文件可能会被覆盖。此时需要使用方法 2。

方法 2:通过网络管理工具配置 DNS

2.1 Network Manager(适用于大多数 Linux 发行版)

如果系统使用 NetworkManager 管理网络,修改 /etc/resolv.conf 文件后可能会被自动重置,因此需要通过 NetworkManager 配置 DNS。

  1. 编辑网络配置文件
    对于 CentOS 和 RHEL 系统,通常配置文件位于 /etc/sysconfig/network-scripts/。找到对应的网络接口文件,例如 ifcfg-eth0

    bash
     
    sudo nano /etc/sysconfig/network-scripts/ifcfg-eth0

    添加或修改以下内容:

    plaintext
     
    DNS1=8.8.8.8
    DNS2=8.8.4.4
  2. 重启网络服务

    bash
     
    sudo systemctl restart NetworkManager
  3. 验证 DNS
    再次检查 /etc/resolv.conf 文件,确认是否包含你设置的 DNS1DNS2


2.2 使用 systemd-resolved(适用于 Ubuntu 18.04+ 和其他使用 systemd 的系统)

  1. 检查 systemd-resolved 是否启用
    查看服务状态:

    bash
     
    systemctl status systemd-resolved

    如果服务未运行,启动它:

    bash
     
    sudo systemctl start systemd-resolved
  2. 修改 DNS 配置
    使用以下命令设置 DNS 服务器:

    bash
     
    sudo systemd-resolve --set-dns=8.8.8.8 --interface=eth0
    sudo systemd-resolve --set-dns=8.8.4.4 --interface=eth0
  3. 持久化配置
    编辑 /etc/systemd/resolved.conf 文件:

    bash
     
    sudo nano /etc/systemd/resolved.conf

    修改或添加以下内容:

    plaintext
     
    [Resolve]
    DNS=8.8.8.8 8.8.4.4
  4. 重启服务

    bash
     
    sudo systemctl restart systemd-resolved
  5. 验证 DNS
    查看当前的 DNS 配置:

    bash
     
    systemd-resolve --status

3. 配置本地 DNS 缓存服务器

为了加速域名解析,可以在服务器上配置本地 DNS 缓存服务器(如 dnsmasqbind)。

3.1 安装 dnsmasq

  1. 安装 dnsmasq:

    bash
     
    sudo apt install dnsmasq -y      # Ubuntu/Debian
    sudo yum install dnsmasq -y      # CentOS
  2. 配置 dnsmasq:
    编辑配置文件:

    bash
     
    sudo nano /etc/dnsmasq.conf

    添加以下内容:

    plaintext
     
    listen-address=127.0.0.1
    server=8.8.8.8
    server=8.8.4.4
  3. 启动并启用服务:

    bash
     
    sudo systemctl start dnsmasq
    sudo systemctl enable dnsmasq
  4. 设置本地 DNS:
    修改 /etc/resolv.conf 文件,添加以下内容:

    plaintext
     
    nameserver 127.0.0.1

4. 测试和验证 DNS 配置

4.1 测试域名解析

使用以下命令测试域名解析是否正常:

bash
 
ping google.com
nslookup google.com
dig google.com

4.2 检查当前 DNS 服务器

查看当前使用的 DNS 服务器:

bash
 
cat /etc/resolv.conf

如果使用 systemd-resolved,运行:

bash
 
systemd-resolve --status

5. 常见问题及解决方法

5.1 /etc/resolv.conf 被自动覆盖

原因

某些 Linux 系统会动态生成 /etc/resolv.conf 文件(如 NetworkManager 或 systemd-resolved)。

解决方法

  1. 禁止自动覆盖:

    bash
     
    sudo chattr +i /etc/resolv.conf

    (注意:此操作会锁定文件,使其无法被修改。需要修改时,运行 sudo chattr -i /etc/resolv.conf 解锁。)

  2. 配置 NetworkManager 或 systemd-resolved(参考上文的对应方法)。


5.2 DNS 解析速度慢

原因

  • DNS 服务器响应时间过长。
  • 未启用本地 DNS 缓存。

解决方法

  1. 切换到更快的 DNS 服务器(如 Google、Cloudflare)。
  2. 安装并配置本地 DNS 缓存服务(如 dnsmasq)。

5.3 无法解析域名

原因

  • DNS 服务器配置错误。
  • 防火墙阻止了 DNS 请求(UDP 53)。

解决方法

  1. 检查 DNS 配置是否正确。
  2. 确保防火墙允许 UDP 53 端口:
    bash
     
    sudo ufw allow 53/udp
    sudo ufw reload

6. 总结

手动配置 DNS 是确保 Linux 云服务器稳定运行和快速解析域名的关键步骤。以下是操作总结:

  1. 修改 /etc/resolv.conf 文件,手动设置 DNS。
  2. 使用 NetworkManagersystemd-resolved 持久化 DNS 配置。
  3. 配置本地 DNS 缓存服务(如 dnsmasq)提升解析速度。
  4. 通过 pingnslookupdig 测试 DNS 配置是否生效。

通过以上方法,您可以根据需求在 Linux 云服务器上灵活配置 DNS 服务,实现快速、稳定的域名解析。

http://www.hskmm.com/?act=detail&tid=19179

相关文章:

  • Python 输入、输出的用法
  • 第一章——概论 - AlgosEng
  • 劝娃妈和娃不要学老人坐姿有感:老人无奈才坐成那样的。。AI协助分析很到位
  • 使用JOL查看对象布局
  • 集训队互测投题——封印
  • 一天一款实用的AI工具,第4期,AI翻译成英语
  • Docker基础与工程部署
  • 安装MariaDB服务器流程介绍在Ubuntu 22.04系统
  • 三种神器让LLM输出结构化数据:LangChain、LlamaIndex与Function Calling实战指南
  • win11安装ensp
  • 自己湿热内蕴出汗痒和岳母生病2天不洗澡发痒的不同-完美解释小孩为啥没那么容易痒
  • vue: ubuntu安装vue环境
  • golang实现ai聊天窗口
  • 源码反码补码
  • 图的分类法:解耦数据和图表类型
  • IDEA 2024的零卡死配置
  • 数据结构
  • Python + MediaPipe 手势绘画高级应用:从基础到创意交互 - 实践
  • Crypto 2021 s Accepted papers
  • Github 12.3kstar, 3分钟起步做中后台?Go+Vue 脚手架,把权限、代码生成、RBAC 都封装好了
  • 250927
  • 完整教程:多线程——单例模式
  • A Twisty Movement
  • 完整教程:iOS 混淆与反调试反 Hook 实战,运行时防护、注入检测与安全加固流程
  • Attention进阶史(MHA, MQA, GQA, MLA)
  • 2025北京个性旅行自由行口碑推荐北京汇通清源国际旅游公司,满足独特需求,自由随心
  • 2025推拉门品牌推荐榜:聚焦玻璃推拉门,钛镁合金推拉门选择指南
  • 9-27
  • 图解KV Cache
  • [K230学习笔记 00] 前言