dns域名解析原理及过程

文章目录

      • 1.DNS协议
      • 2.域名的层次结构
      • 1.DNS域名解析


1.DNS协议

域名解析:就是域名到IP地址的转换过程。(也可以将IP地址转换为相应的域名地址,叫做反向解析)

  • 人们通过注册的域名可以方便地访问到网站。
  • IP地址是网络上标识站点的数字地址,为了方便记忆,采用域名来代替IP地址标识站点地址。
  • 域名的解析工作由DNS服务器完成。

2.域名的层次结构

dns域名解析原理及过程_第1张图片
比如:www.baidu.com

com: 一级域名. 表示这是一个企业域名。同级的还有 “net”(网络提供商), “org”(⾮盈利组织) 等。
baidu: 二级域名,指公司名。
www: 只是一种习惯用法。

1.DNS域名解析

dns域名解析原理及过程_第2张图片

我们都知道在浏览器通过域名发起一个网络请求的时候,会有DNS服务器将域名解析成ip地址,以便向正确的ip地址发送请求,那么这一个过程具体是怎么处理的呢?大致分为10步:

  • 第一步:浏览器会检查缓存中有没有域名对应的ip地址,这个缓存是有过期时长的,一般是几分钟到几小时不等。

  • 第二步:如果浏览器缓存没有,那么就检查操作系统的hosts文件,linux在/etc/hosts文件中配置。

上面两个步骤若都不满足,则进行下面DNS域名服务器(LDNS)发起请求过程:

  • 第三步:如果本地也没有配置那么就会根据向本机配置的本地区DNS域名服务器(LDNS)发起请求,如果你是通过学校连接互联网的一般是你学校的DNS服务器,如果你是在小区连接互联网的一般是网络提供商比如电信,联通的DNS服务器,DNS服务器通常不会太远。如何查看本机的域名服务器,在Linux可以通过 cat /etc/resolv.conf查看。

  • 第四步:如果LDNS也不能解析,那么就直接到根域名服务器请求解析。

  • 第五步:根域名服务器会给本地域名服务器LDNS一个所查询的主域名服务器(gTLD)地址,gTLD是国际顶级域名服务器,比如.com,.cn,.org等。

  • 第六步:本地域名服务器LDNS再向上一步返回的gLTD服务器发送请求。

  • 第七步:gLTD服务器查询并返回域名对应的Name Server域名服务器的地址,通常是你注册的域名服务器,例如你在某个域名服务器提供商申请的域名,那么这个域名解析任务就由这个域名服务提供商来完成。

  • 第八步:Name Server域名服务器会查询存储的域名和ip的映射关系表,将ip连同一个TTL值返回给DNS Server域名服务器。

  • 第九步:LDNS拿到ip和TTL会缓存起来,缓存时间由TTL值控制。

  • 第十步:把解析的结果返回给用户,用户根据TTL值缓存在本地系统缓存中,域名解析过程结束。

总的来说,两种查询方式:递归查询和迭代查询

  • 1)递归查询:本机向本地域名服务器发出一次查询请求,就静待最终的结果。如果本地域名服务器无法解析,自己会以DNS客户机的身份向其它域名服务器查询,直到得到最终的IP地址告诉本机。
  • 2)迭代查询:本地域名服务器向根域名服务器查询,根域名服务器告诉它下一步到哪里去查询,然后它再去查,每次它都是以客户机的身份去各个服务器查询。

你可能感兴趣的:(计算机基础,dns,域名解析)