




版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
1、第9章 域名系统(DNS),9.1 命名机制与名字管理 9.2 因特网域名 9.3 DNS服务器 9.4 域名解析 9.5 DNS报文格式 9.6 DNS资源记录 9.7 DNS配置及数据库文件,9.1 命名机制与名字管理,因特网的命名机制要求主机名字具有: 全局惟一性 便于管理 便于映射 网络中通常采用的命名机制有两种:无层次命名机制和层次型命名机制。 无层次(flat)命名机制:早期因特网采用,主机名用一个字符串表示,没有任何结构。所有的无结构主机名构成无层次名字空间。 为了保证无层次名字的全局惟一性,命名采用集中式管理方式,名字地址映射通常通过主机文件完成。,问题:无层次命名不适合具有大
2、量对象的网络,随着网络中对象的增加,中央管理机构的工作量也会增加,映射效率降低,而且容易出现名字冲突。 层次型命名机制将层次结构引入主机名字,该结构对应于管理机构的层次。 层次型命名机制将名字空间分成若干子空间,每个机构负责一个子空间的管理。授权管理机构可以将其管理的子名字空间进一步划分,授权给下一级机构管理,而下一级又可以继续划分他所管理的名字空间。这样一来,名字空间呈一种树形结构,树上的每一个节点都有一个相应的标号。,根是惟一的,所以不需要标号。树的叶结点是那些需要根据名字去寻址的主机(通常是网络上提供服务的服务器)。 惟一性:每个机构或子机构向上申请自己负责管理的名字空间,并向下分配子名
3、字空间。在给结点命名标号时(分配子名字空间),每个机构或子机构只要保证自己所管理的名字的下一级标号不发生重复就可以保证所有的名字不重复。 管理:通过层次化的名字结构,将名字空间的管理工作分散到多个不同层次的管理机构去进行管理,减轻了单个管理机构的管理工作量,提高了效率。 映射:很多的名字解析工作可以在本地完成。极大地提高了系统适应大量且迅速变化的对象的能力。 当前因特网采用的是层次型命名机制。,返回,9.2 因特网域名,根据系统采用的是无层次命名机制还是层次型命名机制,主机名可以通过主机文件或者域名系统DNS进行转换。 用主机文件进行名字解析时,每个需要进行名字解析的主机都拥有一个HOSTS文
4、件。现在,小型网络仍然可以采用这种方式进行名字解析。下面是Windows系统中的HOSTS文件。,# This is a sample HOSTS file used by Microsoft # TCP/IP for Windows. # This file contains the mappings of IP addresses to # host names. # Each entry should be kept on an individual line. The # IP address should be placed in the first column # followe
5、d by the corresponding host name. # The IP address and the host name should be # separated by at least one space. # Additionally, comments (such as these) may be # inserted on individual lines or following the machine # name denoted by a # symbol. # For example: # 7 # source server # 38.2
6、5.63.10 # x client host localhost,域名系统DNS是在1984年为取代HOSTS文件而创建的层次型名字系统。 域名系统层次结构从高到低的组织: 根域(Root)位于DNS的最高层,一般不出现在域名中。如果确实需要指明根,那么它将出现在FQDN的最后面,以一个句点“”表示。 顶级域又称为一级域,顶级域按照组织类型和国家划分,可以分为三个主要的域:通用顶级域名gTLD、国家代码顶级域名ccTLD和反向域。 gTLD:com、org和net是向所有用户开放的三个通用顶级域名,也称为全球域名,任何国家的用户都可申请注册它们下面的二级域名。mil、go
7、v和edu三个通用顶级域名只向美国专门机构开放。int是适用于国际化机构的国际顶级域名(iTLD)。,上述7个传统的通用顶级域供不应求,后来又新增了7个顶级域:biz、info、name、pro、aero、coop和museum(新的顶级域名)。 其中前4个是非限制性域,后3个是限制性域,限制性域只能用于专门的领域。 ccTLD:目前有240多个国家代码顶级域名,由二个字母缩写来表示。uk代表英国,hk代表香港(地区), sg代表新加坡。 反向域:的顶级域名为arpa,用于实现IP地址到域名的反向解析。 次级域又叫二级域,次级域与具体的公司或组织相关联。 子域是次级域下面的域,子域是各个组织将
8、名字空间进行的进一步划分。,主机名(Host Name)是最末级的名字。 每个域/子域对应图9-1中的一棵子树,而在实际的名字空间的管理中采用的是区域(Zone)的概念,区域是DNS的管理单元,通常是指一个DNS服务器所管理的名字空间。区域和域是不同的概念,域是一个完整的子树,而区域可以是子树中的任何一部分,区域可以是一个域,也可以不是一个域,区域不一定包含那部分DNS树中的所有子域。图9-2描述了区域和域的不同。,DNS主要由3个部分构成: 名字解析器(resolver) 名字解析器请求名字服务器的服务,获得待查主机的IP地址。解析器位于应用程序中或主机的例行程序库中。 域名空间(domai
9、n name space) 用树形结构组织的DNS数据库。 名字服务器(name server) 名字服务器用于保存域名空间各部分的信息,响应名字解析请求。,返回,9.3 DNS服务器,DNS服务器可以通过多种方法获取域名空间的部分信息: 可以由管理员编辑一个原始区域文件 从其他名字服务器那里复制区域文件 通过向其他DNS服务器查询来获取具有一定时效的缓存信息 名字服务器的三种主要类型: 主(primary)名字服务器 次(secondary)名字服务器 惟高速缓存(caching-only)名字服务器 主名字服务器是拥有一个区域文件的原始版本的服务器。关于该区域文件的任何变更都在这个主名字服
10、务器的原始版本上进行。,次名字服务器从其他主名字服务器那里复制一个区域文件。该区域文件是主名字服务器的原始区域文件的一个只读版本。关于区域文件的任何改动都在主名字服务器那里进行,次名字服务器通过区域传输(zone transfer)跟随主名字服务器上区域文件的变化。 惟高速缓存名字服务器上没有区域文件,它的职责是帮助名字解析器完成名字解析,并缓存解析结果。惟高速缓存名字服务器对名字解析请求的响应是非授权的。惟高速缓存名字服务器在启动之后,通过缓存查询的结果来逐渐建立DNS信息。缓存条目的生存期TTL由提供授权解析结果的名字服务器决定。该服务器将查询的生存期和名字解析一起返回。,返回,9.4 域
11、名解析,TCP/IP的域名系统是一个有效的、可靠的、通用的、分布式的名字地址映射系统。 域名解析包括正向解析和反向解析: 正向解析是根据域名查询其对应的IP地址或其他相关信息 反向解析是根据IP地址查询其对应的域名 DNS服务器和客户端属于TCP/IP模型的应用层,DNS既可以使用UDP,也可以使用TCP来进行通信。DNS服务器使用UDP/TCP的53号熟知端口。 DNS服务器能够接收两种类型的解析: 递归解析(Recursive resolution) 反复解析(iterative resolution)。,9.4.1 递归解析 递归解析要求名字服务器系统一次性完成名字地址变换。递归查询强迫
12、指定的DNS服务器对请求做出响应,该响应或者是一个失败响应,或者是一个包含相应的解析结果的成功响应。客户端计算机的解析器通常会发出递归查询。,9.4.2 反复解析反复解析要求客户端本身反复寻求名字服务器的服务来获得最终的解析结果。在反复解析中,名字服务器收到请求后,若能够给出解析结果,则向客户端发回最终结果,若本名字服务器无法给出解析结果,则应向查询者提供它认为能够给出解析结果的服务器的IP地址。请求者收到该IP地址后,将向该地址发解析请求,直到获得最终解析结果或失败响应。 当一个名字服务器试图找到它的本地域之外的名字时,往往会发送反复查询。为了解析名字,它可能必须查询许多外面的DNS服务器,
13、一般从根域服务器开始自顶向下查找。,9.4.3 反向解析名字解析中的反向解析是指由主机的IP地址求得其域名的过程。DNS在名字空间中设置了一个称为的特殊域,专门用于反向解析。为了能够将反向解析与正向解析用相同的方法进行解析,反向解析将IP地址的字节颠倒过来写,构成反向解析的“名字空间”。地址为26的主机的域名为02.. 。,9.4.4 解析效率解决:两步名字解析机制和高速缓存技术。 采用两步名字解析机制解析时,第一步先通过本地名字服务器进行解析,若不行,再采用自顶向下的方法搜索。两步法既提高了效率又
14、保证了域名管理的层次结构。 在名字服务器中采用高速缓存技术,存放最近解析过的名字地址映射和描述解析该名字的服务器位置的信息,可避免每次解析非本地名字时都进行自顶向下的搜索,减小非本地名字解析带来的开销。,有效性问题:若授权名字服务器中的名字地址映射已发生变化而高速缓存未能作相应刷新,则会带来有效性问题,高速缓存内容的失效会导致解析错误。 解决方法: 服务器向解析器报告缓冲信息时,必须注明该信息是非授权的信息,同时还指出能够给出授权解析结果的名字服务器的地址。若解析器仅注重效率,它可以立即使用非授权的结果,若解析器注重解析的准确性,则可以立即向授权服务器发出解析请求,以便获得准确的结果。 高速缓
15、存中的每一个映射条目都有一个生存时间TTL,一旦某条目的TTL时间到,便将它从缓冲区中删除。 事实上,由于域名地址映射的稳定性,名字缓冲机制还是非常有效的。,返回,9.5 DNS报文格式,DNS报文包括请求报文和响应报文。请求报文和响应报文的格式是相同的。 DNS报文的首部由6个字段构成: 标识字段长度为16比特,用于匹配请求和响应。 标志字段长度为16比特,划分为如图9-7所示的若干子字段。 QR子字段(1比特):用来区别请求和响应。0表示请求报文,1表示响应报文。 OpCode子字段(4比特):用来定义操作类型。 0表示标准查询(正向解析) 1表示反向查询(反向解析) 2表示服务器状态请求
16、。,DNS报文首部的后面是可变部分,包括四个小部分。 问题部分由一组问题记录组成。问题记录格式如图。 询问名字段可变长,询问名由标号序列构成,每个标号前有一个字节指出该标号的字节长度。 询问类(query class)16比特,1表示因特网协议(IN)。 询问类型(query type)16比特,定义询问希望得到的回答类型。域名虽然主要针对主机而言,但由于域名系统的通用性,域名解析既可以用于获取IP地址,也可以用于获取名字服务器和主机信息等。为了区分这些不同类型的对象,域名系统中每一命名条目都被赋予类型属性。(表9-3),表9-3 常用的类型 A 1 IPv4地址 用于域名到IPv4地址的转换
17、 NS 2 名字服务器 标识区域的授权名字服务器 CNAME 5 正规名 定义主机正规名的别名 SOA 6 授权开始 标识授权的开始 PTR 12 指针 指向其他域名空间的指针 HINFO 13 主机信息 标识主机使用的CPU和OS MX 15 邮件交换 标识用于域的邮件交换资源 AAAA 28 IPv6地址 用于域名到IPv6地址的转换 AXFR 252 区域传输 请求传输整个区域 ANY 255 全记录请求 请求所有的记录,记录别名 数值 记录类型描 述,DNS报文的其余三个部分是回答部分、授权部分和附加信息部分,附加信息包含回答部分和授权部分返回的资源所要求的附加信息(如IP地址)。 这
18、三部分均由一组资源记录组成,而且仅在应答报文中出现。一条资源记录描述一个域名,格式如图。,在响应报文中,回答的域名往往与问题中的域名相同。为了节省响应报文的空间,服务器对回答的域名采用压缩格式,对相同的域名只存放一个拷贝,其他采用指针表示。 若开始的两个二进制位为“11”,则接下去的14比特为指针,该指针指向存放在报文中另一位置的域名字符串。 若开始的两个二进制位为“00”,则接下去的6比特指出紧跟在计数字节后面的标号的长度。,解析域名的请求报文,解析域名的响应报文,返回,9.6 DNS资源记录,DNS响应报文中的回答部分、授权部分和附加信息部分由资源记录构成,资源记录存放在名字服务器的数据库
19、中。DNS具有20多种不同类型的资源记录,下面给出几种常用的资源记录的格式。 授权开始( SOA)资源记录定义在域中充当主名字服务器的主机及相关参数。语法如下: IN SOA ( ),符号指明名字服务器所负责的域,通过引导文件可以查到域名。 IN和SOA分别指明资源记录的类和类型。 名字服务器(NS)资源记录指明哪一个DNS服务器对于域是授权服务器。要确保在主名字服务器和次名字服务器内包含NS资源记录。语法: IN NS 指明名字服务器所对应的域的名称。指定域名的授权名字服务器的完全合格域名FQDN。 地址(A)资源记录指明主机的IP地址。语法: IN A 指明主机名。定义主机的IPv4地址。
20、IPv6的资源记录类型为AAAA。,正规名(CNAME)资源记录提供为主机创建别名的能力。通过使用别名,可以使提供多种服务的主机以不同的名字提供不同的服务。语法: IN CNAME :主机的别名。:实际主机名。 邮件交换(MX)资源记录描述该域的邮件服务器。一个域可以有多个MX资源记录,以便实现指定域的email服务的负载均衡和容错。语法: IN MX 是邮件交换服务器处理邮件的域名。是邮件交换服务器的代价值,代价值代表服务器的优先级。代价值越小,优先级越高。相同的代价值:进行负载均衡。仅当低代价值的邮件交换服务器不可达时,邮件才被送往高代价的邮件交换服务器。字段代表邮件交换服务器的主机名。,
21、返回,9.7 DNS配置及数据库文件,BIND(Berkeley Internet Name Daemon)软件是一个客户/服务系统,客户端称为解析器或转换程序(resolver),解析器产生域名信息的查询请求,并将信息发送给服务器,服务器回答解析器的查询。BIND的服务器是一个称为named的守护进程。 BIND DNS服务器的配置依赖于几个文本文件。可以用文本编辑器直接生成这些文件或者是从基本模板修改而得到。DNS必须配置的文件包括DNS配置文件(又称引导文件)、DNScache文件、DNS正向查询文件和DNS反向查询文件。,9.7.1 DNS配置文件 BIND的DNS服务器用配置文件na
22、med.conf来包含如下的信息: (1)其他DNS文件所在的路径。 (2)包含因特网根服务器映像的cache文件的名字。 (3)DNS服务器授权的任何主域域名以及包含那个域的资源记录的数据库文件名。 (4)DNS服务器授权的任何次域域名、包含那个域的资源记录的数据库文件名以及对应的主名字服务器的IP地址。,options directory “/etc/db”; ; zone “.” type hint; file “named.cache”; ; zone “” type master; file “named.hosts”; ;,BIND-8.x配置文件named.conf的一个例子。,
23、zone “0.0.127.” type master; file “named.local”; ; zone “85.119.202.” type master; file “named.rev”; ; zone“” typeslave; file“slavenet.njust”; masters 0; ;,9.7.2 DNScache文件,;last update: Aug 22,1997 ;related version of root zone: 1997082200 ;formerly NS.INTERNIC.N
24、ET 3600000 IN NS A.ROOT-SERVERS.NET. A.ROOT-SERVERS.NET. 3600000 A ;formerly NSl.ISI.EDU 3600000 NS B.ROOT-SERVERS.NET. B.ROOT-SERVERS.NET. 3600000 A 07 3600000 NS C.ROOT-SERVERS.NET. C.ROOT-SERVERS.NET. 3600000 A 2 3600000 NS D.ROOT-SERVERS.NET. D.ROOT-SERVERS.NET. 360
25、0000 A 0,DNScache文件包含一系列的根域名服务器。该文件应该随根域名服务器的不断更新而更新。以下是DNScache文件(named.cache)的一个版本。, 3600000 NS E.ROOT-SERVERS.NET. E.ROOT-SERVERS.NET. 3600000 A 0 3600000 NS F.ROOT-SERVERS.NET. F.ROOT-SERVERS.NET. 3600000 A 41 3600000 NS G.ROOT-SERVERS.NET. G.ROOT-SERVERS.NET. 360
26、0000 A 3600000 NS H.ROOT-SERVERS.NET. H.ROOT-SERVERS.NET. 3600000 A 3 3600000 NS I.ROOT-SERVERS.NET. I.ROOT-SERVERS.NET. 3600000 A 7 3600000 NS J.ROOT-SERVERS.NET. J.ROOT-SERVERS.NET. 3600000 A 0 3600000 NS K.ROOT-SERVERS.NET. K.ROOT-SERVERS.NET. 3600000
27、A 29 3600000 NS L.ROOT-SERVERS.NET. L.ROOT-SERVERS.NET. 3600000 A 2 3600000 NS M.ROOT-SERVERS.NET. M.ROOT-SERVERS.NET. 3600000 A 3 ;End of File,9.7.3 DNS正向查询文件,正向查询是指根据主机名查询其IP地址和其他信息。相关的资源记录数据保存在DNS正向查询文件中。一个典型的正向查询区域文件named.hosts的例子: IN SOA . .( 1998030501 ;serial 1
28、0800 ;refresh 3 hours 3600 ;retry 1 hour 604800 ;expire 7 days 86480 ;TTL 1 day ) IN NS . IN NS . . IN A 26 . IN A 27 msrv1 IN A 28 www IN CNAME . ftp IN CNAME . mail IN CNAME . . IN MX 10 . . IN MX 20 .,9.7.4 DNS反向查询文件,DNS反向查询文件提供将一个IP地址转换为主机名的功能。 反向查询区的区域文件是根据IP
29、网络的网络地址决定的。在反向查询区的区域文件里,IP地址是逆序的。 如果一个网络的地址为,则命名其反向查询区为10.。如果网络的地址为,则命名其反向查询区为16.172.。 配置文件名可以是任何名字。为了便于记忆,通常的命名为或named.rev。,在DNS反向查询区域文件中,通常至少配置两个反向查询区域: 环回地址的反向查询区域 该域用的实际网络地址的反向查询区域 地址资源记录要确保包含了所有在网络上经常被访问的主机的地址资源记录。而且要确保SOA、NS或者邮件交换(MX)资源记录中所列举的
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 项目会议纪要与进展跟踪
- 区块链云存储服务项目变更管理办法模板
- 农民合作经营策略作业指导书
- 项目实施进度与计划安排报告
- 江西省港口集团有限公司20242025年度社会招聘【30人】笔试参考题库附带答案详解
- 浙江国企招聘2025杭州海外创新中心有限公司招聘1人笔试参考题库附带答案详解
- 贵州2025年贵州省卫生健康委员会事业单位招聘部分岗位专业调整笔试历年参考题库附带答案详解
- 湖南省益阳市2024-2025学年高二(上)期末历史试卷【含答案】
- 2025年广东省深圳市建文教育集团高考历史二模试卷【含答案】
- 2022年一级造价工程师考试《建设工程造价案例分析(土木建筑工程)》真题及解析
- 2025年阜阳幼儿师范高等专科学校单招职业技能考试题库学生专用
- 2025年安徽工业经济职业技术学院单招职业适应性测试题库附答案
- 2025湖北市政建设集团有限公司管理岗位公开竞聘14人笔试参考题库附带答案详解
- 3.13跨学科主题活动-在线学习小能手 课件 川教版(2024)三年级下册信息科技
- 2024年07月江苏银行招考笔试历年参考题库附带答案详解
- 2023中华护理学会团体标准-注射相关感染预防与控制
- 招贴设计 课件完整版
- 有限空间作业实操评分标准
- 住宅房屋楼层修正系数表
- 高层住宅采暖施工方案有地暖
- 现有厂房内墙面改造施工方案(无尘车间)
评论
0/150
提交评论