DNS域名查询过程

目录

DNS(Domain Names System)

域名转IP

IP转域名 

域名

域名查询流程

浏览器DNS缓存

操作系统缓存

本地host文件

完整流程

递归查询

迭代查询


DNS(Domain Names System)

域名系统,将域名和 IP 地址进行转换的服务器。

域名转IP

在命令行中通过nslookup + 域名可以查看域名解析到ip

也可以在Chrome浏览器中chrome://net-internals/?#dns去输入域名查看ip 

IP转域名 

 nslookup -qt=ptr ip地址,可以查看ip到域名的解析

域名

url链接由协议+主机+端口+路径组成,其中主机对应的部分为域名。域名组成是先写低级域名再写高级域名。

域名查询流程

1.查询浏览器的DNS缓存。(Chrome浏览器对每个域名会默认缓存60s,具体查看得通过网络日志查看)

浏览器DNS缓存

https://www.cnblogs.com/hls-code/p/17124489.html

2.查询操作系统DNS缓存

操作系统缓存

命令行中通过ipconfig/displaydns查看。

3.本地host文件

本地host文件

4.查询路由器DNS缓存(本地域名服务器)

5.迭代查询上级域名服务器,直到返回正确ip。

完整流程

1. 客户端发起一个DNS请求,先查看本地浏览器是否有这个域名的缓存,有解析结束
2. 没有则去看操作系统是否有缓存,有解析结束
3. 没有则去看本地host文件,有解析结束
4. 没有则发送该请求到本地DNS服务器,本地域名服务器采用递归查询自己的 DNS 缓存,如果本地DNS服务器存在则返回
5. 不存在本地DNS服务器则请求根域名服务器,比如请求"www.baidu.com",根域名服务器告诉本地DNS “.com” 顶级域名服务器的位置
6. 本地DNS服务器收到顶级域名服务器位置后则向顶级域名服务器请求"www.baidu.com"的IP地址,顶级域名服务器收到后则告诉本地DNS服务器"www.baidu.com"的权威域名服务器地址
7. 本地DNS服务器再向权威DNS服务器发起请求,权威DNS服务器查询后将对应的IP地址告诉本地DNS
8. 本地DNS服务器缓存该域名与对应IP然后返回IP给客户端
9. 浏览器根据TTL缓存该值

1-4为递归查询,5-7为迭代查询

递归查询

转发器将相应的查询结果返回至本地DNS服务器192.168.16.1,本地DNS服务器将查询结果返回至主机,最终得出http://qq.com的ns记录。因为本地DNS服务器不是http://qq.com的授权解析服务器,所以查询得出的结果是非权威应答。

  递归的意思是:只需要发出一次请求,就能得到相应的结果。比如主机-本地DNS、本地DNS-转发器,都是递归查询。

迭代查询

本地域名服务器(本机)发起请求向根域名服务器,根域名服务器告诉本地域名服务器继续应该向谁查询,直到找到

<think>我们正在讨论DNS域名解析过程。根据引用内容,DNS解析主要分为递归查询迭代查询两种方式,但通常用户向本地DNS服务器发起的是递归查询,而本地DNS服务器向其他DNS服务器发起的是迭代查询。 这里需要简述DNS域名解析过程,因此我们可以按照以下步骤描述: 1. 用户主机向本地DNS服务器(LDNS)发起查询递归查询)。 2. 如果本地DNS服务器缓存中有记录,则直接返回结果;否则,本地DNS服务器会代替用户进行迭代查询。 3. 本地DNS服务器首先向根域名服务器查询,根域名服务器返回顶级域名服务器的地址。 4. 本地DNS服务器再向顶级域名服务器查询,顶级域名服务器返回权威域名服务器的地址。 5. 本地DNS服务器向权威域名服务器查询,权威域名服务器返回最终的IP地址。 6. 本地DNS服务器将结果返回给用户主机,并缓存结果。 注意:引用[4]提到,如果本地主机配置了hosts文件者本地缓存,会先查询这些,然后再查询LDNS。但通常我们说的DNS解析过程是从向LDNS查询开始。 因此,简述过程可以包括以下步骤: 步骤1:主机查询本地缓存hosts文件 步骤2:向LDNS发起递归查询 步骤3:LDNS查询过程迭代查询) 我们按照这个逻辑进行简述,并在适当的地方引用。 </think>### DNS域名解析过程简述 DNS域名解析是将域名换为IP地址的过程,主要分为以下步骤: 1. **本地查询** 用户主机首先查询**本地缓存**(浏览器缓存→系统缓存→hosts文件),若命中则直接返回IP地址[^4]。 2. **递归查询** 若本地无记录,向**本地DNS服务器(LDNS)** 发起递归查询(通常由ISP提供)[^1][^4]: ```mermaid graph LR A[用户主机] -->|递归查询| B[本地DNS服务器] ``` 3. **迭代查询** 本地DNS服务器执行迭代查询(分层逐级查找)[^2]: - **步骤①** 查询**根域名服务器** → 返回顶级域(.com/.org等)服务器地址 - **步骤②** 查询**顶级域名服务器** → 返回权威域名服务器地址 - **步骤③** 查询**权威域名服务器** → 获取最终IP地址[^3] ```mermaid graph LR B[本地DNS] --> C[根域名服务器] C --> D[顶级域名服务器] D --> E[权威域名服务器] E -->|返回IP| B ``` 4. **结果返回与缓存** 本地DNS服务器将IP地址返回用户主机,并缓存结果(TTL决定有效期)[^1]。 5. **完整流程示例**(解析`www.example.com`) $$ \begin{array}{c|c} \text{查询方} & \text{响应内容} \\ \hline \text{根服务器} & \text{.com服务器地址} \\ \text{.com服务器} & \text{example.com服务器地址} \\ \text{权威服务器} & \text{www.example.com=192.0.2.1} \end{array} $$ --- **相关问题** 1. **递归查询迭代查询的核心区别是什么?**[^1][^2] 2. **如何通过`dig`命令验证DNS解析过程?** 3. **为什么DNS需要分层设计?区域(zone)域(domain)有何不同?**[^3] 4. **TTL值对DNS解析性能有什么影响?** 5. **DNS缓存污染攻击的原理是什么?如何防范?**
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值