前言:DNS(domain name system):用于将域名解析成IP地址,进行访问。在我们日常生活中访问百度、腾讯等网站时,由DNS给我们解析并转交到正确的IP地址上进行访问。
它的解析过程为:查看本机缓存→HOSTS文件→DNS
1:当用户在浏览器中输入域名并按下回车键后,第1步,浏览器会检查缓存中有没有这个域名对应的 解析过的IP地址,如果缓存中有,这个解析过程就将结束。
2:如果用户的浏览器缓存中没有,浏览器会查找操作系统缓存中是否有这个域名对应的DNS解析结果。其实操作系统也会有一个域名解析的过程,在Windows中可以通过C:\Windows\System32\drivers\etc\hosts文件来设置,在linux系统中为/etc/hosts文件,你可以将任何域名解析到任何能够访问的IP地址。
3:前面这两个步骤都是在本机完成的。到这里还没有涉及真正的域名解析服务器,如果在本机中仍然无法完成域名的解析,就会真正请求域名服务器来解析这个域名了。
实验环境:Centos6.5 192.168.1.1 主DNS 本地测试域名为:www.baidu.com
Centos6.5 192.168.1.2 从DNS
Client 192.168.1.3 用于测试
bind主配置文件:/etc/named.conf
区域配置文件:/etc/named.rfc1912.zones
数据目录:/var/named
准备工作前:关闭iptables和selinux
[root@localhost~]#iptables -F
[root@localhost~]#service iptables save
[root@localhost~]#setenforce 0
主DNS部署:
[root@localhost~]# yum -y install bind*
[root@localhost~]# vim /etc/named.conf
[root@localhost~]# vim /etc/named.rfc1912.zones
尾部添加:
[root@localhost~]# cd /var/named
[root@localhost~]# cp -p named.localhost baidu.com.zone
[root@localhost~]# cp -p named.localhost 192.168.1.zone
[root@localhost~]# vim baidu.com.zone
[root@localhost~]# vim 192.168.1.zone
注意com后面有个小点.
[root@localhost~]# named-checkconf
没有显示则配置无问题
[root@localhost~]# named-checkzone “baidu.com” /var/named/baidu.com.zone
ok,测试无问题,可以启动服务了
[root@localhost~]# /etc/init.d/named start
下面到从DNS上面部署↓↓
[root@localhost~]# yum -y install bind*
[root@localhost~]# vim /etc/named.conf
[root@localhost~]# vim /etc/named.rfc1912.zones
尾部添加:
[root@localhost~]# mkdir /var/named/slaves
[root@localhost~]# chown named:named /var/named/slaves
[root@localhost~]# /etc/init.d/named start
[root@localhost~]# ll /var/named/slaves
那么可以看到文件已经自动下载过来了
下面到win7虚拟机测试
IP:192.168.1.3
首选DNS为:192.168.1.1
将首选DNS为:192.168.1.2
输入www.baidu.com,可以给我们正确解析到192.168.1.1上面
是不是so easy呢。。。