一、什么是DNS
DNS(Domain Name System,域名系统),因特网上作为域名和IP地址相互映射的一个分布式数据库,能够使用户更方便的访问互联网,而不用去记住能够被机器直接读取的IP数串。通过主机名,最终得到该主机名对应的IP地址的过程叫做域名解析(或主机名解析)。
二、DNS查询的两种方式
1)递归解析
如图所示的是递归方式。局部DNS服务器自己负责向其他DNS服务器进行查询,一般是先向该域名的根域服务器查询,再由根域名服务器一级级向下查询。最后将得到的查询结果返回给局部DNS服务器,再由局部DNS服务器返回给客户端。
2)迭代解析
当局部DNS服务器自己不能回答客户机的DNS查询时,也可以通过迭代查询的方式进行解析,如图所示。局部DNS服务器不是自己向其他DNS服务器进行查询,而是把能解析该域名的其他DNS服务器的IP地址返回给客户端DNS程序,客户端DNS程序再继续向这些DNS服务器进行查询,直到得到查询结果为止。也就是说,迭代解析只是帮你找到相关的服务器而已,而不会帮你去查。比如说:baidu.com的服务器ip地址在192.168.4.5这里,你自己去查吧,本人比较忙,只能帮你到这里了。
三、DNS域名解析过程
1、首先,浏览器会检查自己的DNS缓存
2、浏览器会查找操作系统缓存(本地hosts文件)
3、浏览器会把域名发送给LDNS(本地DNS服务器,承担了主要的域名解析工作,通过ipconfig可以查到),LDNS首先会查询缓存记录
4、LDNS服务器向Root Server域名服务器(根域名服务器)请求解析,经过迭代解析,直至根域名服务器返回一个gTLD服务器(主域名服务器)地址。
5、LDNS服务器向主域名服务器(国际的顶级域名服务器,全球只有13台)请求解析,返回Name Server域名服务器地址(注册的域名服务器)
6、LDNS服务器向域名的解析服务器发出请求,最终得到与域名相对应的IP地址。
特别声明:域名不包括端口
四、DNS负载均衡
当一个网站有足够多的用户的时候,假如每次请求的资源都位于同一台机器上面,那么这台机器随时可能会蹦掉。处理办法就是用DNS负载均衡技术,它的原理是在DNS服务器中为同一个主机名配置多个IP地址,在应答DNS查询时,DNS服务器对每个查询将以DNS文件中主机记录的IP地址按顺序返回不同的解析结果,将客户端的访问引导到不同的机器上去,使得不同的客户端访问不同的服务器,从而达到负载均衡的目的。例如可以根据每台机器的负载量,该机器离用户地理位置的距离等等。
五、参考资料:
1、咸鱼老弟博客园 http://www.cnblogs.com/xianyulaodi/p/6547807.html#_label1
2、《深入分析Java Web技术内幕》 许令波 著