Linux

关注公众号 jb51net

关闭
首页 > 网站技巧 > 服务器 > Linux > Linux手动配置DNS

Linux云服务器手动配置DNS的方法步骤

作者:网硕互联的小客服

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

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

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

2. 手动配置 DNS 的方法

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

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

2.1 什么是 /etc/resolv.conf?

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

2.2 配置步骤

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

cat /etc/resolv.conf 

示例输出:

nameserver 8.8.8.8
nameserver 8.8.4.4

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

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

sudo nano /etc/resolv.conf

或:

sudo vi /etc/resolv.conf 

添加或修改 DNS 服务器地址
替换或添加以下内容:

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

保存文件

测试 DNS 是否正常工作
使用 pingnslookup 测试域名解析:

ping google.com
nslookup google.com

2.3 注意事项

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

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

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

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

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

添加或修改以下内容:

DNS1=8.8.8.8
DNS2=8.8.4.4

重启网络服务

sudo systemctl restart NetworkManager 

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

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

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

systemctl status systemd-resolved

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

sudo systemctl start systemd-resolved

修改 DNS 配置
使用以下命令设置 DNS 服务器:

sudo systemd-resolve --set-dns=8.8.8.8 --interface=eth0
sudo systemd-resolve --set-dns=8.8.4.4 --interface=eth0

持久化配置
编辑 /etc/systemd/resolved.conf 文件:

sudo nano /etc/systemd/resolved.conf 

修改或添加以下内容:

[Resolve]
DNS=8.8.8.8 8.8.4.4

重启服务

sudo systemctl restart systemd-resolved

验证 DNS
查看当前的 DNS 配置:

systemd-resolve --status 

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

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

3.1 安装 dnsmasq

安装 dnsmasq:

sudo apt install dnsmasq -y      # Ubuntu/Debian
sudo yum install dnsmasq -y      # CentOS

配置 dnsmasq:
编辑配置文件:

sudo nano /etc/dnsmasq.conf 

添加以下内容:

listen-address=127.0.0.1
server=8.8.8.8
server=8.8.4.4

启动并启用服务:

sudo systemctl start dnsmasq
sudo systemctl enable dnsmasq

设置本地 DNS:
修改 /etc/resolv.conf 文件,添加以下内容:

nameserver 127.0.0.1 

4. 测试和验证 DNS 配置

4.1 测试域名解析

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

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

4.2 检查当前 DNS 服务器

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

cat /etc/resolv.conf 

如果使用 systemd-resolved,运行:

systemd-resolve --status 

5. 常见问题及解决方法

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

原因:

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

解决方法:

禁止自动覆盖:

sudo chattr +i /etc/resolv.conf 

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

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

5.2 DNS 解析速度慢

原因:

解决方法:

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

5.3 无法解析域名

原因:

解决方法:

  1. 检查 DNS 配置是否正确。
  2. 确保防火墙允许 UDP 53 端口:
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 服务,实现快速、稳定的域名解析。

以上就是Linux云服务器手动配置DNS的方法步骤的详细内容,更多关于Linux手动配置DNS的资料请关注脚本之家其它相关文章!

您可能感兴趣的文章:
阅读全文