使用 bind 设置 DNS 服务器的方法
DNS(DomainNameServer,域名服务器)是进行域名(domainname)和与之相对应的IP地址(IPaddress)转换的服务器。
域名系统DomainNameSystem,我们更通常称为DNS的系统,可以将域名翻译或转换为与该域关联的IP地址。DNS是能够让你通过名称找到自己喜欢的网站而不是在浏览器中输入IP地址的原因。本指南将向你展示如何配置一个主DNS系统以及客户端。
以下是本文示例中使用的系统细节:
dns01.fedora.local(192.168.1.160)-主DNS服务器 client.fedora.local(192.168.1.136)-客户端
DNS服务器配置
使用sudo安装bind包:
$sudodnfinstallbindbind-utils-y
bind包提供了/etc/named.conf配置文件,来供你配置DNS服务器。
编辑/etc/named.conf文件:
sudovi/etc/named.conf
查找以下行:
listen-onport53{127.0.0.1;};
添加主DNS服务器的IP地址,如下所示:
listen-onport53{127.0.0.1;192.168.1.160;};
查找以下行:
allow-query{localhost;};
添加本地网络范围。该示例系统使用的IP地址在192.168.1.X的范围内。指定如下:
allow-query{localhost;192.168.1.0/24;};
指定转发和反向区域。区域文件Zonefile就是具有系统上DNS信息(例如IP地址和主机名)的文本文件。转发区域文件forwardzonefile使得将主机名转换为IP地址成为可能。反向区域文件reversezonefile则相反。它允许远程系统将IP地址转换为主机名。
在/etc/named.conf文件的底部查找以下行:
include"/etc/named.rfc1912.zones";
在此处,你将在该行的正上方指定区域文件信息,如下所示:
zone"dns01.fedora.local"IN{ typemaster; file"forward.fedora.local"; allow-update{none;}; }; zone"1.168.192.in-addr.arpa"IN{ typemaster; file"reverse.fedora.local"; allow-update{none;}; };
forward.fedora.local和reverse.fedora.local文件是要创建的区域文件的名称。它们可以是任意名字。
保存并退出。
创建区域文件
创建你在/etc/named.conf文件中指定的转发和反向区域文件:
$sudovi/var/named/forward.fedora.local
添加以下行:
$TTL86400 @INSOAdns01.fedora.local.root.fedora.local.( 2011071001;Serial 3600;Refresh 1800;Retry 604800;Expire 86400;MinimumTTL ) @INNSdns01.fedora.local. @INA192.168.1.160 dns01INA192.168.1.160 clientINA192.168.1.136
所有粗体(LCTT译注:本译文中无法呈现粗体)内容都特定于你的环境。保存文件并退出。接下来,编辑reverse.fedora.local文件:
$sudovi/var/named/reverse.fedora.local
添加以下行:
$TTL86400 @INSOAdns01.fedora.local.root.fedora.local.( 2011071001;Serial 3600;Refresh 1800;Retry 604800;Expire 86400;MinimumTTL ) @INNSdns01.fedora.local. @INPTRfedora.local. dns01INA192.168.1.160 clientINA192.168.1.136 160INPTRdns01.fedora.local. 136INPTRclient.fedora.local.
所有粗体(LCTT译注:本译文中无法呈现粗体)内容都特定于你的环境。保存文件并退出。
你还需要配置SELinux并为配置文件添加正确的所有权。
sudochgrpnamed-R/var/named sudochown-vroot:named/etc/named.conf sudorestorecon-rv/var/named sudorestorecon/etc/named.conf
配置防火墙:
sudofirewall-cmd--add-service=dns--perm sudofirewall-cmd--reload
检查配置是否存在语法错误
sudonamed-checkconf/etc/named.conf
如果没有输出或返回错误,那么你的配置有效。
检查转发和反向区域文件。
$sudonamed-checkzoneforward.fedora.local/var/named/forward.fedora.local $sudonamed-checkzonereverse.fedora.local/var/named/reverse.fedora.local
你应该看到“OK”的响应:
zoneforward.fedora.local/IN:loadedserial2011071001OKzonereverse.fedora.local/IN:loadedserial2011071001OK
启用并启动DNS服务
$sudosystemctlenablenamed $sudosystemctlstartnamed
配置resolv.conf文件
编辑/etc/resolv.conf文件:
$sudovi/etc/resolv.conf
查找你当前的nameserver行。在示例系统上,使用调制解调器/路由器充当名称服务器,因此当前看起来像这样:
nameserver192.168.1.1
这需要更改为主DNS服务器的IP地址:
nameserver192.168.1.160
保存更改并退出。
不幸的是需要注意一点。如果系统重启或网络重启,那么NetworkManager会覆盖/etc/resolv.conf文件。这意味着你将丢失所做的所有更改。
为了防止这种情况发生,请将/etc/resolv.conf设为不可变:
$sudochattr+i/etc/resolv.conf
如果要重新设置,就需要允许其再次被覆盖:
$sudochattr-i/etc/resolv.conf
测试DNS服务器
$digfedoramagazine.org ;<<>>DiG9.11.13-RedHat-9.11.13-2.fc30<<>>fedoramagazine.org ;;globaloptions:+cmd ;;Gotanswer: ;;->>HEADER<<-opcode:QUERY,status:NOERROR,id:8391 ;;flags:qrrdra;QUERY:1,ANSWER:1,AUTHORITY:3,ADDITIONAL:6 ;;OPTPSEUDOSECTION: ;EDNS:version:0,flags:;udp:4096 ;COOKIE:c7350d07f8efaa1286c670ab5e13482d600f82274871195a(good) ;;QUESTIONSECTION: ;fedoramagazine.org.INA ;;ANSWERSECTION: fedoramagazine.org.50INA35.197.52.145 ;;AUTHORITYSECTION: fedoramagazine.org.86150INNSns05.fedoraproject.org. fedoramagazine.org.86150INNSns02.fedoraproject.org. fedoramagazine.org.86150INNSns04.fedoraproject.org. ;;ADDITIONALSECTION: ns02.fedoraproject.org.86150INA152.19.134.139 ns04.fedoraproject.org.86150INA209.132.181.17 ns05.fedoraproject.org.86150INA85.236.55.10 ns02.fedoraproject.org.86150INAAAA2610:28:3090:3001:dead:beef:cafe:fed5 ns05.fedoraproject.org.86150INAAAA2001:4178:2:1269:dead:beef:cafe:fed5 ;;Querytime:830msec ;;SERVER:192.168.1.160#53(192.168.1.160) ;;WHEN:MonJan0608:46:05CST2020 ;;MSGSIZErcvd:266
需要检查几件事以验证DNS服务器是否正常运行。显然,取得结果很重要,但这本身并不意味着DNS服务器实际上正常工作。
顶部的QUERY、ANSWER和AUTHORITY字段应显示为非零,如我们的示例所示:
;;flags:qrrdra;QUERY:1,ANSWER:1,AUTHORITY:3,ADDITIONAL:6
并且SERVER字段应有你的DNS服务器的IP地址:
;;SERVER:192.168.1.160#53(192.168.1.160)
如果这是你第一次运行dig命令,请注意完成查询要花费830毫秒的时间:
;;Querytime:830msec
如果再次运行它,查询将会更快:
$digfedoramagazine.org ;;Querytime:0msec ;;SERVER:192.168.1.160#53(192.168.1.160)
客户端配置
客户端配置将简单得多。
安装bind程序:
$sudodnfinstallbind-utils-y
编辑/etc/resolv.conf文件,并将主DNS配置为唯一的名称服务器:
$sudovi/etc/resolv.conf
它看起来像这样:
nameserver192.168.1.160
保存更改并退出。然后,使/etc/resolv.conf文件不可变,防止其被覆盖并变回默认设置:
$sudochattr+i/etc/resolv.conf
测试客户端
你应该获得与DNS服务器相同的结果:
$digfedoramagazine.org ;<<>>DiG9.11.13-RedHat-9.11.13-2.fc30<<>>fedoramagazine.org ;;globaloptions:+cmd ;;Gotanswer: ;;->>HEADER<<-opcode:QUERY,status:NOERROR,id:8391 ;;flags:qrrdra;QUERY:1,ANSWER:1,AUTHORITY:3,ADDITIONAL:6 ;;OPTPSEUDOSECTION: ;EDNS:version:0,flags:;udp:4096 ;COOKIE:c7350d07f8efaa1286c670ab5e13482d600f82274871195a(good) ;;QUESTIONSECTION: ;fedoramagazine.org.INA ;;ANSWERSECTION: fedoramagazine.org.50INA35.197.52.145 ;;AUTHORITYSECTION: fedoramagazine.org.86150INNSns05.fedoraproject.org. fedoramagazine.org.86150INNSns02.fedoraproject.org. fedoramagazine.org.86150INNSns04.fedoraproject.org. ;;ADDITIONALSECTION: ns02.fedoraproject.org.86150INA152.19.134.139 ns04.fedoraproject.org.86150INA209.132.181.17 ns05.fedoraproject.org.86150INA85.236.55.10 ns02.fedoraproject.org.86150INAAAA2610:28:3090:3001:dead:beef:cafe:fed5 ns05.fedoraproject.org.86150INAAAA2001:4178:2:1269:dead:beef:cafe:fed5 ;;Querytime:1msec ;;SERVER:192.168.1.160#53(192.168.1.160) ;;WHEN:MonJan0608:46:05CST2020 ;;MSGSIZErcvd:266
确保SERVER输出的是你DNS服务器的IP地址。
你的DNS服务器设置完成了,现在所有来自客户端的请求都会经过你的DNS服务器了!
为什么要搭建一个简单的DNS服务器?
(1)当外网DNS崩溃,比如暴风门发生的那种情况,可以使用我们自己的DNS应急
(2)为内网网站提供内线的IP地址解析,或者实现双线解析
(3)当你的ISP限制了二级域名和高级管理特性,你需要自己搭建DNS服务器来满足自己的需要
(4)避免DNS劫持
(5)和别的解决方案集成
总结
到此这篇关于使用bind设置DNS服务器的文章就介绍到这了,更多相关binddns服务器内容请搜索毛票票以前的文章或继续浏览下面的相关文章希望大家以后多多支持毛票票!