DNS是什么?
简单说是:DNS把难记的IP地址转换为好记的域名帮助记忆。
DNS(Domain Name System 域名系统):是一项互联网服务,存储域名和IP地址相互映射关系的一个分布式数据库,通过为每台主机建立IP地址与域名之间的映射关系,用户可以避开难记的IP地址,而使用域名来唯一标识网络中的计算机。
主机名和域名的区别:
主机名是内网的名字,域名是外网的名字。
DNS服务器特点
-
域名由点、字母和数字组成
-
点分割不同的域
-
域名包括根域名、顶级域、二级域、三级域(主机)
DNS域名解析过程
情景:如果客户端准备访问百度网站
第一步、先在本地缓存中查询是否有对应的IP地址:如果有则直接读取结果;如果没有,则进行第二步
第二步、向本地DNS服务器发送查询请求:如果有则直接返回给客户端,如果没有,则向根服务器查询,但不是询问www.baidu.com对应的IP是多少,根服务器仅管理顶级域名,而且所有的顶级域名都属于根的管理范畴,所以此时本地DNS服务器向根查询的结果是:根服务器会将它管理的com域对应的IP提供给本地DNS服务器
第三步、本地DNS服务器得到com域服务器的IP后,会再向com查询,然而com也没有最终答案,com域服务器会将它所管理的baidu域服务器对应的IP提供给本地DNS服务器
第四步、本地DNS服务器再向baidu域服务器查询,询问该域下主机名为www的计算机对应的IP地址,由于www主机确实直接属于baidu域的管理范畴,所以baidu会将最终的正确答案返回给本地DNS服务器
第五步、本地DNS服务器将得到的结果返回给客户端,同时本地DNS服务器会将结果缓存起来,当下次再有相同的查询请求时,本地DNS服务器就可以直接从缓存中找到结果返回给客户端。
DNS服务器查询的类型
前提:该过程发生在客户端,客户端需要通过域名转换成IP地址和服务端建立连接,在查询域名所对应的IP地址时有两种方法进行查询 :
1、递归查询:客户端仅发出一次请求,让DNS服务器去查询并返回结果
2、迭代查询:发出请求去分别查询不同的DNS服务器
递归查询和迭代查询的区别
递归查询:客户端只发一次请求,要求对方给出最终答案。返回的结果只有两种:查询成功或查询失败
迭代查询:又称为“重指引”,客户端发出一次请求,对方如果没有授权回答(授权回答:向DNS服务器查询一个域名,刚好这个域名时本服务器负责,返回的结果就是授权回答),他会返回一个能解答这个查询的其他名称服务器列表,客户端会再向返回的列表中发出请求,直到找出最终负责所查询域名的名称服务器,从它得到最终结果。
客户端-本地DNS服务器:属于递归查询
本地DNS服务器-外网:属于迭代查询(不启用转发模式)
---------------------------------------------------------------------------------------------------------------------------------
好啦,就先到这里吧~
喜欢我的可以点赞、关注、收藏,如果有什么技术上的疑问,欢迎留言或私信~