云网牛站
所在位置:首页 > Linux云服务器 > 在Linux操作系统中设置DNS服务器:配置主DNS系统和一个客户端

在Linux操作系统中设置DNS服务器:配置主DNS系统和一个客户端

2020-01-13 21:30:50作者:叶云稿源:云网牛站

本指南说明如何在Linux操作系统中配置主DNS系统和一个客户端,将使用bind来设置DNS服务器。

在Linux操作系统中设置DNS服务器:配置主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文件:

sudo vi /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; };

指定正向和反向区域,区域文件只是具有系统上DNS信息(例如IP地址和主机名)的文本文件,转发区域文件使将主机名转换为其IP地址成为可能,反向区域文件则相反,它允许远程系统将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文件中指定的正向和反向区域文件:

$ sudo vi /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

请根据自身的情况进行修改,保存文件并退出。接下来,编辑reverse.fedora.local文件:

$ sudo vi /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.

请根据自身的情况进行修改,保存文件并退出。

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

sudo chgrp named -R /var/named

sudo chown -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服务

$ sudo systemctl enable named

$ sudo systemctl start named

 

配置resolv.conf文件

编辑/etc/resolv.conf文件:

$ sudo vi /etc/resolv.conf

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

nameserver 192.168.1.1

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

nameserver 192.168.1.160

保存更改并退出。

不幸的是,有一个警告需要注意。如果系统重新启动或网络重新启动,则NetworkManager会覆盖/etc/resolv.conf文件,这意味着您将丢失所做的所有更改。

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

$ sudo chattr +i /etc/resolv.conf 

如果要重新设置并允许其再次覆盖:

$ sudo chattr -i /etc/resolv.conf

 

测试DNS服务器

$ dig fedoramagazine.org

; <<>> DiG 9.11.13-RedHat-9.11.13-2.fc30 <<>> fedoramagazine.org

;; global options: +cmd

;; Got answer:

;; ->>HEADER<<- opcode: QUERY, status: NOERROR, id: 8391

;; 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

;; Query time: 830 msec

;; SERVER: 192.168.1.160#53(192.168.1.160)

;; WHEN: Mon Jan 06 08: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毫秒的时间:

;; Query time: 830 msec

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

$ dig fedoramagazine.org 

;; Query time: 0 msec

;; SERVER: 192.168.1.160#53(192.168.1.160)

参考:dig命令_Linux dig命令使用详解:域名查询工具

 

客户端配置

客户端配置将简单得多。

安装bind实用程序:

$ sudo dnf install bind-utils -y

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

$ sudo vi /etc/resolv.conf

它应该是这样的:

nameserver 192.168.1.160

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

$ sudo chattr +i /etc/resolv.conf

 

测试客户端

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

$ dig fedoramagazine.org

; <<>> DiG 9.11.13-RedHat-9.11.13-2.fc30 <<>> fedoramagazine.org

;; global options: +cmd

;; Got answer:

;; ->>HEADER<<- opcode: QUERY, status: NOERROR, id: 8391

;; 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

;; Query time: 1 msec

;; SERVER: 192.168.1.160#53(192.168.1.160)

;; WHEN: Mon Jan 06 08:46:05 CST 2020

;; MSG SIZE  rcvd: 266

确保SERVER输出具有您的DNS服务器的IP地址。

DNS服务器现在可以使用了,来自客户端的所有请求现在都应该通过DNS服务器。

 

相关主题

在CentOS 8/RHEL 8上安装和配置主/从BIND DNS服务器

精选文章
热门文章