目录
前言
DNS(域名解析系统)作为互联网基础设施的核心组件,承担着将易记的域名转换为机器可识别的 IP地址的关键任务。其正向解析(域名到 IP)与反向解析(IP 到域名)功能,极大简化了网络资源的访问与管理。通过 BIND,管理员可构建缓存域名服务器以加速査询、主域名服务器以自主管理区域数据,以及从域名服务器实现数据冗余与负载均衡。
一. BIND域名服务基础
第一层 顶级域 第二层 二级域 依次往下类推 分别是三级四级五级
1.DNS系统的作用及类型
整个 Internet 大家庭中连接了数以亿计的服务器、个人主机,其中大部分的网站、邮件等服务器都使用了域名形式的地址,如 www.google.com、mai1.163.com 等。这种地址形式要比使用64.233.189.147、202.108.33.74 的 IP 地址形式更加直观,且更容易被用户记住。
DNS 系统在网络中的作用就是维护一个地址数据库,其中记录了各种主机域名与 IP 地址的对应关系,以便为客户程序提供正向或反向的地址查询服务,即正向解析与反向解析。
正向解析 | 据域名查 IP 地址,即将指定的域名解析为相对应的 IP 地址。域名的正向解析是DNS 服务器最基本的功能,也是最常用的功能。 |
反向解析 | 根据 IP地址查域名,即将指定的 IP 地址解析为相对应的域名。域名的反向解析不是很常用,只在一些特殊场合才会用到,比如可用于反垃圾邮件的验证。 |
实际上,每一台 DNS 服务器都只负责管理一个有限范围(一个或几个域)内的主机域名和 IP地址的对应关系,这些特定的 DNS 域或 IP地址段称为 zone(区域)。根据地址解析的方向不同,DNS 区域相应地分为正向区域(包含域名到IP 地址的解析记录)和反向区域(包含 IP 地址到域名的解析记录)。
根据所管理的区域地址数据的来源不同,DNS 系统可以分为不同的类型。在同一台 DNS服务器中,相对于不同的区域来说,也拥有不同的身份。
DNS常见的类型
缓存域名服务器 | 只提供域名解析结果的缓存功能,目的在于提高查询速度和效率,但是没有自己控制的区域地址数据。构建缓存域名服务器时,必须设置根域或指定其他 DNS 服务器作为解析来源。 |
主域名服务器 | 维护某一个特定 DNS 区域的地址数据库,对其中的解析记录具有自主控制权,是指定区域中唯一存在的权威服务器、官方服务器。构建主域名服务器时,需要自行建立所负责区域的地址数据文件。 |
从域名服务器 | 与主域名服务器提供完全相同的 DNS 解析服务,通常用于 DNS 服务器的热备份。对客户机来说,无论使用主域名服务器还是从域名服务器,查询的结果都是一样的。关键区别在于,从域名服务器提供的解析结果不是由自己决定的,而是来自于主域名服务器。构建从域名服务器时,需要指定主域名服务器的位置,以便服务器能自动同步区域的地址数据库。 |
主、从服务器的角色只是针对某一个特定的 DNS 区域来说的。例如,同一台 DNS 服务器可以是“.chinaunix.net”区域的主域名服务器,同时也可以是“.cublog.cn”区域的从域名服务器。
2. DNS查询类型
递归查询 | 客户端要求DNS服务器必须返回最终结果(如用户设备->递归DNS服务器) |
迭代查询 | DNS服务器按层级逐步查询(如递归服务器->根/TLD/权威服务器) |
3. DNS记录类型
- A记录:域名->ipv4地址
- AAAA记录:域名->ipv6
- CNAME记录:域名别名(如www.baidu.com->baidu.com)
- MX记录:邮件服务器地址
- NS记录:指定域名的权威DNS服务器
二. BIND 的安装和控制
BIND 不是唯一能够提供域名服务的 DNS 服务程序,但它却是应用最为广泛的,BIND 可以运行在大多数 Linux/UNIX 主机中。其官方站点位于 https://www.isc.org/。
1. 安装 BIND 软件
在 openEuler 系统中,系统光盘自带了 BIND 服务的安装文件,主要包括以下几个软件包
- bind-9.18.21-3.oe2403sp1.x86 64.rpm
- bind-utils-9.18.21-3.oe2403sp1.x86 64.rpm
- bind-libs-9.18.21-3.oe2403sp1.x86 64.rpm
- bind-chroot-9.18.21-3.oe2403sp1.x86 64.rpm
各软件包的主要作用
- bind:提供了域名服务的主要程序及相关文件。
- bind-utils:提供了对 DNS 服务器的测试工具程序,如 nslookup 等。
- bind-libs:提供了 bind、bind-utils 需要使用的库函数。
- bind-chroot:为 BIND 服务提供一个伪装的根目录(将/var/named/chroot/文件夹作为 BIND 服务的根目录),以提高安全性。
使用 dnf 安装 bind 服务
[root@localhost~]# dnf -y install bind bind-utils bind-libs bind-chroot
2. BIND服务的配置文件
使用 BIND 软件构建域名服务时,主要涉及两种类型的配置文件:主配置文件和区域数据文件。
主配置文件 | 用于设置 named 服务的全局选项、注册区域及访问控制等各种运行参数 |
区域数据文件 | 用于存放某个 DNS 区域的地址解析记录(正向记录或反向记录) |
2.1 主配置文件
主配置文件 named.conf 通常位于/etc/目录下,在 named.conf 文件中,主要包括全局配置、区域配置两个部分,每一条配置记录的行尾以分号“:”表示结束,以“#”号或“//”开始的部分表示注释文字(大段注释可以使用“/*…… */”的格式)。
(1) 全局配置部分
全局配置参数包括在形如“options{};”的大括号中,如可以设置监听的地址和端口、区域数据文件存放的目录、允许哪些客户机查询等。
上述配置内容中,除了 directory 配置项通常会保留以外,其他的配置项都可以省略。若不指定listen-on 配置项,则 named 默认在所有接口的 UDP 53 端口监听服务;若不指定 allow-query 配置项,则默认会响应所有客户机的查询请求。
(2) 区域配置部分
区域配置参数使用“zone …… {};”的配置格式,一台 DNS 服务器可以为多个区域提供解析,因此在 named.conf 文件中也可以有多个 zone 配置段。区域类型按照解析方向可分为正向区域、反向区域。
需要注意的地方
- 每个 zone 区域都是可选的(包括根域、回环域、反向域),具体根据实际需要而定,zone 配置部分的“IN”关键字也可以省略。
- 反向区域的名称由倒序的网络地址和“.in-addr.arpa”组合而成。例如,对于 192.168.10.0/24网段,其反向区域名称表示为“10.168.192.in-addr.arpa”。
- file 配置项用于指定实际的区域数据文件,文件名称由管理员自行设置。区域配置中的部分参数(如 allow-transfer)也可以放在全局配置中。
修改完主配置文件以后,可以执行“named-checkconf”命令对 named.conf 文件进行语法检査。如果文件中没有语法错误,该命令将不给出任何提示;反之,则会给出相应的提示信息,然后根据出错提示修正文件中的错误即可。带“-z”选项的“named-checkconf”命令还可以尝试加载主配置文件中对应的区域数据库文件,并检查该文件是否存在问题。
2.2 区域数据配置文件
区域数据配置文件通常位于/var/named/日录下,每个区域数据文件对应一个 DNS 解析区域,文件名及内容由该域的管理员自行设置。
根域“.”的区域数据文件比较特殊。Internet 中所有的 DNS 服务器都使用同一份根区域数据文件,其中列出了所有根服务器的域名和 IP 地址。根区域数据文件可以从国际互联网络信息中心(InterNIC)的官方网站地址 http://www.internic.net/下载。
在区域数据文件中,主要包括 TTL(Time To Live,生存时间)配置项、S0A(Start Of Authority,授权信息开始)记录、地址解析记录。文件中的注释信息以“;”(分号)开始。
(1) TTL 配置及 SOA 记录部分
第一行的 TTL配置用于设置默认生存周期,即缓存解析结果的有效时间。SOA 记录部分用于设置区域名称、管理邮箱,以及为从域名服务指定更新参数。
上述配置内容中,时间单位默认为秒(s),也可以使用 M(分)、H(时)、W(周)、D(天)等单位。文件中的“@”符号表示当前的 DNS 区域名,相当于“benet.com.”或“admin.benet.com.”,表示域管理员的电子邮箱地址(由于“@”符号已有其他含义,因此将电子邮件地址中的“@”用“.”代替)S0A 记录中的更新序列号用来同步主、从服务器的区域数据,当从服务器判断区域更新时,若发现主服务器中的序列号与本地区域数据中的序列号相同,则不会进行下载。
(2) 地址解析记录部分
地址解析记录用来设置 DNS 区域内的域名、IP地址映射关系,包括正向解析记录和反向解析记录反向解析记录只能用在反向区域数据文件中。
四种常见的地址解析记录
NS(Name Server,域名服务器) | 记录当前区域的 DNS 服务器的主机地址 |
MX(Mail Exchange,邮件交换) | 记录当前区域的邮件服务器的主机地址,数字 10 表示(当有多个 MX 记录时)选择邮件服务器的优先级,数字越大,优先级越低。 |
A(Address,地址) | 录正向解析条目。例如,“www IN A 192.168.10.200”表示域名 www.benet.com对应的 IP 地址是 192.168.10.200。 |
CNAME(Canonical Name,别名) | 记录某一个正向解析条目的其他名称。例如,“ftp IN CNAME www”表示域名 ftp.benet.com 是 www.benet.com 的别名。 |
其中,NS、MX 记录行首的“@”符号可以省略(默认继承 SOA 记录行首的@信息),但是必须保留-个空格或 Tab 制表符。
在反向区域数据文件中,不会用到 A 记录,而是使用 PTR 指针(Point)记录。
使用 PTR 记录时,第一列只需要指明对应 IP 地址的“主机地址”部分即可,如“102”或“101”等,系统在查找地址记录时会自动将当前反向域的网络地址作为前缀。
在区域数据配置文件中,凡是不以点号“.”结尾的主机地址,系统在查找地址记录时都会自动将当前的域名作为后缀。例如,若当前的 DNS 域为“benet.com”,则在文件中的主机地址“www”相当于
“www.benet.com. ”。因此,当使用完整的 FQDN(Fully Qualified Domain Name,完全合格域名/全称域名)地址时,务必记得地址末尾的点号“.”不能省略。
当一台服务器需要同时承载某个 DNS 区域内的许多个不同的域名(如 IDC 的虚拟主机服务器、提供个人主页空间的网站服务器等)时,可以在区域数据文件的最后一行添加泛域名解析记录,即使用“*”以匹配任意主机名。
三. 使用BIND构建域名服务器
1. 构建缓存域名服务器
缓存域名服务器通常架设在公司的局域网内,主要目的是提高域名解析的速度,减少对互联网访问的出口流量。
BIND 构建缓存域名服务器的基本步骤
想要缓存域名生效要把最后两行的命令注释掉
开启服务
客户端配置
重启网卡
验证 用nslookup命令
虚拟机里面做千万千万要关闭防火墙 不然验证结果会出不来
2. 构建主域名服务器
主域名服务器通常架设在 Internet 环境中,提供某一个域或某几个域内的主机名与 IP地址的查询服务。为了分担域名查询的压力、提供区域数据的备份,有时还会另外架设一台从域名服务器,与主域名服务器同时提供服务。
查看文件是否有错
建立正,反区域数据文件
复制文件的名字一定要根 zone里面的名字一样
反向区域
因为区域数据配置文件是手动创建的,默认的属主与属组均为 root 用户,而 named 服务默认以名为“named”的用户身份运行。named 用户要对区域数据文件有读取权限。否则,BIND 服务将无法读取所创建的区域数据配置文件
给权限
重启服务 或 重载 reload
验证主域名服务器
在客户端将 DNS 服务器指向 173.16.16.5(主域名服务器的 IP 地址),使用 nslookup 命令验证 DNS查询结果。
3. 构建从域名服务器
在已经构建好主域名服务器 192.168.10.101 的基础上,继续构建从域名服务器 192.168.10.102。
确认本机的网络地址、主机映射、默认 DNS 服务器地址
将从域名服务器的 IP 地址设为 192.168.10.102,主机名设为 ns2.bdgn.com。另外,主机映射文件/etc/hosts 和 DNS 解析文件/etc/resolv.conf 的内容与主服务器中的内容相同。
建立主配置文件 named.conf
zone "benet.com" IN {
type slave;
file "slaves/benet.com.zone";
};
zone "10/168.192.in-addr.arpa" IN {
type slave;
file "slaves/benet.com.zone";
};
由于从服务器的区域数据文件是从主服务器中下载而来,因此该文件保存的名称可以自行定义,不用与主服务器中的名称一致。但需要注意的是,named 服务默认以名为“named”的用户身份运行,因此要确认 named 用户对存放目录有写入权限
[root@ns2~l# ls -ld /var/named/slaves/
drwxrwx---.2 named named 6 Nov 11 2016 /var/named/slaves/
启动 named 服务,查看区域数据文件是否下载成功
在从域名服务器中启动 named 服务,若配置无误,则 named 将会从主域名服务器中自动下载指定的区域数据文件,并保存到 slaves/日录下。另外,通过系统日志文件/var/log/messages 也可以观察到下载区域数据文件的过程
[root@locathost~]# systemctl start named
[root@locathost~]# ls -lh /var/named/slaves/
总计 8.0K
-rw-r--r--1 named named 450 May 16 16:57 192.168.10.arpa
-rw-r--r--1 named named 453 May 16 16:57 bdgn.com.zone
验证从域名服务器
对于客户端来说,从域名服务器与主域名服务器没有什么区别,通过主服务器能够查询到的信息,通过从服务器也同样能够査询到。验证从域名服务器时,只需要将客户端的首选 DNS 服务器地址设为192.168.10.102(从域名服务器的 IP 地址),使用 nslookup 命令进行正常测试即可。