DNS域名分级
1 | # 格式 |
根域可以忽略不写,例如
www.yuhal.com
不用写成www.yuhal.com.
。
DNS域名解析流程
DNS解析优先级
- /etc/nsswitch.conf
修改 DNS 查询的顺序
- /etc/hosts
存放常用的 DNS 记录与开发中测试使用的服务器记录。
- /etc/resolv.conf
设定 DNS 服务器。
DNS的安装
下面使用 BIND9 来搭建 DNS 服务器。
- 更新源
1 | $ apt-get update |
- 安装和配置 BIND
1 | $ apt-get install -y bind9 bind9utils bind9-doc |
- 激活 IPv4 Mode
1 | OPTIONS="-4 -u bind" |
在 /etc/default/bind9 文件中,修改 OPTIONS 变量。
DNS服务器的配置
一般都会设置两个 DNS 服务器,一个主要的,一个备用的,这里只配置主 DNS 服务器。
- 查看主配置文件 named.conf
1 | // This is the primary configuration file for the BIND DNS server named. |
BIND 的配置由多个文件组成,这些文件包含在主配置文件中 named.conf。
- 修改 /etc/bind/named.conf.options
1 | acl "trusted" { |
10.0.2.14 是本机的 ip 地址,114.114.114.114 是非用于商业用途的 DNS 服务器。注意:粘贴前请先设置
:set paste
。有关各配置详细解释可参考 BIND 官方配置项文档。
- 修改 /etc/bind/named.conf.local
1 | // |
该文件中配置了
正向解析
和反向解析
的文件在系统中的位置,简单的说,正向解析就是根据域名查 ip,反向就是根据 ip 查域名。
- 创建正反解析文件的目录
1 | $ mkdir /etc/bind/zones |
- 创建正向解析域文件
1 | $ cp /etc/bind/db.local /etc/bind/zones/db.yuhal.example.com |
- 修改 /etc/bind/zones/db.yuhal.example.com
1 | ; |
- 创建反向解析域文件
1 | $ cp /etc/bind/db.127 /etc/bind/zones/db.10.0.2.14 |
- 修改 /etc/bind/zones/db.10.0.2.14
1 | ; |
- 正反向解析域文件详解
记录类型 | 作用 |
---|---|
A 记录 | 正向解析记录,域名到 IP 地址的映射 |
NS 记录 | 域名服务器记录(NS 为 NameServer) |
MX 记录 | 邮件记录 |
PTR 记录 | 反向解析记录,IP 地址到域名的映射 |
CNAME 记录 | 别名记录,为主机添加别名 |
SOA 记录 | 域权威记录,说明本服务器为域管理服务器 |
AAAA 记录 | 正向解析记录,域名到 IPv6 地址的映射 |
- 检验 BIND 配置文件语法是否错误
1 | $ named-checkconf |
- 检验正向解析和反向解析文件是否正确
1 | $ named-checkzone yuhal.example.com /etc/bind/zones/db.yuhal.example.com |
- 重启 BIND service
1 | $ service bind9 restart |
DNS客户端配置
1 | options timeout:1 attempts:1 rotate |
修改 /etc/resolv.conf,内容如上。
验证
- 运行 dns 服务器在前台
1 | $ named -g |
- 再打开一个终端,查询服务器
1 | $ nslookup host1.yuhal.example.com |