作者:Vamei 出处:http://www.cnblogs.com/vamei 严禁任何形式转载。

在周星驰的电影《唐伯虎点秋香》中,周星驰饰演的主角一进入华府,就被强制增加了一个代号9527。从此,华府的人开始称呼主角为9527,而不是他的姓名。

域名(domain name)是IP地址的代号。域名通常是由字符构成的。对于人类来说,字符构成的域名,比如www.yahoo.com,要比纯粹数字构成的IP地址(106.10.170.118)容易记忆。域名解析系统(DNS, domain name system)就负责将域名翻译为对应的IP地址。在DNS的帮助下,我们可以在浏览器的地址栏输入域名,而不是IP地址。这大大减轻了互联网用户的记忆负担。另一方面,处于维护和运营的原因,一些网站可能会变更IP地址。这些网站可以更改DNS中的对应关系,从而保持域名不变,而IP地址更新。由于大部分用户记录的都是域名,这样就可以降低IP变更带来的影响。

从机器和技术的角度上来说,域名并不是必须的。但Internet是由机器和用户共同构成的。鉴于DNS对用户的巨大帮助,DNS已经被当作TCP/IP套装不可或缺的一个组成部分。

DNS服务器

域名和IP地址的对应关系存储在DNS服务器(DNS server)中。所谓的DNS服务器,是指在网络中进行域名解析的一些服务器(计算机)。这些服务器都有自己的IP地址,并使用DNS协议(DNS protocol)进行通信。DNS协议主要基于UDP,是应用层协议(这也是我们见到的第一个应用层协议)。

DNS服务器构成一个分级(hierarchical)的树状体系。上图中,每个节点(node)为一个DNS服务器,每个节点都有自己的IP地址。树的顶端为用户电脑出口处的DNS服务器。在Linux下,可以使用cat /etc/resolv.conf,在Windows下,可以使用ipconfig /all,来查询出口DNS服务器。树的末端是真正的域名/IP对应关系记录。一次DNS查询就是从树的顶端节点出发,最终找到相应末端记录的过程。

中间节点根据域名的构成,将DNS查询引导向下一级的服务器。比如说一个域名cs.berkeley.edu,DNS解析会将域名分割为cs, berkeley, edu,然后按照相反的顺序查询(edu, berkeley, cs)。出口DNS首先根据edu,将查询指向下一层的edu节点。然后edu节点根据berkeley,将查询指向下一层的berkeley节点。这台berkeley服务器上存储有cs.berkeley.edu的IP地址。所以,中间节点不断重新定向,并将我们引导到正确的记录。

在整个DNS查询过程中,无论是重新定向还是最终取得对应关系,都是用户计算机和DNS服务器使用DNS协议通信。用户计算机根据DNS服务器的反馈,依次与下一层的DNS服务器建立通信。用户计算机经过递归查询,最终和末端节点通信,并获得IP地址。

来自wikipedia

缓存

用户计算机的操作系统中的域名解析模块(DNS Resolver)负责域名解析的相关工作。任何一个应用程序(邮件,浏览器)都可以通过调用该模块来进行域名解析。

并不是每次域名解析都要完整的经历解析过程。DNS Resolver通常有DNS缓存(cache),用来记录最近使用和查询的域名/IP关系。在进行DNS查询之前,计算机会先查询cache中是否有相关记录。这样,重复使用的域名就不用总要经过整个递归查询过程。

来自wikipedia

反向DNS

上面的DNS查询均为正向DNS查询:已经知道域名,想要查询对应IP。而反向DNS(reverse DNS)是已经知道IP的前提下,想要查询域名。反向DNS也是采用分层查询方式,对于一个IP地址(比如106.10.170.118),依次查询in-addr.arpa节点(如果是IPv6,则为ip6.arpa节点),106节点,10节点,170节点,并在该节点获得106.10.170.118对应的域名。

实例

下面的视频来自youtube,我觉得它很生动的解释了DNS的工作过程。

如果不能打开,请访问: http://v.youku.com/v_show/id_XNTAwNDY2NjYw.html

很棒的视频,静静享受吧。

欢迎继续阅读“协议森林”系列

协议森林13 9527 (DNS协议)相关推荐

  1. 协议森林06 瑞士军刀 (ICMP协议)

    作者:Vamei 出处:http://www.cnblogs.com/vamei 严禁任何形式转载. 到现在为止,我们讲解了网络层中最重要的IP协议(参考协议森林).IP协议的一个重要补充是是ICMP ...

  2. 计算机网络应用层(二):DNS协议详解

    DNS协议详解 前言 DNS协议概述 DNS工作原理 DNS缓存 DNS记录和报文 资源记录 DNS报文 总结 前言 DNS是计算机网络中应用层的一个协议,可能很多同学碰到过DNS被劫持的情况,我们现 ...

  3. 万字长文爆肝 DNS 协议!

    试想一个问题,我们人类可以有多少种识别自己的方式?可以通过身份证来识别,可以通过社保卡号来识别,也可以通过驾驶证来识别,尽管我们有多种识别方式,但在特定的环境下,某种识别方法可能比另一种方法更为适合. ...

  4. DNS协议详解及报文格式分析

    https://blog.csdn.net/tianxuhong/article/details/74922454 目录 一. DNS协议理论知识 1.1. 域名结构 1.2. 域名服务器 1.3. ...

  5. 带你一文搞懂网络层的IP协议\数据链路层的以太网\ARP协议以及DNS和NAT协议

    TCP连接管理中的保活机制: TCP协议是面向连接通信,若通信双方长时间没有数据往来,就需要确定对方还是否在线,连接是否正常?        若通信双方长时间(7200秒)没有数据往来,在服务端会向客 ...

  6. DNS协议及客户端实现

    2019独角兽企业重金招聘Python工程师标准>>> 一:DNS报文 DNS有两种类型的报文,分别是查询报文和响应报文 其中,首部格式如下: 各字段意义如下: 标识:16位:客户端 ...

  7. 前端网络基础-应用层DNS协议

    目录 初识域名 正向解析和反向解析 DNS解析 主机本地hosts文件实现DNS解析 浏览器缓存实现DNS解析 本地DNS服务器实现DNS解析 域名的组成 DNS迭代解析 DNS递归解析 DNS协议 ...

  8. SLB负载均衡和DNS协议

    SLB负载均衡和DNS协议 SLB 负载均衡 负载均衡原理 负载均衡的组成 健康检测 HTTP/HTTPS监听健康检查机制 健康检测中域名的设置 TCP监听健康检查机制 健康检查状态对请求转发的影响如 ...

  9. DNS协议与DNS服务器搭建(bind)

    写在前面: 博客书写牢记5W1H法则:What,Why,When,Where,Who,How. 本篇主要内容: ● tcp/ip回顾 ● DNS协议/DNS服务相关概念 ● bind安装配置   正向 ...

最新文章

  1. 5笔涂出一只3D猫咪模型,可跑可跳无需手动绑定骨骼,新鬼畜素材get丨浙大开源...
  2. 代码改动两三行,AI数据秒换隐身衣!隐私计算+AI?中科院博士实践分享一键切换...
  3. leetcode算法题--Remove K Digits
  4. ❀❀ selenium 学习网站 ★★★★★
  5. What happens when clicking interaction record work center?
  6. uni-app—微信公众号授权登录(截取code)
  7. Magicodes.IE.AspNetCore之一行代码多格式导出
  8. webservice引用spring的bean
  9. 如何快速搭建云原生企业级数据湖架构及实践分享
  10. abovedisplayskip无效_latex公式图片行间距段间距调整心得 -
  11. 经验 | 如何使用Python进行可视化?
  12. 小户型吊顶的注意事项有哪些
  13. arcgis engine设置数据源路径_不懂ArcGIS,你前期分析用什么做的?
  14. 软件设计模式概述(摘自《研磨设计模式》)
  15. win10本机计算机策略,[本地策略组怎么打开]win10本地组策略打开方法
  16. vue 创建项目时报错yorkie: Command failed.
  17. 超分辨率重建双三次插值Bicubic生成高分辨率图像
  18. Oracle-12c新功能基于时间点recover table
  19. 动图怎么裁剪边框?三步教你在线裁剪gif
  20. 身份证识别-全方位突破,高精度,轻量级!

热门文章

  1. 一次线上Redis类转换异常排查引发的思考
  2. I - Ant Trip (无向图欧拉回路+并查集),判断
  3. webpack 配置
  4. networkX如何读取存储图的二进制.dat文件
  5. 利用Hexo搭建个人博客-博客初始化篇
  6. 在xcode上把你的app多语言国际化(NSLocalizedString)
  7. 使用Java实现的简单的计算器
  8. 接受数据,table列表,外加判断
  9. 26.多线程join detach
  10. POJ--2449--Remmarguts#39; Date【dijkstra_heap+A*】第K短路