详解DNS域名解析全过程

关于dns域名解析的大体过程不少人都知道,但有些细枝末节的东西容易遗忘,今天有空整理一下,做为之后复习用偷笑,若有不对的地方,还望指正。解析大体过程如图(不喜欢看图的能够直接跳过大笑):windows



当一个用户在地址栏输入www.taobao.com时,DNS解析有大体十个过程惊恐,以下:浏览器


1. 浏览器先检查自身缓存中有没有被解析过的这个域名对应的ip地址,若是有,解析结束。同时域名被缓存的时间也可经过TTL属性来设置。缓存


2. 若是浏览器缓存中没有(专业点叫还没命中),浏览器会检查操做系统缓存中有没有对应的已解析过的结果。而操做系统也有一个域名解析的过程。在windows中可经过c盘里一个叫hosts的文件来设置,若是你在这里指定了一个域名对应的ip地址,那浏览器会首先使用这个ip地址。服务器




可是这种操做系统级别的域名解析规程也被不少黑客利用,经过修改你的hosts文件里的内容把特定的域名解析到他指定的ip地址上,形成所谓的域名劫持。因此在windows7中将hosts文件设置成了readonly,防止被恶意篡改。性能


3.  若是至此尚未命中域名,才会真正的请求本地域名服务器(LDNS)来解析这个域名,这台服务器通常在你的城市的某个角落,距离你不会很远,而且这台服务器的性能都很好,通常都会缓存域名解析结果,大约80%的域名解析到这里就完成了。网站


4. 若是LDNS仍然没有命中,就直接跳到Root Server 域名服务器请求解析spa


5. 根域名服务器返回给LDNS一个所查询域的主域名服务器(gTLD Server,国际顶尖域名服务器,如.com .cn .org等)地址操作系统


6. 此时LDNS再发送请求给上一步返回的gTLDblog


7. 接受请求的gTLD查找并返回这个域名对应的Name Server的地址,这个Name Server就是网站注册的域名服务器dns


8. Name Server根据映射关系表找到目标ip,返回给LDNS


9. LDNS缓存这个域名和对应的ip


10. LDNS把解析的结果返回给用户,用户根据TTL值缓存到本地系统缓存中,域名解析过程至此结束


写完了,真的累啊!大哭