CN域名解析服务的体系结构

  1. 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
  2. 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
  3. 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。

CN域名解析服务的体系结构

中国互联网络信息中心(CNNIC)技术部苑卫国孙国念

1. 引言

(1)域名服务的基本概念

域名解析系统DNS(domain Name System)是由主机名解析方案发展出来的一种新的名字的解析机制。1984年9月,ARPANET开始使用DNS,从此DNS成为访问主机名到IP地址映射的标准方法。Internet上最常用的DNS服务器是BIND(Berkeley Internet Name Domain)软件,目前BIND最新的发行版本是9.3.1。

域名系统将主机名解析成IP地址使用到一个全局的、层次性的分布式数据库系统。该系统包含了Internet上所有域名及IP的对应信息。数据库的层次性允许将域名空间划分成独立的管理部分,并称为域(Domain)。数据库的分布式特性则允许将数据库的各个不同的部分分配到不同网络上的域名服务器上,这样各域名服务器可以实现独立的管理。

DNS的域是一种分布式的层次结构系统,这种结构非常类似于UNIX文件系统的层次结构,根的名字以空标签(“”)表示,并称为根域(root domain)。图1所给出的结构是典型的例子。根域的下一级是顶级域。顶级域有两种划分方法:地理域和通用域。地理域是为世界上每个国家或地区设置的,由ISO-3166定义,如中国是cn,美国是us,日本是jp。通用域是指按照机构类别设置的顶级域,主要包括:com(商业组织);edu(教育机构)等。另外随着互联网的不断发展,新的通用顶级域名也根据实际需要不断被扩充到现有的域名体系中来,新增加的通用顶级域名是biz(商业),info(信息行业)等。在顶级域名下,还可以再根据需要定义次一级的域名,如在我国的顶级域名cn下又设立了com,net,org,gov,edu,ac以及我国各个行政区划的字母代表如bj代表北京,sh代表上海等。

图1 域名体系层次结构

域名空间是指表示DNS这个分布式数据库的逆向树型层次结构,完整域名由从树叶节点到根节点的一条路径的所有节点以分隔符“.”按顺序连接而成,如., 其中“.”代表根域(当“.”出现在域名的最右边时,实际上还表示其右边有代表根的空标签“”;也可以用最右边的“.”来表示根),“cn”为顶级域,“com”为二级域,“sina”为三级域,“www”为主机名。

DNS的服务管理层次结构允许将整个域名空间的管理任务分成多份,分别由每个子域自行进行管理,被委托子域有自己的域名服务器,该服务器维护属于该子域的所有主机信息,父域的域名服务器不保留子域的所有信息,而只保留指向子域的指针。域和子域的实际信息包含在区数据文件(zonefile)中,域和子域指域名空间的逻辑分区,区指域名服务器含有的域名空间中的某一部分的完整信息,一个域内可以有多个区。区数据文件是一套包含某个域内机器信息的文本,它的格式是资源记录(resource record)。这些记录中表示主机和它的IP的映射方法。大部分的资源记录如下:Name [TTL] class type data。其中Name是域名。TTL域表示“生存时间”,它是告诉域名服务器隔多长时间更新一次记录。Class域说明记录属于的等级,一般是IN,表示Internet数据。Type域指出记录的类型。Data域保存资源记录要求的参数。主要的资源记录如下表:

表1主要的资源记录的类型

(2)域名服务器

域名的解析过程是域名解析服务器完成的,采用的客户机/服务器模式。在域名服务器上运行一个服务进程(在UNIX系统中一般为named进程),该进程进行名字对IP地址的解析。域名服务器中存储一个区或多个区中主机的信息。

通常在一个区内设置多台服务器,这样做的目的主要是为了提高域名解析系统的可靠性,就是当其中有某台域名服务器出现故障时,所有的域名请求能够转发给其他的域名服务器;另外可以将域名请求的平均地分担到多台服务器上,提高整个系统域名解析的能力和解析的效率,并且可以根据需要将多台域名服务器放置到不同的地方,可以为用户提供地理位置的就近解析。

在一个区内具有多台域名服务器时,域名服务器包括主域名服务器和辅域名服务器,主域名服务器直接从本地的区数据文件(zonefile)中加载本区的信息,区数据文件中包含了服务器所在区内的主机的主机名和它们相应的IP地址;而辅域名服务器则在启动时与负责本区的主域名服务器进行联系,经过一个“区内传输”的过程复制主服务器的数据库。此后,将周期性的查询主域名服务器的数据是否被修改,以保持自己数据库中的数据是最新版本。

2.CN域名服务的解析的原理和过程

在介绍了域名服务体系的层次结构合域名服务器的相关概念后,我们可以比较容易的理解CN域名解析的工作原理和过程,其工作原理及过程分下面几个步骤:

第一步:用户提出域名解析请求,并将该请求发送给本地的域名服务器。

第二步:当本地的域名服务器收到请求后,就先查询本地的缓存,如果有该纪录项,则本地的域名服务器就直接把查询的结果返回。

第三步:如果本地的缓存中没有该纪录,则本地域名服务器就直接把请求发给根域名服务器,然后根域名服务器再返回给本地域名服务器一个所查询域(根的子域,如CN)的主域名服务器的地址。

第四步:本地服务器再向上一步骤中所返回的域名服务器发送请求,然后收到该请求的服务器查询其缓存,返回与此请求所对应的记录或相关的下级的域名服务器的地址。本地域名服务器将返回的结果保存到缓存。

第五步:重复第四步,直到找到正确的纪录。

第六步:本地域名服务器把返回的结果保存到缓存,以备下一次使用,同时还将结果返回给客户机。

下面的例子来形象地说明一个CN域名解析的过程。假设客户机想获得域名“”的服务器的IP地址,此客户本地的域名服务器是(159.226.1.8),域名解析的过程如下所示:

(1)客户机发出请求解析域名的报文。

(2)本地的域名服务器收到请求后,查询本地缓存,假设没有该纪录,则本地域名服务器则向根域名服务发出请求解析域名。

(3)根域名服务器收到请求后,判断该域名属于.cn域,查询到6条NS记录及相应的A记录(或AAAA记录,IPv6使用),得到如下结果并返回给服务器:

相关文档
最新文档