首页 资讯频道 互联频道 智能频道 网络 数据频道 安全频道 服务器频道 存储频道

使用指南:如何利用 bind 设置 DNS 服务器

2020-03-16 14:17:35 来源 : Linux中国

域名系统

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

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

dns01.fedora.local(192.168.1.160)-主 DNS 服务器

client.fedora.local(192.168.1.136)-客户端

DNS 服务器配置

使用sudo安装 bind 包:

$ sudo dnf install bind bind-utils -y

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

编辑/etc/named.conf文件:

sudovi/etc/named.conf

查找以下行:

listen-on port 53{127.0.0.1;};

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

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

查找以下行:

allow-query { localhost;};

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

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

指定转发和反向区域。区域文件

Zone file

就是具有系统上 DNS 信息(例如 IP 地址和主机名)的文本文件。转发区域文件

forward zone file

使得将主机名转换为 IP 地址成为可能。反向区域文件

reverse zone file

则相反。它允许远程系统将 IP 地址转换为主机名。

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

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

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

zone "dns01.fedora.local" IN {

type master;

file"forward.fedora.local";

allow-update { none;};

};

zone "1.168.192.in-addr.arpa" IN {

type master;

file"reverse.fedora.local";

allow-update { none;};

};

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

保存并退出。

创建区域文件

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

$ sudovi/var/named/forward.fedora.local

添加以下行:

$TTL 86400

@ IN SOA dns01.fedora.local. root.fedora.local.(

2011071001;Serial

3600;Refresh

1800;Retry

604800;Expire

86400;Minimum TTL

)

@ IN NS dns01.fedora.local.

@ IN A 192.168.1.160

dns01 IN A 192.168.1.160

client IN A 192.168.1.136

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

$ sudovi/var/named/reverse.fedora.local

添加以下行:

$TTL 86400

@ IN SOA dns01.fedora.local. root.fedora.local.(

2011071001;Serial

3600;Refresh

1800;Retry

604800;Expire

86400;Minimum TTL

)

@ IN NS dns01.fedora.local.

@ IN PTR fedora.local.

dns01 IN A 192.168.1.160

client IN A 192.168.1.136

160 IN PTR dns01.fedora.local.

136 IN PTR client.fedora.local.

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

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

sudochgrp named -R /var/named

sudochown-v root:named /etc/named.conf

sudo restorecon -rv /var/named

sudo restorecon /etc/named.conf

配置防火墙:

sudo firewall-cmd --add-service=dns --perm

sudo firewall-cmd --reload

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

sudo named-checkconf /etc/named.conf

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

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

$ sudo named-checkzone forward.fedora.local/var/named/forward.fedora.local

$ sudo named-checkzone reverse.fedora.local/var/named/reverse.fedora.local

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

zone forward.fedora.local/IN: loaded serial 2011071001

OK

zone reverse.fedora.local/IN: loaded serial 2011071001

OK

启用并启动 DNS 服务

$ sudosystemctl enable named

$ sudosystemctl start named

配置 resolv.conf 文件

编辑/etc/resolv.conf文件:

$ sudovi/etc/resolv.conf

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

nameserver 192.168.1.1

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

nameserver 192.168.1.160

保存更改并退出。

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

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

$ sudochattr+i /etc/resolv.conf

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

$ sudochattr-i /etc/resolv.conf

测试 DNS 服务器

$ dig fedoramagazine.org

;>DiG9.11.13-RedHat-9.11.13-2.fc30> fedoramagazine.org

;;global options:+cmd

;;Got answer:

;;->>HEADER

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

;; OPT PSEUDOSECTION:

; EDNS: version:0, flags:; udp:4096

; COOKIE: c7350d07f8efaa1286c670ab5e13482d600f82274871195a (good)

;; QUESTION SECTION:

;fedoramagazine.org. IN A

;; ANSWER SECTION:

fedoramagazine.org.50 IN A 35.197.52.145

;; AUTHORITY SECTION:

fedoramagazine.org.86150 IN NS ns05.fedoraproject.org.

fedoramagazine.org.86150 IN NS ns02.fedoraproject.org.

fedoramagazine.org.86150 IN NS ns04.fedoraproject.org.

;; ADDITIONAL SECTION:

ns02.fedoraproject.org.86150 IN A 152.19.134.139

ns04.fedoraproject.org.86150 IN A 209.132.181.17

ns05.fedoraproject.org.86150 IN A 85.236.55.10

ns02.fedoraproject.org.86150 IN AAAA 2610:28:3090:3001:dead:beef:cafe:fed5

ns05.fedoraproject.org.86150 IN AAAA 2001:4178:2:1269:dead:beef:cafe:fed5

;;Querytime:830 msec

;; SERVER:192.168.1.160#53(192.168.1.160)

;; WHEN:MonJan0608:46:05 CST 2020

;; MSG SIZE rcvd:266

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

顶部的QUERY、ANSWER和AUTHORITY字段应显示为非零,如我们的示例所示:

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

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

;; SERVER:192.168.1.160#53(192.168.1.160)

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

;;Querytime:830 msec

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

$ dig fedoramagazine.org

;;Querytime:0 msec

;; SERVER:192.168.1.160#53(192.168.1.160)

客户端配置

客户端配置将简单得多。

安装 bind 程序:

$ sudo dnf install bind-utils -y

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

相关文章

最近更新
详解什么是架构设计 2020-03-13 11:29:58