文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

如何使用bind设置DNS服务器

2024-12-24 18:31

关注

Domain Name System,我们更通常称为 DNS 的系统,可以将域名翻译或转换为与该域关联的 IP 地址。DNS 是能够让你通过名称找到自己喜欢的网站而不是在浏览器中输入 IP 地址的原因。本指南将向你展示如何配置一个主 DNS 系统以及客户端。

以下是本文示例中使用的系统细节:

  1. dns01.fedora.local 192.168.1.160)- DNS 服务器
  2. client.fedora.local 192.168.1.136)- 客户端

DNS 服务器配置

使用 sudo 安装 bind 包:

  1. $ sudo dnf install bind bind-utils -y

bind 包提供了 /etc/named.conf 配置文件,来供你配置 DNS 服务器。

编辑 /etc/named.conf 文件:

  1. sudo vi /etc/named.conf

查找以下行:

  1. listen-on port 53 { 127.0.0.1; };

添加主 DNS 服务器的 IP 地址,如下所示:

  1. listen-on port 53 { 127.0.0.1; 192.168.1.160; };

查找以下行:

  1. allow-query { localhost; };

添加本地网络范围。该示例系统使用的 IP 地址在 192.168.1.X 的范围内。指定如下:

  1. allow-query { localhost; 192.168.1.0/24; };

指定转发和反向区域。区域文件Zone file就是具有系统上 DNS 信息(例如 IP 地址和主机名)的文本文件。转发区域文件forward zone file使得将主机名转换为 IP 地址成为可能。反向区域文件reverse zone file则相反。它允许远程系统将 IP 地址转换为主机名。

/etc/named.conf 文件的底部查找以下行:

  1. include "/etc/named.rfc1912.zones";

在此处,你将在该行的正上方指定区域文件信息,如下所示:

  1. zone "dns01.fedora.local" IN {
  2. type master;
  3. file "forward.fedora.local";
  4. allow-update { none; };
  5. };
  6.  
  7. zone "1.168.192.in-addr.arpa" IN {
  8. type master;
  9. file "reverse.fedora.local";
  10. allow-update { none; };
  11. };

forward.fedora.localreverse.fedora.local 文件是要创建的区域文件的名称。它们可以是任意名字。

保存并退出。

创建区域文件

创建你在 /etc/named.conf 文件中指定的转发和反向区域文件:

  1. $ sudo vi /var/named/forward.fedora.local

添加以下行:

  1. $TTL 86400
  2. @ IN SOA dns01.fedora.local. root.fedora.local. (
  3. 2011071001 ;Serial
  4. 3600 ;Refresh
  5. 1800 ;Retry
  6. 604800 ;Expire
  7. 86400 ;Minimum TTL
  8. )
  9. @ IN NS dns01.fedora.local.
  10. @ IN A 192.168.1.160
  11. dns01 IN A 192.168.1.160
  12. client IN A 192.168.1.136

所有粗体(LCTT 译注:本译文中无法呈现粗体)内容都特定于你的环境。保存文件并退出。接下来,编辑 reverse.fedora.local 文件:

  1. $ sudo vi /var/named/reverse.fedora.local

添加以下行:

  1. $TTL 86400
  2. @ IN SOA dns01.fedora.local. root.fedora.local. (
  3. 2011071001 ;Serial
  4. 3600 ;Refresh
  5. 1800 ;Retry
  6. 604800 ;Expire
  7. 86400 ;Minimum TTL
  8. )
  9. @ IN NS dns01.fedora.local.
  10. @ IN PTR fedora.local.
  11. dns01 IN A 192.168.1.160
  12. client IN A 192.168.1.136
  13. 160 IN PTR dns01.fedora.local.
  14. 136 IN PTR client.fedora.local.

所有粗体(LCTT 译注:本译文中无法呈现粗体)内容都特定于你的环境。保存文件并退出。

你还需要配置 SELinux 并为配置文件添加正确的所有权。

  1. sudo chgrp named -R /var/named
  2. sudo chown -v root:named /etc/named.conf
  3. sudo restorecon -rv /var/named
  4. sudo restorecon /etc/named.conf

配置防火墙:

  1. sudo firewall-cmd --add-service=dns --perm
  2. sudo firewall-cmd --reload

检查配置是否存在语法错误

  1. sudo named-checkconf /etc/named.conf

如果没有输出或返回错误,那么你的配置有效。

检查转发和反向区域文件。

  1. $ sudo named-checkzone forward.fedora.local /var/named/forward.fedora.local
  2.  
  3. $ sudo named-checkzone reverse.fedora.local /var/named/reverse.fedora.local

你应该看到 “OK” 的响应:

  1. zone forward.fedora.local/IN: loaded serial 2011071001
  2. OK
  3.  
  4. zone reverse.fedora.local/IN: loaded serial 2011071001
  5. OK

启用并启动 DNS 服务

  1. $ sudo systemctl enable named
  2. $ sudo systemctl start named

配置 resolv.conf 文件

编辑 /etc/resolv.conf 文件:

  1. $ sudo vi /etc/resolv.conf

查找你当前的 nameserver 行。在示例系统上,使用调制解调器/路由器充当名称服务器,因此当前看起来像这样:

  1. nameserver 192.168.1.1

这需要更改为主 DNS 服务器的 IP 地址:

  1. nameserver 192.168.1.160

保存更改并退出。

不幸的是需要注意一点。如果系统重启或网络重启,那么 NetworkManager 会覆盖 /etc/resolv.conf 文件。这意味着你将丢失所做的所有更改。

为了防止这种情况发生,请将 /etc/resolv.conf 设为不可变:

  1. $ sudo chattr +i /etc/resolv.conf

如果要重新设置,就需要允许其再次被覆盖:

  1. $ sudo chattr -i /etc/resolv.conf

测试 DNS 服务器

  1. $ dig fedoramagazine.org
  1. ; <<>> DiG 9.11.13-RedHat-9.11.13-2.fc30 <<>> fedoramagazine.org
  2. ;; global options: +cmd
  3. ;; Got answer:
  4. ;; ->>HEADER<<- opcode: QUERY, status: NOERROR, id: 8391
  5. ;; flags: qr rd ra; QUERY: 1, ANSWER: 1, AUTHORITY: 3, ADDITIONAL: 6
  6.  
  7. ;; OPT PSEUDOSECTION:
  8. ; EDNS: version: 0, flags:; udp: 4096
  9. ; COOKIE: c7350d07f8efaa1286c670ab5e13482d600f82274871195a (good)
  10. ;; QUESTION SECTION:
  11. ;fedoramagazine.org. IN A
  12.  
  13. ;; ANSWER SECTION:
  14. fedoramagazine.org. 50 IN A 35.197.52.145
  15.  
  16. ;; AUTHORITY SECTION:
  17. fedoramagazine.org. 86150 IN NS ns05.fedoraproject.org.
  18. fedoramagazine.org. 86150 IN NS ns02.fedoraproject.org.
  19. fedoramagazine.org. 86150 IN NS ns04.fedoraproject.org.
  20.  
  21. ;; ADDITIONAL SECTION:
  22. ns02.fedoraproject.org. 86150 IN A 152.19.134.139
  23. ns04.fedoraproject.org. 86150 IN A 209.132.181.17
  24. ns05.fedoraproject.org. 86150 IN A 85.236.55.10
  25. ns02.fedoraproject.org. 86150 IN AAAA 2610:28:3090:3001:dead:beef:cafe:fed5
  26. ns05.fedoraproject.org. 86150 IN AAAA 2001:4178:2:1269:dead:beef:cafe:fed5
  27.  
  28. ;; Query time: 830 msec
  29. ;; SERVER: 192.168.1.160#53(192.168.1.160)
  30. ;; WHEN: Mon Jan 06 08:46:05 CST 2020
  31. ;; MSG SIZE rcvd: 266

需要检查几件事以验证 DNS 服务器是否正常运行。显然,取得结果很重要,但这本身并不意味着 DNS 服务器实际上正常工作。

顶部的 QUERYANSWERAUTHORITY 字段应显示为非零,如我们的示例所示:

  1. ;; flags: qr rd ra; QUERY: 1, ANSWER: 1, AUTHORITY: 3, ADDITIONAL: 6

并且 SERVER 字段应有你的 DNS 服务器的 IP 地址:

  1. ;; SERVER: 192.168.1.160#53(192.168.1.160)

如果这是你第一次运行 dig 命令,请注意完成查询要花费 830 毫秒的时间:

  1. ;; Query time: 830 msec

如果再次运行它,查询将会更快:

  1. $ dig fedoramagazine.org
  1. ;; Query time: 0 msec
  2. ;; SERVER: 192.168.1.160#53(192.168.1.160)

客户端配置

客户端配置将简单得多。

安装 bind 程序:

  1. $ sudo dnf install bind-utils -y

编辑 /etc/resolv.conf 文件,并将主 DNS 配置为唯一的名称服务器:

  1. $ sudo vi /etc/resolv.conf

它看起来像这样:

  1. nameserver 192.168.1.160

保存更改并退出。然后,使 /etc/resolv.conf 文件不可变,防止其被覆盖并变回默认设置:

  1. $ sudo chattr +i /etc/resolv.conf

测试客户端

你应该获得与 DNS 服务器相同的结果:

  1. $ dig fedoramagazine.org
  1. ; <<>> DiG 9.11.13-RedHat-9.11.13-2.fc30 <<>> fedoramagazine.org
  2. ;; global options: +cmd
  3. ;; Got answer:
  4. ;; ->>HEADER<<- opcode: QUERY, status: NOERROR, id: 8391
  5. ;; flags: qr rd ra; QUERY: 1, ANSWER: 1, AUTHORITY: 3, ADDITIONAL: 6
  6.  
  7. ;; OPT PSEUDOSECTION:
  8. ; EDNS: version: 0, flags:; udp: 4096
  9. ; COOKIE: c7350d07f8efaa1286c670ab5e13482d600f82274871195a (good)
  10. ;; QUESTION SECTION:
  11. ;fedoramagazine.org. IN A
  12.  
  13. ;; ANSWER SECTION:
  14. fedoramagazine.org. 50 IN A 35.197.52.145
  15.  
  16. ;; AUTHORITY SECTION:
  17. fedoramagazine.org. 86150 IN NS ns05.fedoraproject.org.
  18. fedoramagazine.org. 86150 IN NS ns02.fedoraproject.org.
  19. fedoramagazine.org. 86150 IN NS ns04.fedoraproject.org.
  20.  
  21. ;; ADDITIONAL SECTION:
  22. ns02.fedoraproject.org. 86150 IN A 152.19.134.139
  23. ns04.fedoraproject.org. 86150 IN A 209.132.181.17
  24. ns05.fedoraproject.org. 86150 IN A 85.236.55.10
  25. ns02.fedoraproject.org. 86150 IN AAAA 2610:28:3090:3001:dead:beef:cafe:fed5
  26. ns05.fedoraproject.org. 86150 IN AAAA 2001:4178:2:1269:dead:beef:cafe:fed5
  27.  
  28. ;; Query time: 1 msec
  29. ;; SERVER: 192.168.1.160#53(192.168.1.160)
  30. ;; WHEN: Mon Jan 06 08:46:05 CST 2020
  31. ;; MSG SIZE rcvd: 266

确保 SERVER 输出的是你 DNS 服务器的 IP 地址。

你的 DNS 服务器设置完成了,现在所有来自客户端的请求都会经过你的 DNS 服务器了! 

 

来源:Linux中国内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     813人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     354人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     318人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     435人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     224人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-后端开发
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯