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 服务器中,然后返回到用户。

原文地址:https://www.cnblogs.com/mabiao008/p/13775861.html