用户在浏览器输入www.baidu.com时,DNS域名解析大致分为以下几个过程:

  1. 浏览器客户端检查自身有没有该域名的缓存:

    如果浏览器有命中,直接返回该域名对应的IP地址,解析结束;

    (这个缓存可以设置TTL来控制有效时间,有点像APR协议在本地保存的的目的IP与主机MAC地址的缓存) 如下图:


    如果浏览器未命中,浏览器会去检查检查操作系统缓存中有没有对应的已解析过的结果,原理同上;

  2. 如果浏览器和OS中都找不到该域名对应的缓存,**那么会请求 本地域名服务器(LDNS)**来解析这个域名,这台服务器一般在距离你的主机比较近的位置,一般情况都会缓存着你要解析域名的结果,大约80%的域名在这里就能解析完成了。

  3. 如果LDNS仍然没有命中,就直接跳到Root Server( 根域名服务器 )请求解析

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

  5. 此时LDNS再发送请求给上一步返回的gTLD Server主域名服务器

  6. 接受请求的gTLD查找并返回给LDNS注册这个域名时候的Name Server (注册该域名的服务器) 的地址;

  7. LDNS再向Name Server发起解析请求,Name Server会根据映射关系表直接找到目标ip,返回给LDNS

  8. LDNS会缓存这个域名和对应的ip,然后把解析的结果返回给用户;

  9. 用户根据TTL值缓存到本地系统缓存中,域名解析过程至此结束;

简单总结DNS域名解析过程:

浏览器首先在自己的缓存找,没有就去系统的缓存还没就去请求本地域名服务器LDNS(一般到这里就有了)
如果LDNS还没有解析结果,那它就去Root Server根域名服务器请求,Root Server会返回给LDNS一个查询主域名(.com .cn等)的主域名服务器gTLD Server
LDNS发起请求gTLD ServergTLD Server查找并返回给LDNS注册这个域名时候的Name Server地址;
LDNS发起请求Name ServerName Server会根据映射关系表直接找到目标ip,最终返回给LDNS
之后向下交付的过程,这个解析结果会还存在LDNS,本地OS,和浏览器缓存中,方便下次解析;

理解要点: 极端情况下,LDNS扮演者核心中转角色,与ROOT DNS Server 根域名服务器,gTLD Server .xxx对应的主域名服务器 ,Name Server 注册待解析域名的服务器 进行了三次一去一回的循环式交付,最终拿到结果;