DNS全称为Domain Name System,即域名系统,其作用就是将域名解析为IP地址。
分层式管理结构。DNS利用树形目录结构,将主机名的管理分配给不同的层级,这样可以实现更加快速的完成主机名的查找, 修改主机名解析时也更加方便。
域:
TLD:Top Level Domain (顶级域名)
组织域:.com, .org, .net, .edu,.gov,.mil,.cc,…
国家域:.cn, .us, .tw, .iq,…
反向域: .in-addr-arpa
完整的域名 www.baidu.com.
. 根域 全球一共13个根域
.com 超级域,一级域
.baidu 二级域
www 主机名
资源记录:rr(resource record)
有类型的概念;用于此记录解析的属性
本地hosts文件
本地DNS缓存
本地DNS服务器
发起迭代查询
主DNS服务器:为客户端提供域名解析的主要区域,主DNS服务器宕机,会启用从DNS服务器提供服务。
从DNS服务器 :主服务器DNS长期无应答,从服务器也会停止提供服务。
主从区域之间的同步采用周期性检查+通知的机制,从服务器周期性的检查主服务器上的记录情况,一旦发现 修改就会同步,另外主服务器上如果有数据被修改了,会立即通知从服务器更新记录。
缓存服务器:服务器本身不提供解析区域,只提供非权威应答。不负责解析,仅为加速,不需要注册
转发服务器:当DNS服务器的解析区域(包括缓存)中无法为当前的请求提供权威应答时,将请求转发至其 它的DNS服务器,此时本地DNS服务器就是转发服务器。
安装DNS服务器软件:
yum install bind-chroot
分为四步骤:
0)#关闭防火墙和selinux
1)#主配置文件:/etc/named.conf
2)#区域配置文件:/etc//etc/named.rfc1912.zones:用来保存域名和IP地址对应关系
3)#数据配置文件目录/var/named,用来保存域名和IP地址对应关系的所在位置
vi /etc/named.conf
options {
#listen-on port 53 { any; }; #服务器上的所有IP地址可提供DNS域名解析
#listen-on-v6 port 53 { ::1; };
directory "/var/named";
dump-file "/var/named/data/cache_dump.db";
statistics-file "/var/named/data/named_stats.txt";
memstatistics-file "/var/named/data/named_mem_stats.txt";
#allow-query { any; }; #允许所有人对本服务器发送DNS请求
可以用 named-checkconf 命令检测named.conf文件是否出错
}
vi /etc/named..rfc1912.zones
zone "yuan.com" IN {
type master; #服务类型
file "yuan.com.zone"; #域名与IP地址解析规则保存文件
allow-update { none; }; #允许哪些客户机动态更新解析信息
}; #正向解析
zone "192.168.192.in-addr.arpa" IN { #表示为192.168.192.0/24网段的反射解析区域 #此行IP反着写比如原为192.168.1.0>,在这则写为1.168.192
type master;
file "192.168.192.arpa";
allow-update { none; };
}; #反向解析
用 named-checkzone来检测zone文件的配置是否正确
cd /var/named
cp -a named.localhost yuan.com.zone
vi yuan.com.zone
$TTL 1D #生存周期为1天 @
IN SOA yuan.com. root.yuan.com.( #@当前的域名 #授权信息开始 #DNS区域的地址 #域名管理员邮箱不要用@符号
11 ; serial #更新序列号
1D ; refresh #更新时间
1H ; retry #重试延时
1W ; expire #失效时间
3H ) ; minimum #无效解析记录时间
NS ns.yuan.com. #域名服务器记录
ns IN A 192.168.192.133 #地址记录ns.yuan.com.
IN MX 10 mail.yuan.com. #邮箱交换记录
mail IN A 192.168.192.133 #地址记录mail.yuan.com.
www IN A 192.168.192.133 #地址记录www.yuan.com.
news IN A 192.168.192.133 #地址记录news.yuan.com.
cd /var/named
cp -a named.localhost yuan.com.zone
vi yuan.com.zone
$TTL 1D
@ IN SOA yuan.com. root.yuan.com. (
11 ; serial
1D ; refresh
1H ; retry
1W ; expire
3H ) ; minimum
NS ns.yuan.com.
ns A 192.168.192.133
133 PTR ns.yuan.com. #PTR为指针记录,仅用于反向解析中
133 PTR mail.yuan.com.
133 PTR www.yuan.com.
133 PTR news.yuan.com.
systemctl restart named #重启服务
yum install bind-utils -y #bind-utils为客户端 测试dns使用
接下来修改网络配置文件,配置DNS客户
vi /etc/resolv.conf
search localdomain
nameserver 192.168.192.133
#注意:测试前必须先修改网络配置文件 防止出现如下错误:
测试:
nslookup
> www.yuan.com
Server: 192.168.192.133
Address: 192.168.192.133#53
> news.yuan.com
Server: 192.168.192.133
Address: 192.168.192.133#53
> mail.yuan.com
Server: 192.168.192.133
Address: 192.168.192.133#53
> mail.yuan.com
Server: 192.168.192.133
Address: 192.168.192.133#53
[root@localhost etc]# nslookup
> server 192.168.192.133
Default server: 192.168.192.133
Address: 192.168.192.133#53
#在DNS域名解析服务中,从服务器可以从主服务器上获取指定的区域数据文件,从而起到备份解析记录与负载均衡的作 用,因此通过部署从服务器可以减轻主服务器的负载压力,还可以提升用户的查询效率
#测试需要两台服务器!主192.168.192.133,从192.168.192.223
vi /etc/named.rfc1912.zones
zone "yuan.com" IN {
type master;
file "yuan.com.zone";
allow-update { 192.168.192.223; };
};
zone "192.168.192.in-addr.arpa" IN {
type master; file "192.168.192.arpa";
allow-update { 192.168.192.223; };
};
systemctl restart name #重启服务
vi /etc/named.rfc1912.zones
zone "yuan.com" IN {
type slave;
masters { 192.168.192.133; };
file "slave/yuan.com.zone";
};
zone "192.168.192.in-addr.arpa" IN {
type slave;
masters { 192.168.192.133; };
file "slave/192.168.192.arpa";
};
systemctl restart name #重启服务
vi /etc/resolv.conf
search localdomain
nameserver 192.168.192.133
nameserver 192.168.192.223
cd /var/named/slaves/
ls
192.168.192.arpa yuan.com.zone
nslookup
> www.yuan.com
Server: 192.168.192.133
Address: 192.168.163.133#53
> 192.168.192.133
Server: 192.168.192.133
Address: 192.168.192.133#53
133.192.168.192.in-addr.arpa name = www.yuan.com.192.168.192.in-addr.arpa.
133.192.168.192.in-addr.arpa name = ns.yuan.com.
133.192.168.192.in-addr.arpa name = news.yuan.com.
vi /etc/named.rfc1912.zones
zone"yuan.com" IN {
type master;
file "yuan.com.zone";
allow-update { 192.168.192.223; 192.168.192.129; };
};
zone "192.168.192.in-addr.arpa" IN {
type master;
file "192.168.192.arpa";
allow-update { 192.168.192.223; 192.168.192.129; };
};
C:\Users\asus>nslookup
>server 192.168.192.133 #设置默认服务器
默认服务器:[192.168.192.133]
Address:192.168.192.133
192.168.192.133
> 192.168.192.133
服务器: [192.168.192.133]
Address: 192.168.192.133
名称: news.yuan.com
Address: 192.168.192.133
> www. yuan.com
服务器: [192.168.192.133]
Address: 192.168.192.133
名称: www.yuan.com
Address: 192.168.192.133
扩展测试:
1.停掉Linux的主从或主服务器
2.停掉Linux的从服务器