DNS工作流程

2024-08-30 08:44
文章标签 流程 工作 dns

本文主要是介绍DNS工作流程,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

DNS(域名系统)

DNS(域名系统)的工作流程是将人类可读的域名(如 www.example.com)转换为机器可读的IP地址(如 192.0.2.1),以便计算机能够相互通信。DNS查询过程可以分为递归查询和迭代查询两种,下面是DNS的基本工作流程:

1. 用户发起DNS请求

当用户在浏览器中输入一个网址(如 www.example.com)时,浏览器首先检查本地缓存是否有该域名的记录。如果没有,操作系统会向配置的DNS服务器发送一个DNS查询请求。

2. 递归查询

如果本地DNS解析器(通常是用户ISP的DNS服务器)没有缓存该域名的IP地址,它会作为DNS客户端,向根DNS服务器发起查询。

3. 根DNS服务器

根DNS服务器是顶级的DNS服务器,它不直接解析域名,而是告诉下一级的顶级域(TLD,例如.com、.net等)DNS服务器的地址。

4. 顶级域(TLD)DNS服务器

本地DNS服务器接着向TLD DNS服务器发起查询。TLD DNS服务器管理着在其下注册的所有二级域名的记录,它会返回负责该域名的权威DNS服务器的地址。

5. 权威DNS服务器

最后,本地DNS服务器向权威DNS服务器发起查询。权威DNS服务器存储了域名对应的IP地址等记录,它会将这些信息返回给本地DNS服务器。

6. 缓存结果

本地DNS服务器收到IP地址后,会缓存这个结果(以减少未来的查询时间),然后把IP地址返回给用户的计算机。

7. 浏览器发起连接

用户的计算机使用得到的IP地址,通过互联网与目标服务器建立连接,从而用户可以访问目标网站。

递归查询与迭代查询

  • 递归查询:当DNS客户端向DNS服务器请求解析域名时,如果这个服务器不直接回答请求,而是代表客户端向其他服务器查询,直到得到最终结果再返回给客户端,这种查询方式称为递归查询。
  • 迭代查询:当DNS服务器接收到客户端的查询请求时,如果这个服务器不直接回答请求,而是告诉客户端下一步应该查询哪个服务器,由客户端向这个新的服务器发起查询,这种查询方式称为迭代查询。

DNS查询过程中,通常用户的本地DNS服务器对根服务器、TLD服务器和权威服务器的查询是迭代查询,而用户的计算机对本地DNS服务器的查询是递归查询。

DNS流程图

+------------------------+
|    用户输入网址        |
|  www.example.com       |
+------------------------+|v
+------------------------+
|   检查浏览器DNS缓存    |
+------------------------+|+-----+-----++-----+-----++-----+-----+|                                     |未命中                                命中|                                     |v                                     v
+------------------------+ 命中   +------------------------+
|   检查操作系统DNS缓存     |----->|      返回IP地址       |
+------------------------+      +------------------------+|                              ^未命中                            ||                               |v                               |
+------------------------+                 |
| 查询本地DNS解析服务器  |                 |
+------------------------+                 ||                               |+-----+-----+                         ||           |                         |未命中      命中                        ||           |                         |v           +-------------------------+
+------------------------+
|   向根DNS服务器查询    |
+------------------------+|v
+------------------------+
| 根DNS服务器返回TLD服务 |
| 器地址 (.com DNS服务器)|
+------------------------+|v
+------------------------+
|   向.com TLD服务器查询 |
+------------------------+|v
+------------------------+
| .com DNS服务器返回     |
| example.com的          |
| 权威名称服务器地址     |
+------------------------+|v
+------------------------+
| 向example.com的        |
| 权威名称服务器查询     |
+------------------------+|v
+------------------------+
| 权威名称服务器返回     |
| www.example.com的      |
| IP地址                 |
+------------------------+|v
+------------------------+
| 本地DNS服务器缓存      |
| 结果并返回给客户端     |
+------------------------+|v
+------------------------+
| 客户端OS缓存DNS记录    |
+------------------------+|v
+------------------------+
| 浏览器缓存DNS记录      |
+------------------------+|v
+------------------------+
| 浏览器使用IP地址       |
| 发起HTTP请求           |
+------------------------+

包括:

  1. 用户输入网址
  2. 检查浏览器DNS缓存
  3. 检查操作系统DNS缓存
  4. 查询本地DNS解析服务器
  5. 如果本地DNS服务器没有缓存,开始递归查询:
    • 查询根DNS服务器
    • 查询顶级域(TLD)DNS服务器(如.com)
    • 查询权威名称服务器
  6. 获取IP地址后,本地DNS服务器缓存结果
  7. 操作系统和浏览器也会缓存DNS记录
  8. 最后,浏览器使用解析到的IP地址发起HTTP请求

这个流程图展示了DNS查询中的主要步骤和决策点,包括各级缓存的检查和递归查询的过程。

这篇关于DNS工作流程的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1120337

相关文章

Security OAuth2 单点登录流程

单点登录(英语:Single sign-on,缩写为 SSO),又译为单一签入,一种对于许多相互关连,但是又是各自独立的软件系统,提供访问控制的属性。当拥有这项属性时,当用户登录时,就可以获取所有系统的访问权限,不用对每个单一系统都逐一登录。这项功能通常是以轻型目录访问协议(LDAP)来实现,在服务器上会将用户信息存储到LDAP数据库中。相同的,单一注销(single sign-off)就是指

Spring Security基于数据库验证流程详解

Spring Security 校验流程图 相关解释说明(认真看哦) AbstractAuthenticationProcessingFilter 抽象类 /*** 调用 #requiresAuthentication(HttpServletRequest, HttpServletResponse) 决定是否需要进行验证操作。* 如果需要验证,则会调用 #attemptAuthentica

工作常用指令与快捷键

Git提交代码 git fetch  git add .  git commit -m “desc”  git pull  git push Git查看当前分支 git symbolic-ref --short -q HEAD Git创建新的分支并切换 git checkout -b XXXXXXXXXXXXXX git push origin XXXXXXXXXXXXXX

嵌入式方向的毕业生,找工作很迷茫

一个应届硕士生的问题: 虽然我明白想成为技术大牛需要日积月累的磨练,但我总感觉自己学习方法或者哪些方面有问题,时间一天天过去,自己也每天不停学习,但总感觉自己没有想象中那样进步,总感觉找不到一个很清晰的学习规划……眼看 9 月份就要参加秋招了,我想毕业了去大城市磨练几年,涨涨见识,拓开眼界多学点东西。但是感觉自己的实力还是很不够,内心慌得不行,总怕浪费了这人生唯一的校招机会,当然我也明白,毕业

kubelet组件的启动流程源码分析

概述 摘要: 本文将总结kubelet的作用以及原理,在有一定基础认识的前提下,通过阅读kubelet源码,对kubelet组件的启动流程进行分析。 正文 kubelet的作用 这里对kubelet的作用做一个简单总结。 节点管理 节点的注册 节点状态更新 容器管理(pod生命周期管理) 监听apiserver的容器事件 容器的创建、删除(CRI) 容器的网络的创建与删除

husky 工具配置代码检查工作流:提交代码至仓库前做代码检查

提示:这篇博客以我前两篇博客作为先修知识,请大家先去看看我前两篇博客 博客指路:前端 ESlint 代码规范及修复代码规范错误-CSDN博客前端 Vue3 项目开发—— ESLint & prettier 配置代码风格-CSDN博客 husky 工具配置代码检查工作流的作用 在工作中,我们经常需要将写好的代码提交至代码仓库 但是由于程序员疏忽而将不规范的代码提交至仓库,显然是不合理的 所

火语言RPA流程组件介绍--浏览网页

🚩【组件功能】:浏览器打开指定网址或本地html文件 配置预览 配置说明 网址URL 支持T或# 默认FLOW输入项 输入需要打开的网址URL 超时时间 支持T或# 打开网页超时时间 执行后后等待时间(ms) 支持T或# 当前组件执行完成后继续等待的时间 UserAgent 支持T或# User Agent中文名为用户代理,简称 UA,它是一个特殊字符串头,使得服务器

未来工作趋势:零工小程序在共享经济中的作用

经济在不断发展的同时,科技也在飞速发展。零工经济作为一种新兴的工作模式,正在全球范围内迅速崛起。特别是在中国,随着数字经济的蓬勃发展和共享经济模式的深入推广,零工小程序在促进就业、提升资源利用效率方面显示出了巨大的潜力和价值。 一、零工经济的定义及现状 零工经济是指通过临时性、自由职业或项目制的工作形式,利用互联网平台快速匹配供需双方的新型经济模式。这种模式打破了传统全职工作的界限,为劳动

Smarty模板引擎工作机制(一)

深入浅出Smarty模板引擎工作机制,我们将对比使用smarty模板引擎和没使用smarty模板引擎的两种开发方式的区别,并动手开发一个自己的模板引擎,以便加深对smarty模板引擎工作机制的理解。 在没有使用Smarty模板引擎的情况下,我们都是将PHP程序和网页模板合在一起编辑的,好比下面的源代码: <?php$title="深处浅出之Smarty模板引擎工作机制";$content=

3.比 HTTP 更安全的 HTTPS(工作原理理解、非对称加密理解、证书理解)

所谓的协议 协议只是一种规则,你不按规则来就无法和目标方进行你的工作 协议说白了只是人定的规则,任何人都可以定协议 我们不需要太了解细节,这些制定和完善协议的人去做的,我们只需要知道协议的一个大概 HTTPS 协议 1、概述 HTTPS(Hypertext Transfer Protocol Secure)是一种安全的超文本传输协议,主要用于在客户端和服务器之间安全地传输数据