DNS 原理

概述

DNS (Domain Name System)域名系统。是提供根据域名找到对应的 IP 的服务。
Http 协议访问一个网址时,其实是根据 ip 地址进行访问的,所以需要把 域名转换成IP,在进行访问。

DNS 记录表

DNS 服务器数据存储格式类似下面表格。

域名 Class 记录类型 响应数据
www.baidu.com IN A 163.177.151.110
126.com IN MX 10 mail.126.com
mail.126.com IN A 123.126.96.212
  • 域名
    服务器、邮件服务器的名称
  • Class
    目前只有 IN 一种 Class。代表 Internate。
  • 记录类型
    A:Address,表示这条记录存储是 ip 地址
    MX: mail exchange,表示这条记录是邮件服务器
    PTR:表示 IP 反查域名
    NS: 查询DNS 服务器IP地址
    CNAME:查询域名别名
    SOA:查询域名属性信息
    ...

查询 DNS

查询 DNS 时,需要传入三个参数:域名、Class、记录类型。然后DNS根据传入的这三个参数信息去DNS 表中查询对应的数据,并返回响应数据。
比如:

  • 查询条件
    域名=www.baidu.com
    Class=IN
    记录类型=A

  • 返回结果
    响应数据=163.177.151.110

DNS 请求原理

当浏览器打开一个网站时首先会从浏览器缓存中获取域名对应的ip,如果获取不到,则从 host 文件中获取,如果还是无法获取到,则开始去 DNS 服务器中获取,如下图。

比如请求解析的域名为: www.baidu.com

第①步,请求电脑上配置的 DNS 服务器,DNS 服务器也可以有多个层级,比如:公司内部可以搭建一个DNS 服务器,公司DNS 服务器获取不到,可以去当前市级 DNS 服务器,市级 DNS 服务器获取不到然后到 省级 DNS 服务器。

第②步:DNS 服务器获取不到ip,则会请求根DNS服务器,根DNS服务器,可以根据你请求的域名,判断属于哪个顶级域名,然后把顶级域名 DNS 服务器的ip 返回,此时返回的是 com。

根DNS 服务器的ip,全球只有13个,这13个ip地址是固定不变的,因此可以将这13个ip 内置到 所有的 DNS 服务器中,这样就可以保证能解析到任何的域名。

就这样经过 ③、④、⑤步, DNS 服务器就可以把 www.baidu.com 的域名对应的ip 解析出来,并缓存到当前的 DNS 服务器中,然后返回到用户。

你可能感兴趣的:(DNS 原理)