Loading [MathJax]/jax/output/CommonHTML/config.js
前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >专栏 >如何使用 bind 设置 DNS 服务器

如何使用 bind 设置 DNS 服务器

原创
作者头像
用户1685462
修改于 2021-09-13 03:35:51
修改于 2021-09-13 03:35:51
4.7K00
代码可运行
举报
文章被收录于专栏:网站教程网站教程
运行总次数:0
代码可运行

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

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

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
dns01.fedora.local    (192.168.1.160-DNS 服务器client.fedora.local     (192.168.1.136- 客户端

DNS 服务器配置

使用 sudo 安装 bind 包:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
$ sudo dnf install bind bind-utils -y

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

编辑 /etc/named.conf 文件:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
sudo vi /etc/named.conf

查找以下行:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
listen-on port 53 { 127.0.0.1; };

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

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
listen-on port 53 { 127.0.0.1; 192.168.1.160; };

查找以下行:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
allow-query  { localhost; };

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

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
allow-query  { localhost; 192.168.1.0/24; };

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

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

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
include "/etc/named.rfc1912.zones";

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

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
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.localreverse.fedora.local 文件是要创建的区域文件的名称。它们可以是任意名字。

保存并退出。

创建区域文件

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

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
$ sudo vi /var/named/forward.fedora.local

添加以下行:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
$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.160dns01           IN  A   192.168.1.160client          IN  A   192.168.1.136

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

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
$ sudo vi /var/named/reverse.fedora.local

添加以下行:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
$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.160client          IN  A   192.168.1.136160     IN  PTR         dns01.fedora.local.136     IN  PTR         client.fedora.local.

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

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

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
sudo chgrp named -R /var/namedsudo chown -v root:named /etc/named.confsudo restorecon -rv /var/namedsudo restorecon /etc/named.conf

配置防火墙

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
sudo firewall-cmd --add-service=dns --permsudo firewall-cmd --reload
检查配置是否存在语法错误
代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
sudo named-checkconf /etc/named.conf

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

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

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
$ sudo named-checkzone forward.fedora.local /var/named/forward.fedora.local$ sudo named-checkzone reverse.fedora.local /var/named/reverse.fedora.local

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

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
zone forward.fedora.local/IN: loaded serial 2011071001OKzone reverse.fedora.local/IN: loaded serial 2011071001OK
启用并启动 DNS 服务
代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
$ sudo systemctl enable named$ sudo systemctl start named
配置 resolv.conf 文件

编辑 /etc/resolv.conf 文件:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
$ sudo vi /etc/resolv.conf

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

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
nameserver 192.168.1.1

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

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
nameserver 192.168.1.160

保存更改并退出。

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

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

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
$ sudo chattr +i /etc/resolv.conf

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

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
$ sudo chattr -i /etc/resolv.conf
测试 DNS 服务器
代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
$ dig fedoramagazine.org
代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
; <<>> 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 服务器实际上正常工作。

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

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
;; flags: qr rd ra; QUERY: 1, ANSWER: 1, AUTHORITY: 3, ADDITIONAL: 6

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

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
;; SERVER: 192.168.1.160#53(192.168.1.160)

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

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
;; Query time: 830 msec

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

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
$ dig fedoramagazine.org
代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
;; Query time: 0 msec;; SERVER: 192.168.1.160#53(192.168.1.160)

客户端配置

客户端配置将简单得多。

安装 bind 程序:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
$ sudo dnf install bind-utils -y

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

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
$ sudo vi /etc/resolv.conf

它看起来像这样:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
nameserver 192.168.1.160

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

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
$ sudo chattr +i /etc/resolv.conf
测试客户端

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

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
$ dig fedoramagazine.org
代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
; <<>> 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 服务器了!

原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。

如有侵权,请联系 cloudcommunity@tencent.com 删除。

原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。

如有侵权,请联系 cloudcommunity@tencent.com 删除。

评论
登录后参与评论
暂无评论
推荐阅读
编辑精选文章
换一批
CentOS 7.x下配置DNS服务基础入门知识
  bind:开源、稳定、应用广泛的DNS服务。bind的软件包名bind,服务名称named.
星哥玩云
2022/07/25
8300
DNS:使用 bind9 配置主从权威DNS服务器
对每个人而言,真正的职责只有一个:找到自我。然后在心中坚守其一生,全心全意,永不停息。所有其它的路都是不完整的,是人的逃避方式,是对大众理想的懦弱回归,是随波逐流,是对内心的恐惧 ——赫尔曼·黑塞《德米安》
山河已无恙
2023/08/21
7830
DNS:使用 bind9 配置主从权威DNS服务器
DNS:使用 Bind 9 配置权威 DNS 服务器
我承认爱情是空幻的,只有情感才是真实的,是情感在促使我们去追求,使我们产生爱情的真正的美 ----卢梭《爱弥儿》
山河已无恙
2023/08/21
3.2K0
DNS:使用 Bind 9 配置权威 DNS 服务器
DNS服务器配置和测试
两台服务器分别为:172.20.0.140和172.20.0.130,用yum install bind安装DNS服务。
全栈程序员站长
2022/08/29
4.6K0
CentOS下源码安装Bind 9.6.1搭建DNS服务器
一.下载最新的Bind发行版:  ①.在根目录下创建一个名为software的文件夹并进入这个文件夹(此文件夹是为了放置下载的源码包和解压的文件):  mkdir /software  cd /software ②.下载bind.9.6.1的软件包:  wget ftp://ftp.isc.org/isc/bind9/9.6.1/bind-9.6.1.tar.gz
星哥玩云
2022/07/01
1.5K0
CentOS7上使用bind9搭建DNS主从服务器
   Linux中通常使用bind来实现DNS服务器的架设,bind软件由isc(https://www.isc.org/downloads/bind/)维护。在yum仓库中可以找到软件,配置好yum源,直接使用命令yum install bind就可以安装。当前bind的稳定版本为bind9,bind的服务名称为named,监听的端口为53号端口。bind的主要配置文件为/etc/named.conf,此文件主要用于配置区域,并指定区域数据库文件名称。区域数据库文件通常保存于/var/named/目录下,用于定义区域的资源类型。
三杯水Plus
2018/11/14
4.8K0
Linux下搭建主从DNS服务器并实现智能解析
组织域:.com, .net, .org, .gov, .edu, .mil 国家域:.iq, .tw, .hk, .jp, .cn, ...
星哥玩云
2022/07/25
13.9K0
Linux下搭建主从DNS服务器并实现智能解析
DNS(bind)服务器的安装与配置
  DNS 是计算机域名系统 (Domain Name System 或Domain Name Service) 的缩写,域名服务器是进行域名(domain name)和与之相对应的IP地址 (IP address)转换的服务器。DNS中保存了一张域名(domain name)和与之相对应的IP地址 (IP address)的表,以解析消息的域名。 域名是Internet上某一台计算机或计算机组的名称,用于在数据传输时标识计算机的电子方位(有时也指地理位置)。域名是由一串用点分隔的名字组成的,通常包含组织名,而且始终包括两到三个字母的后缀,以指明组织的类型或该域所在的国家或地   基本工作流程
菲宇
2019/06/12
11.9K0
DNS(bind)服务器的安装与配置
Linux运维bind9-DNS概述入门
DNS(Domain Name System,域名系统),因特网上作为域名和IP地址相互映射的一个分布式数据库,能够使用户更方便的访问互联网,而不用去记住能够被机器直接读取的IP数串。通过主机名,最终得到该主机名对应的IP地址的过程叫做域名解析(或主机名解析)。DNS协议运行在UDP协议之上,使用端口号53。 DNS 的分布式数据库是以域名为索引的,每个域名实际上就是一棵很大的逆向树中路径,这棵逆向树称为域名空间(domain name space)。如图所示树的最大深度不得超过127 层,树中每个节点都有一个可以长达63 个字符的文本标号。
王先森sec
2023/04/24
1.8K0
Linux运维bind9-DNS概述入门
Linux部署DNS服务器
DNS(Domain Name System–域名系统),是因特网的一项服务。它作为将域名和IP地址相互映射的一个分布式数据库,能够使人更方便地访问互联网。是一个应用层的协议DNS使用TCP和UDP端口53。 DNS是一个分布式数据库,命名系统采用层次的逻辑结构,如同一颗倒置的树,这个逻辑的树形结构称为域名空间,由于DNS划分了域名空间,所以各机构可以使用自己的域名空间创建DNS信息. DNS(Domain Name Service) 域名解析服务,就是将域名和 ip 之间做相应的转换,利用 TCP 和 UDP 的53号端口。DNS默认端口是53的TCP和UPD,UDP是供用户查询的,主从复制用TCP和UDP的53端口都用。
黑白天安全
2020/07/23
25K0
Linux部署DNS服务器
bind实现智能DNS(ACL,view
   在实现了DNS主从同步,子域授权之后,还可以针对不同网络内的域名解析请求DNS能够指向不同的主机地址,以实现分流。
py3study
2020/01/10
3.2K0
Linux下DNS简单部署(主从域名服务器)
一、DNS简介 DNS(Domain Name System),域名系统,因特网上作为域名和IP地址相互映射的一个分布式数据库,能够使用户更方便的访问互联网,而不用去记住能够被机器直接读取的IP数串。通过主机名,最终得到该主机名对应的IP地址的过程叫做域名解析(或主机名解析)。DNS协议运行在UDP协议之上,使用端口号53。DNS服务器的作用就是就好比生活中的电话簿、114查号台一样,为各种网络程序找到对应目标主机的IP地址或对应的主机域名。 二、DNS功能 每个IP地址都可以有一个主机名,主机名由一个或多
洗尽了浮华
2018/01/23
7.6K1
DNS主从同步及正反向区域解析
环境说明: 主DNS:Centos 6.9, IP:192.168.1.19 从DNS:Centos 7.3, IP:192.168.1.20 开始前的准备工作 关闭防火墙和SELinxu [root@Centos6 ~]# chkconfig iptables off #对于Centos 6 [root@centos7 ~]# systemctl disable firewalld #对于Centos 7 [root@Centos6 ~]# sed -i.bak 's@SELINUX=enforcin
用户1456517
2019/03/05
8.3K0
[Centos7]安装及配置bind(DNS服务)
本文编写于 205 天前,最后修改于 205 天前,其中某些信息可能已经过时。 1.环境 内网IP:192.168.3.8 系统:Centos7 2.安装 yum -y install bind* 3.修改bind配置文件 vi /etc/named.conf options { listen-on port 53 { 127.0.0.1; any; }; #监听任何ip对53端口的请求 allow-query { localhost; any; }; #接收任何
贰叁壹小窝
2020/07/22
2.9K0
内建DNS服务器--BIND
参考 BIND 官网:http://www.isc.org/downloads/bind/ 1、系统环境说明 [root@clsn6 ~]# cat /etc/redhat-release CentOS release 6.9 (Final) [root@clsn6 ~]# uname -r 2.6.32-696.el6.x86_64 [root@clsn6 ~]# sestatus SELinux status: disabled [root@clsn6 ~]# /e
惨绿少年
2018/03/30
2.6K0
DNS原理和CentOS7上bind域名服务器配置详解
1、什么是DNS? ( Domain Name System)是“域名系统”的英文缩写,是一种组织成域层次结构的计算机和网络服务命名系统,它用于TCP/IP网络,它所提供的服务是用来将主机名和域名转换为IP地址的工作。DNS就是这样的一位“翻译官”,它的基本工作原理可用下图来表示。
kirin
2020/09/07
3.4K0
DNS原理和CentOS7上bind域名服务器配置详解
bind杂记(3)
[root@www named]# dig -t NS ops.zz.com @10.201.106.129 +norecurse
py3study
2020/01/10
3.3K0
CentOS7配置DNS服务器--配置bind服务器
安装 BIND 软件包 1. 安装 2. 配置 下面的例子是以公网IP(172.16.0.80/29),局域网IP(192.168.0.0/24),域名(wscon.cn)作说明。在配置你自己的服务器时,请使用你自己的IP和域名。 # vim /etc/named.conf options { directory "/var/named"; # query range allow-query { localhost; 192.168.0.0/24; }; # transfer range allow-tra
孤鸿
2022/09/23
4.5K0
Ubuntu下DNS服务搭建
DNS(domain name system 域名系统):基于C/S模式的域名解析服务,监听在53/udp,53/tcp端口,其中tcp用来区域传送,udp用来解析,其实是一个数据库,用于TCP/IP程序的分布式数据库,同时也是一种重要的网络协议,DNS储存了网络中的IP地址与对应主机的信息,邮件路由信息,还有其他网络应用方面的信息,它所提供的服务是用来将主机名和域名转换为IP,就像一个翻译官
dogfei
2020/07/31
2.4K0
DNS安装与设置(3)
    DNS版本:version: 9.8.2rc1-RedHat-9.8.2-0.30.rc1.el6
py3study
2020/01/13
3.2K0
相关推荐
CentOS 7.x下配置DNS服务基础入门知识
更多 >
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档
本文部分代码块支持一键运行,欢迎体验
本文部分代码块支持一键运行,欢迎体验