一、流程

流程图如下

如图所示,大致就是:浏览器输入地址,然后浏览器这个进程去调操作系统某个库里的 gethostbyname 函数(例如,Linux GNU glibc 标准库的 gethostbyname 函数),然后呢这个函数通过网卡给 DNS 服务器发 UDP 请求,接收结果,然后将结果给返回给浏览器。

这张图其实已经讲明白大致的流程,但是细节上可能有些差异。 例如

  • 我们在用 chrome 浏览器的时候,其实会先去浏览器的 dns 缓存里头查询,DNS 缓存中没有,再去调用 gethostbyname 函数。
  • gethostbyname 函数在试图进行 DNS 解析之前首先检查域名是否在本地 Hosts 里,如果没找到再去 DNS 服务器上查。

不过,看到这里!请回忆下这两道面试题?

现在,会回答了么?

什么,你还不懂怎么答?把文章拉到开头。从头看过。 不过呢,需要补充说明一下,DNS中也有一个地方用到了 TCP 协议。那就是区域传送

DNS 的规范规定了 2 种类型的 DNS 服务器,一个叫主 DNS 服务器,一个叫辅助 DNS 服务器。在一个区中主 DNS 服务器从自己本机的数据文件中读取该区的 DNS 数据信息,而辅助 DNS 服务器则从区的主DNS 服务器中读取该区的 DNS 数据信息。当一个辅助 DNS 服务器启动时,它需要与主 DNS 服务器通信,并加载数据信息,这就叫做区传送(zone transfer)。 这种情况下,使用TCP协议。

讲到这里。其实面试官是可以深入追问的,如下所示

针对第一问,为什么域名解析用UDP协议?

因为 UDP 快啊!UDP 的 DNS 协议只要一个请求、一个应答就好了。而使用基于 TCP 的 DNS 协议要三次握手、发送数据以及应答、四次挥手。但是 UDP 协议传输内容不能超过 512 字节。不过客户端向DNS 服务器查询域名,一般返回的内容都不超过 512 字节,用 UDP 传输即可。

针对第二问,为什么区域传送用 TCP 协议?

因为 TCP 协议可靠性好啊!你要从主 DNS 上复制内容啊,你用不可靠的 UDP ? 因为 TCP 协议传输的内容大啊,你用最大只能传 512 字节的 UDP 协议?万一同步的数据大于 512 字节,你怎么办?

二、原理

现在,讲最后一块 DNS 解析域名的原理!这块是重中之重! 先介绍 linux 下一个 dig 命令,以显示解析域名的过程。 为了便于说明,我们来 dig 一下天猫的过程

dig www.tmall.com

结果如下图所示

莫方,看不懂没事。 现在我们来读重点的两段。第一段代表请求参数如下图所示

这段为查询内容。 DNS 的查询参数一般有三个

(1)域名:服务器、邮件服务器(邮件地址中 @ 后面的部分)的名称。

(2)Class:在设置 DNS 方案时,互联网之外的网络也考虑到了,而 Class 就是用来识别网络的,不过现在只有互联网,所以它的值永远都是代表互联网的 IN 。

(3)记录类型:标识域名对应何种类型的记录。

  • 类型为 A,表示域名对应的 IP 地址。
  • 类型为 MX 时,表示域名对应的是邮件服务器。
  • 类型为 PTR,表示根据 IP 地址反查域名。
  • 类型为 CNAME,表示查询域名相关别名。

当然,你这个时候要问我一个问题啦(注意上图红框)

烟哥,我输入的明明是 http://www.tmall.com 可是命令里解析的地址是 www.tmall.com. 啊,多了一个 . 的符号啊?这个 . 符号是什么意思呢?

于是乎,又扯了一道经典面试题

OK,好,要讲明白这个问题。我们要先把域名的结构讲清楚! www.tmall.com 对应的真正的域名为 www.tmall.com.。末尾的. 称为根域名,因为每个域名都有根域名,因此我们通常省略。

根域名的下一级,叫做"顶级域名"(top-level domain,缩写为 TLD),比如 .com、.net

再下一级叫做"次级域名"(second-level domain,缩写为 SLD ),比如 www.tmall.com 里面的 .tmall,这一级域名是用户可以注册的;

再下一级是主机名(host),比如 www.tmall.com 里面的 www,又称为"三级域名",这是用户在自己的域里面为服务器分配的名称,是用户可以任意分配的。

那么解析流程就是分级查询

(1)先在本机的 DNS 里头查,如果有就直接返回了。本机 DNS 就是下面这个东东

(2)本机 DNS 里头发现没有,就去根服务器里查。根服务器发现这个域名是属于 com 域,因此根域 DNS 服务器会返回它所管理的 com 域中的 DNS 服务器的 IP 地址,意思是“虽然我不知道你要查的那个域名的地址,但你可以去 com 域问问看”

(3)本机的 DNS 接到又会向 com 域的 DNS 服务器发送查询消息。com 域中也没有 www.tmall.com 这个域名的信息,和刚才一样,com 域服务器会返回它下面的 tmall.com 域的 DNS 服务器的 IP 地址。

以此类推,只要重复前面的步骤,就可以顺藤摸瓜找到目标 DNS 服务器。

ps:温馨提醒,dig trace www.tmall.com 可以看到解析过程。有兴趣的读者,自己实验一下。

扯了那么多东西,我们来看第二段内容,也就是响应体的部分! 如下所示

很明显,第一行就是说 www.tmall.com 有一个别名是 www.tmall.com.danuoyi.tbcache.com。后面几行就是这个 www.tmall.com.danuoyi.tbcache.com 地址的真实 IP。

为什么天猫要设一个别名到 http://www.tmall.com.danuoyi.tbcache.com 地址呢? 于是乎,又一道经典面试题出现

说句实在话,我当初第一眼,见到这题的时候,我觉得应该是方便 cdn 配置。 回到我们的例子,如果烟哥的猜测正确,www.tmall.com.danuoyi.tbcache.com 这个地址,应该是淘宝的一个 cdn 地址。 因此,我特意去查了域名备案记录。如下图所示

果然,就是一个淘宝的cdn环境。

那么这么配有什么好处呢?

唉,这题当思考题,快过来探讨留言!

转载于:https://zhuanlan.zhihu.com/p/79350395

(SAW:Game Over!)

DNS 流程说明以及相关问题的解析相关推荐

  1. DNS基本概念和相关命令

    1.基本概念: 1)域名系统(DNS)是一种用于TCP/IP应用程序的分布式数据库,它提供主机名字和IP地址之间的转换及有关电子邮件的选路信息. DNS最常用的版本(包括解析器和名字服务器)是BIND ...

  2. 全网最硬核 JVM TLAB 分析(额外加菜) 7. TLAB 相关 JVM 日志解析

    今天,又是干货满满的一天.这是全网最硬核 JVM 系列的开篇,首先从 TLAB 开始.由于文章很长,每个人阅读习惯不同,所以特此拆成单篇版和多篇版 全网最硬核 JVM TLAB 分析(单篇版不包含额外 ...

  3. 最详细最易理解的linux启动流程解读及相关问题,万字高能无废话

    linux启动流程 linux的启动流程是运维所必须非常理解的东西,因为它将会是我们在发生服务器开不起机等情况的主要排错手段,充分理解了liunx的启动流程能够助力我们对此类故障的快速定位和处理. 废 ...

  4. linux 检查mps版本,linux_mps启动流程_存储相关.doc

    linux_mps启动流程_存储相关 Linux-mips启动流程 -存储相关 linux内核启动的第一个阶段是从 /arch/mips/kernel/head.s文件开始的.而此处正是内核入口函数k ...

  5. yolov3前向传播(二)-- yolov3相关模块的解析与实现(二)

    yolov3相关模块的解析与实现(二) 接上一篇 三.上采样函数 作用:用于将特征图扩展到想要的尺寸大小,和其他特征叠加到一起使用. 上采样的方法为近邻差值法 上采样函数的实现 # 定义上采样函数 d ...

  6. gradle相关配置内容解析

    gradle 项目的构建工具,基于groovy语言.主要用于管理依赖包. as中一般将gradle下载在C:\Documents and Settings<用户名>.gradle\wrap ...

  7. DNS与ARP的关系与原理解析

    DNS与ARP的关系与原理解析 "计算机之间进行通信的只靠IP地址不能完成吗?" 01 前言 我们在上网查询某一个网站的时候,比如谷歌搜索,一般都是输入www .google.co ...

  8. DNS(域名系统)介绍,深入解析DNS解析失败发生的原因及解决方法

    域名系统(英文:Domain Name System,缩写:DNS)是互联网的一项服务.它作为将域名和IP地址相互映射的一个分布式数据库,能够使人更方便地访问互联网.DNS使用TCP和UDP端口53. ...

  9. HTTP请求的三次握手和四次挥手,以及DNS流程解析

    前言:http的交互现在无论是平时自己做项目还是面试,理解他底层连接的原理都至关重要. 前置知识(已知请略过) IP地址(internet Protocol Address) 互联网协议地址 作用:分 ...

最新文章

  1. linq lambda 分组后排序
  2. Python——CSV文件读写(CSV库)
  3. Javascript 获取字符串字节数的多种方法
  4. 重学TCP协议(12)SO_REUSEADDR、SO_REUSEPORT、SO_LINGER
  5. Java中哪些可以作为GC Roots
  6. IModelBinder
  7. java中如何判断一个String 是否可以强制转换成Integer
  8. 两道考研算法设计题- 2010 2013
  9. 程序员面试宝典问题及解析
  10. matlab仿真之大尺度衰落因子2--小区间
  11. 在MATLAB中快速画圆(给出圆心坐标和半径就能直接画的那种)
  12. apk编辑器android源码,apk编辑器电脑版_apk编辑器电脑版下载[apk编译]- 下载之家
  13. 实体与实体之间的联系
  14. 实战篇--优惠券秒杀
  15. the sip module implements API v12.0 to v12.8 but the PyQt5.QtGui module requires API v12.9
  16. # imshow 报错
  17. Vue - 根据输入关键字过滤数组列表(列表搜索功能)
  18. linux系统能看抖音吗,用电脑如何刷抖音?电脑刷抖音方法你知多少
  19. 退役赛总结(山东省第八届ACM程序设计大赛总结)
  20. 【渗透测试】Struts2系列漏洞

热门文章

  1. 轻量集群管理工具PSSH
  2. 关于SQL Server数据库中的标识列
  3. 初学HTML5系列二:HTML5新增的事件属性
  4. MeeGo 1.2发布
  5. as3分页——页数多了后自动居中类似谷歌分页
  6. Web 趋势榜:上周不可错过的最热门的 10 大 Web 项目 - 210416
  7. VMware虚拟机很卡~
  8. SpringBatch之CompositeItemWriter详解
  9. windows下安装服务注册Consul
  10. docker环境下指定jvm参数