首页
学习
活动
专区
圈层
工具
发布

DNS递归和迭代过程详解

DNS原理解析 DNS进化史 etc/hosts –> NIS –>DNS 起初域名和ip地址之间的解析都是完全存放在一个名为hosts的文件当中,在这个文件当中我们建立了ip和域名的一一对应的关系...现在,我们使用DNS协议,来实现分布式、阶层式的系统来管理ip地址和域名之间的对应关系。...DNS查询流程 我们以客户端第一次查询百度为例子解释DNS的查询流程 递归和迭代的区别?...所谓 递归查询过程 就是 “查询的递交者” 更替, 而 迭代查询过程 则是 “查询的递交者”不变。...参考文献 《鸟哥的linux私房菜服务篇》 DNS解析的工作原理及递归与迭代的区别 《TCP/IP详解卷一:协议》 发布者:全栈程序员栈长,转载请注明出处:https://javaforall.cn/134835

3.4K41

DNS递归和迭代查询

转自:https://www.jianshu.com/p/6b502d0f2ede 一、DNS解析分类 DNS解析流程分为递归查询和迭代查询,递归查询是以本地名称服务器为中心查询,递归查询是默认方式,迭代查询是以...其实DNS客户端和本地名称服务器是递归,而本地名称服务器和其他名称服务器之间是迭代 二、DNS递归解析原理 递归解析(或叫递归查询)是最常见,也是默认的解析方式。...,直到本地名称服务器从权威名称服务器得到了正确的解析结果,然后由本地名称服务器告诉DNS客户端查询的结果 DNS递归解析基本流程: 在这个查询过程中,一直是以本地名称服务器(Local DNS)为中心的...然后再由本地名称服务器返回给DNS客户,同时本地名称服务器会缓存本次查询得到的记录项 三、递归查询和迭代查询的区别 DNS客户端和本地名称服务器是递归,而本地名称服务器和其他名称服务器之间是迭代 DNS...DNS迭代名称解析:(或者叫迭代查询)的所有查询工作全部是DNS客户端自己进行(以DNS客户端自己为中心)。

8.9K40
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    【DNS 解析】DNS 解析过程分析

    解析》对 DNS 解析的整个过程进行了阐述,在这里我就简单通过对这篇文章的分析来讲述解析这一过程吧。...图片简单概括一下改文章中域名解析过程:查找浏览器缓存查找系统缓存查找路由器缓存查找ISP DNS 缓存递归搜索首先浏览器缓存是没有太大问题的,各家浏览器都有自己的缓存机制。...最后的查找 ISP DNS 缓存和递归搜索那就更值得怀疑了,首先我设置的 DNS 解析地址不一定是 ISP 所提供的地址,我大可选择一些公共 DNS ,谷歌、微软、腾讯等公司都对外提供公共 DNS 解析...,并且并不是所有的 DNS 服务器都采用递归方式进行请求,迭代请求方式也是常见的。...这里不得不再提的是 DNS 的迭代查询方式和递归查询方式,实际情景可能会较为复杂,甚至出现不同方式混合的情况,这里简单的进行如下不严谨的表述:迭代解析方式中客户端依次访问不同级别的域名解析服务器进行查询递归请求中由服务器完成解析直接返回给客户端

    130K134

    DNS解析过程

    DNS解析过程 域名是为了方便记忆而专门建立的一套地址转换系统,要访问一台互联网上的服务器,最终还必须通过IP地址来实现,域名解析就是将域名重新转换为IP地址的过程。...解析方式 DNS解析查询的方式有两种:递归解析查询和迭代解析查询,通常来说,客户端和本地域名服务器是递归查询,而本地域名服务器和其他域名服务器之间是迭代查询。...递归解析 假如我们本地客户端是A,有三个域名解析服务器B、C、D,首先在本地客户端A发起一次DNS解析请求,对B服务器请求解析DNS,B服务器查询后并无解析记录,则B服务器对C服务器请求解析DNS,,C...A → B → C → D A ← B ← C ← D 迭代解析 假如我们本地客户端是A,有三个域名解析服务器B、C、D,首先在本地客户端A发起一次DNS解析请求,对B服务器请求解析DNS,B服务器查询后并无解析记录...A → B A → C A → D 解析过程 浏览器缓存 在输入URL后浏览器首先检查自身的DNS缓存是否对于此域名有IP地址,通常浏览器对于自身DNS解析缓存保留时间比较短,且数量也有限制,chrome

    43.1K10

    DNS的解析原理和过程

    DNS的解析原理和过程: 在Internet上域名和IP是对应的,DNS解析有两种:一种是正向解析,另外一种是反向解析。...正向解析:正向解析就是将域名转换成对应的 IP地址的过程,它应用于在浏览器地址栏中输入网站域名时的情形。 反向解析:根据IP地址查找对应的注册域名,经常被一些后台程序使用,用户看不到。...另外需要知道的是DNS查询的工作方式: 客户端和浏览器,本地DNS之间的查询方式是递归查询; 本地DNS服务器与根域及其子域之间的查询方式是迭代查询; DNS解析过程: 场景:用户在浏览器输入网址:www.qcloud.com...,其解析过程如下: 第1步:浏览器将会检查缓存中有没有这个域名对应的解析过的IP地址,如果有该解析过程将会结束。...第5步:如果本地DNS服务器无法查询到,则根据本地DNS服务器设置的转发器进行查询; 未用转发模式:本地DNS就把请求发至根DNS进行(迭代)查询,根DNS服务器收到请求后会判断这个域名(.com)是谁来授权管理

    10K00

    DNS解析过程

    以下是DNS解析的详细过程:一、DNS解析的总体流程DNS解析通常分为递归查询和迭代查询两种方式。...以下是两种查询方式的基本流程:递归查询客户端发起请求:客户端(如浏览器)向本地DNS服务器(通常是ISP提供的DNS服务器)发送一个DNS查询请求,请求解析某个域名。...二、DNS解析的详细步骤(以迭代查询为例)以下是DNS解析过程中涉及的主要DNS服务器及其作用:根DNS服务器根DNS服务器是DNS解析的最顶层服务器,负责管理顶级域名服务器(TLD服务器)的地址信息。...TTL值的设置需要平衡解析效率和域名更新的及时性。...四、DNS解析的示例假设客户端要解析域名www.example.com,以下是迭代查询的详细过程:客户端向本地DNS服务器发送查询请求,请求解析www.example.com。

    10.8K10

    递归和迭代

    一.递归(Recursion) 1.递归:以相似的方式重复自身的过程 2.递归在程序中表现为:在函数的定义中直接或间接调用函数自身 3.递归和循环: (1)递归是有去(递去)有回(归来),因为存在终止条件...,比如你打开一扇门还有一扇门,不断打开,最终你会碰到一面墙,然后返回 (2)循环是有去无回,但可以设置终止条件,比如你打开一扇门还有一扇门,不断打开,还有门,没有终点 4.递归的递去和归来: (1)递归的递去...,包括树的遍历,树的深度,…) 7.递归的优缺点 (1)递归的优点:简洁,容易处理问题,代码可读性高 (2)时间和空间消耗大 8.递归式求解的基本方法 (1)代换法 1.猜对答案 2.用数学归纳法求解常系数...,不断用变量的旧值递推新值的过程 2.迭代在程序中的表现:函数不断调用原函数的返回值, 3.迭代与循环,迭代和递归一样,也是循环的一种 (1)循环:参与运算的变量同时是保存结果的变量 (2)迭代:当前保存的结果作为下一次循环计算的初始值...4.迭代和递归 (1)迭代:函数内某段代码实现循环,函数调用时使用前一次循环的返回值作为初始值,A调用B,使5用计数器结束循环 (2)递归:重复调用自身实现循环,A调用A,设置结束条件 (3)递归中一定有迭代

    1.1K30

    DNS 解析过程详解

    域名系统(Domain Name System,简称 DNS)就像是互联网的 “电话簿”,它的作用是将便于人们记忆的域名转换为计算机能够识别的 IP 地址,下面来详细介绍一下 DNS 解析的过程。...全球有众多的 DNS 服务器,它们相互协作,共同构成了庞大的 DNS 系统,比如常见的有根 DNS 服务器、顶级域名服务器、权威 DNS 服务器等,各自承担着不同阶段的解析任务。...如果在本地缓存中找到了该域名对应的 IP 地址,那么就直接使用这个 IP 地址去访问目标网站,这个过程速度非常快,能有效减少网络查询的开销,因为不需要向外部的 DNS 服务器发送请求了。...三、DNS 缓存的作用及相关机制(一)缓存的重要性DNS 缓存机制极大地提高了域名解析的效率。...总结总的来说,DNS 解析过程是一个涉及多个环节、多个服务器协作的复杂但又十分有序的过程,它默默地在背后为我们方便快捷地访问互联网资源发挥着关键作用,了解它的工作原理也有助于我们更好地理解网络通信以及排查一些可能出现的网络访问问题

    3.6K10

    递归和迭代详解

    一个过程或函数在其定义或说明中有直接或间接 调用自身的一种方法,它通常把一个大型复杂的问题层层转化为一个与原问题相似的规模较小的问 题来求解,递归策略只需少量的程序就可描述出解题过程所需要的多次重复计算...通过图解清晰看出递归的工作原理,同时也符合上面所需的两个必要条件 二.迭代 什么是迭代: 迭代是重复反馈过程的活动,其目的通常是为了逼近所需目标或结果。...每一次对过程的重复称为一次“迭代”,而每一次迭代得到的结果会作为下一次迭代的初始值。重复执行一系列运算步骤,从前面的量依次求出后面的量的过程。...,不停的去和\0进行比较,没比较一次都会自增1,这样我们省下了很大的工作量。...三.递归和迭代 上面分别讲解了递归和迭代,两者之间有相同点也有不同的地方 1. 许多问题是以递归的形式进行解释的,这只是因为它比非递归的形式更为清晰。 2.

    35310

    递归和迭代小结

    递归和迭代小结 迭代是人,递归是神。...递归和迭代都是循环的一种。总结分析递归和迭代的区别、联系、优缺点及实例分析。...这是编写迭代程序必须考虑的问题。不能让迭代过程无休止地重复执行下去。迭代过程的控制通常可分为两种情况:一种是所需的迭代次数是个确定的值,可以计算出来;另一种是所需的迭代次数无法确定。...对于前一种情况,可以构建一个固定次数的循环来实现对迭代过程的控制;对于后一种情况,需要进一步分析出用来结束迭代过程的条件。...递归和迭代的比较 相同点: 递归和迭代都是循环的一种。 不同点: 1、程序结构不同 递归是重复调用函数自身实现循环。 迭代是函数内某段代码实现循环。

    66810

    关于递归和迭代

    首先明确递归和迭代的概念。...递归:程序调用自身的编程技巧(将大问题化解为相同结构的小问题,从待解问题一直分解到已知答案的最小问题,在逐级返回得 到原解) 使用递归的两个阶段: 1)递推:把复杂的问题的求解推到比原问题简单一些的问题的求解...迭代:从已知式出发,通过递推式,不断更新变量到解决问题。 从思想上来说,迭代是人,递归是神!...迭代是人,递归是神 从实现上来说,能用迭代就不用递归(递归调用函数,浪费空间,并且递归太深容易造成堆栈的溢出) 下面以剑指offer题为例,给出几个个人感觉实现比较好的迭代。...分析:(递归方式分析得思路 —>迭代方式写代码) public class Solution { public int JumpFloorII(int target) {

    79820

    java递归和迭代_Java中的迭代与递归

    在进行每一步计算时,只要要知道当前结果(product)和i的值即可以了。这种计算形式称之为迭代。迭代有这样几个条件:1、有一个有初始值的变量。2、一个说明变量值如何升级的规则。3、一个结束条件。...( 循环三要素:循环变量、循环体和循环终止条件 )。和递归一样。时间要求随着输入的增长呈线性的可以叫做线性迭代。...迭代 VS 递归 比较了两个程序,我们可以发现,他们看起来几乎相同,特别是其数学函数方面。在计算n!的时候,他们的计算步数都是和n的值成正比的。...递归中肯定有迭代,但是迭代中不肯定有递归,大部分可以相互转换。 能用迭代的不要用递归,递归调用函数不仅白费空间,假如递归太深的话还容易造成堆栈的溢出。...在这个过程中计算了两次fib(3)。 从上面分析的计算过程可以得出一个结论:使用递归实现斐波那契数列存在冗余计算。 就像上面提到的,可以用递归的算法一般都能用迭代实现,斐波那契数列的计算也一样。

    2.9K40

    DNS查询的两种方式:递归查询和迭代查询

    DNS查询的两种方式:递归查询和迭代查询 ---- 1、递归解析 当局部DNS服务器自己不能回答客户机的DNS查询时,它就需要向其他DNS服务器进行查询。此时有两种方式,如图所示的是递归方式。...局部DNS服务器自己负责向其他DNS服务器进行查询,一般是先向该域名的根域服务器查询,再由根域名服务器一级级向下查询。最后得到的查询结果返回给局部DNS服务器,再由局部DNS服务器返回给客户端。...2、迭代解析 当局部DNS服务器自己不能回答客户机的DNS查询时,也可以通过迭代查询的方式进行解析,如图所示。...局部DNS服务器不是自己向其他DNS服务器进行查询,而是把能解析该域名的其他DNS服务器的IP地址返回给客户端DNS程序,客户端DNS程序再继续向这些DNS服务器进行查询,直到得到查询结果为止。...也就是说,迭代解析只是帮你找到相关的服务器而已,而不会帮你去查。比如说:baidu.com的服务器ip地址在192.168.4.5这里 声明:本站所有文章,如无特殊说明或标注,均为本站原创发布。

    9.3K30

    DNS域名解析过程

    域名系统是将互联网资源和地址关联起来的一个分布式数据库。 DNS和统一资源定位符,域名系统本质就是定位资源,互联网中的各种资源,比如视频、图片、文件、网页。。。。...图片 DNS域名解析过程 如上图所示,DNS的存储设计是一个树状结构,叶子节点中才存放真实的映射关系,中间节点存的都是目录。...图片 DNS域名解析过程 DNS查询过程 当用户在浏览器中输入一个网址,就会触发DNS查询。...图片 DNS域名解析过程 根据上图,详细DNS查询结果如下: 1、用户输入网址,先查询本地DNS,本地DNS是一系列DNS的集合,比如ISP提供的DNS、公司网络提供的DNS。...A是记录的类型,A记录代表着这是一条解析IPv4地址的记录,代表域名和IPv4地址的映射关系。从这条记录可知 www.example.com.的IP地址是 139.18.28.5。

    31.6K10

    DNS解析全过程

    域名到IP地址的解析过程的要点如下:当某一个应用需要把主机名解析为IP地址时,该应用进程就调用解析程序,并称为DNS的一个客户,把待解析的域名放在DNS请求报文中,以UDP用户数据报方式发给本地域名服务器...所有的根域名服务器都知道所有的顶级域名服务器的域名和IP地址。不管是哪一个本地域名服务器,若要对因特网上任何一个域名进行解析,只要自己无法解析,就首先求助根域名服务器。...当一个主机发出DNS查询请求时,这个查询请求报文就发送给本地域名服务器。 4、域名的解析过程 注意: 一、主机向本地域名服务器的查询一般都是采用递归查询。...因此,递归查询返回的查询结果或者是所要查询的IP地址,或者是报错,表示无法查询到所需的IP地址。 二、本地域名服务器向根域名服务器的查询的迭代查询。...下面是上图a的几个查询步骤: 1、主机m.abc.com先向本地服务器dns.xyz.com进行递归查询。 2、本地服务器采用迭代查询。它先向一个根域名服务器查询。

    3K00

    Dns域名解析过程

    一、DNS是什么   dns全称Domain Name System,又称域名系统,是互联网的一项服务,   主要在dns服务器中保存着域名和ip地址的对应关系,为人们提供域名解析服务。   ...全球一共有13台根dns服务器,美国10台,欧洲2台,分布在英国和瑞典,   亚洲1台,在日本。...  顶级DNS服务器:掌握着权威dns的ip和域名的对应关系     eg: .com .cn .org   权威DNS服务器 :掌握着二级域名dns服务器的ip和域名的对应关系     eg: baidu.com...三、在浏览器输入url按下回车的整个过程 3.1大致过程   1.把输入的url域名通过dns解析成ip地址   2.浏览器向ip发送请求信息(包括请求头Request Headers和请求体Request...Body)   3.服务器向浏览器回应一个响应信息(包括响应头Response Headers和响应体Response Body) 3.2dns解析详细过程   1.先向本地dns缓存查看有没有该域名对应的

    59.8K30

    递归和迭代的对比

    一个过程或函数在其定义或说明中有直接或间接调用自身的一种方法,它通常把一个大型复杂的问题层层转化为一个与原问题相似的规模较小的问题来求解,递归策略只需少量的程序就可描述出解题过程所需要的多次重复计算,大大地减少了程序的代码量...每一次对过程的重复称为一次“迭代”,而每一次迭代得到的结果会作为下一次迭代的初始值。重复执行一系列运算步骤,从前面的量依次求出后面的量的过程。...,递归代码块更加简洁轻便,而迭代冗长。...那么我们再看一下递归在内存中的情况: 我们拿阶乘问题作例子: 在程序递归过程中,每调用一次函数就会创建一个栈帧结构,而在每个栈帧结构中就会创建各自的局部变量,就会占用内存,相比于迭代,在内存方面...综上所述,尽管递归看起来代码简单,但是无论是时间复杂度和空间复杂度来说都是迭代更好,所以在项目中还是推荐使用迭代而不是递归。

    1.2K10

    C语言-递归和迭代

    (以3为例),红色表示递退过程,绿色表示回归过程. 2.按顺序打印 1.Print( 1234 ) 2....在第三个例子中,被除数和除数都是浮点数,所以结果保留小数部分,为浮点数 2.5。 递归与迭代 虽然递归很好用,但是如果递归深度太深可能会发生栈溢出的问题....,发生栈溢出现象 迭代: 表示一种重复做的事情,循环是一种迭代 我们可以通过迭代(循环)解决阶乘问题 int main() { int n = 0; scanf("%d", &n); int i...写代码, 是非常方便的,简单的 写出的代码是没有明显缺陷的,这时候使用递归即可 2.如果使用递归写的代码,是存在明显缺陷的 比如:栈溢出,效率低下等 这时候必须考虑其他方式,比如: 迭代...操作规则:每次只能移动一个盘子,并且在移动过程中三根杆上都始终保持大盘在下,小盘在上,操作过程中盘子可以置于A、B、C任一杆上。

    56410
    领券