返回总站 总站 江阴版 宜兴版
   
   
 
电 话:0510-85802511  85802502
传 真:510-85802502-803
业务咨询:13861793128   联系人:浦俊成  业务QQ :395956435
售后服务电话:13093086187   客服QQ:569670353
   
什么是DNS,提供的服务,WINS
     DNS是一个分布式的数据库, 它是为了定义Internet上的主机而提供的一个层次性的命名系统。利用DNS能进行域名的解析。
    我们已经知道,既可以使用主机名标识一台主机,也可以使用IP地址标识。人们更愿意使用便于记忆的主机名标识符,而路由器则只愿使用长度固定并有层次结构的IP地址。
我们可以通过多种方法来识别一个人。例如,通过出生证明上的姓名,还可以通过社会安全编号、通过驾驶执照编号。尽管这些标识都可以用来识别人,但是在某种背景下会有一种标识比其他的标识更加恰当。例如,IRS(美国的一个税收机构)中的计算机喜欢使用固定长度的社会安全编号而不是出生证上的姓名来标注。另——方面,日常生活中人们喜欢用更好记的出生证上的姓名而不是社会安全编号〔确实,你能想象出如果一个人说“嗨,我的名字是132—67—9875,请找一下我丈夫,178—87—1146”会是何等滑稽的场景)。
因特网中的主机就像人一样能以多种力式标识。标识方法之一是使用主机名(hostname)。主机名(例如cnn.com,www.yahoo.com)是助记性的,人们更愿意使用。然而主机名几乎没有提供关于主机在因特网中的位置信息(主机名为sina.com.cn的主机也许是在中国境内,此外不再有别的位置信息了)。另外,主机名是由可变长度的字母数字字符构成的,路由器处理起来有困难。因此因特网中的主机也使用所谓的IP地址标识。我们将在以后深入讨论IP地址,这里只简单地说明一下。IP地址由4个字节构成,具有严格的层次结构。IP地址一般以点分十进制数格式表示,也就是说所有4个字节都以0—255之间的十进制数表示,bvg1I各个字节之间以点号分隔,例如121.7.106.83。IP地址具有层次结构,当从左到右扫描某个地址时,我们得到关于其主机在因特网中所在位置的越来越明确的信息。这就像从下到上扫描某个邮政地址时,我们得到关于住宅所在位置的越来越明确的信息一样。
DNS提供的服务
    我们已经知道,既可以使用主机名标识一台主帆,也可以使用IP地址标识。人们更愿意使用便于记忆的主机名标识符,而路由器则只愿使用长度固定民有层次结构的IP地址。为调解这两种不同的偏好,我们需要一个把主机名转换成IP地址的目录服务。这就是因特网的域名系统(Domain Name System,DNS)的主要任务。DNS既是一个在由名称服务器主机构成的层次结构中实现的分布式数据库,又是一个允许客户主机和名称服务器主机通信以使用域名转换服务的应用层协议。名称服务器主机通常是运行Berkeley Internet Name Domain(简称BIND)软件的UNIX主机。DNS协议运行在UDP之上,使用端口号53。
   其他应用层协议(例如HTTP,SMTP,FTP)普遍使用DNS把由用户提供的主机名转换成IP地址。作为例子,我们考虑某个用户使用运行在本地主机上的一个浏览器(也就是HTTP客户)请求http://www.yesky.com时会发生什么。为了把HTTP请求消息发送到名为www.yesky.com的web服务器主机,浏览器必须获悉这台主机的IP地址。我们知道,差不多每台主机都运行着DNS应用的客户端。浏览器从URL中抽取出主机名后把它传递给本地主机上的DNS应用客户端。DNS客户于是向某个DNS服务器发出一个包含该主机名的DNS查询消息。DNS客户最终收到一个包含与该主机名对应的IP地址的应答消息。浏览器接着打开一个到位于该IP地址的HTTP服务器的TCP连接。从这个例子中可以看出,DNS给使用它的因特网应用引入了额外延迟(有时还相当大)。所幸的是,正如我们即将讨论的那样.预期的主机名—IP地址对应关系往往高速缓存在就近的DNS名称服务器主机中,从而帮助降低了DNS访问延迟和DNS网络流量。
除了从主机名到IP地址的转换,DNS还提供其他一些重要的服务:
●主机别名(hody aliasing)。具有复杂主机名的主机还可以有一个或多个别名。例如,
主机名为relay1.west-coast.enterprise.com的主机有两个别名:enterprise.com和www.enterprise.com。这种情况下,主机名relay1.west-coast.enterprise.com特称为正规主机名(canonical hostname),另外两个主机名则是别名主机名(alias hostname)。
    别名主机名往往比正规主机名更便于记忆。应用可以调用DNS获取所给定别名主机名的正规主机名和IP地址。
●邮件服务器别名(mail server aliasing)。电子邮件地址显然要求便于记忆。例如,如果Bob有一个hotmail账号,那么他的电子邮件地址可能是简单的bob@hotmail.com。然而hotmail邮件服务器的主机名要比hotmail.com复杂且不易记住。电子邮件应用可以调用DNS获取所给定别名主机名的正规主机名和IP地址。事实上,#DNS允许一个公司的邮件服务器和Web服务器使用相同的别名主机名。例如,某个公司的web服务器和邮件服务器可以都称为enterprise.com。
●负载分担(load distribution)。DNS还越来越多地用于执行在多个复制成的服务器(例如复制成的Web服务器)之间的负载分担。像cnn.com那样的繁忙站点往往把Web服务器复制成多个,每个服务器运行在不向的端系统上,具有不同的IP地址。对于复制成的多个Web服务器,与其单个正规主机名相关联的是一组IP地址。DNS数据库中保存着这组IP地址。客户发出针对映射到一组IP地址的某个主机名的DNS查询后,服务器响应以整组IP地址,不过每次响应的地址顺序是轮转的。既然访问web站点时,浏览器一般把HTTP请求消息发送给内DNS客户否询到的一组IP地址中的第一个,DNS轮转于是把web站点的访问负载分担在所有复制成的服务器上。电子邮件应用也可以使用DNS轮转,这样多个邮件服务器可以有相同的别名。近来,有些公司已经以更为复杂的方式使用DNS提供web内容分发服务。
DNS在RFC 1034和RFC 1035中有详细说明,并在另外若干个RFC中作了更新。DNS是一个复杂的系统,我们只在这儿讨论其操作的关键方面。感兴趣的读者可以参见协议文档。
DNS工作机理概述
   我们就DNS工作机理的讨论将集中在从主机名到IP地址的转换服务上。从客户看来,DNS是一个黑盒子。客户把一个DNS查询消息发送给这个黑盒于,其中指明需要转换成IP地址的主机名。在许多基于UNIX的主机上,应用程序通过调用库函数gethostbyname()发出查询消息。过了从数毫秒到数十秒的一段延迟时间之后,客户收到一个给出所需映射关系的DNS响应消息。因此从客户看来,DNS是一个简单而直接了当的转换服务。然而实现这个服务的黑盒子事实上相当复杂,涉及散布全球的许多台名称服务器主机,以及说明名称服务器和DNS客尸如何通信的一个应用层协议。
DNS可以简单地设计成让单个因特网名称服务器包含所有映射关系。在这种集中式的设计中,客户简单地把所有咨询消息发送给这个惟一的名称服务器,该名称服务器则把响应消息返回给查询的客户。这种设汁尽管具有诱人的简单性,但对于今今的因特网来说却完全不合适,因为其中的主机数非常巨大,而且仍在增长。集中式设计的问题在于:
●单点故障 要是惟一的名称服务器崩溃了,整个因特网也完了。
●巨大访问量 单个名称服务器将不得不处理所有DNS查询消息(因为所有的HITP请求和电子邮件消息都是由数百万台的主机生成的。
●远距离集中式数据库 单台名称服务器主机不可能在所有请求查询的客户主机附近。例如,假设名称服务器在纽约,而所有的查询都来自于地球另一边的澳大利亚,可能要经过缓慢且拥塞的链路。这样造成的远距离访问将导致相当大的延迟。
●维护 单台名称服务器将保存所有因特网主机的记录。这个集中式数据库不仅会相当巨大,而且不得不为每台新增的主机频繁更新。允许任何用户在集中式数据库中注册主机还存在身份认证与授权问题。
总之,存放在单台名称服务器主机中的集中式数据库是不可扩展的。可见DNS必须设计成分布式数据库。实际上,DNS是一个如何在因特网中实现分布式数据库的范例。
为了应对扩展问题,DNS使用以某种层次结构组织的散布全世界各地的大量名称服务器主机。其中没有一个名称服务器拥有因特网中所有主机的主机名—IP地址映射关系。相反,这些映射关系足散布在各个名称服务器上的。近似地说,共有三种类型的名称服务器:局部名称服务器、根名称服务器和权威名称服务器。再近似地说,这些名称服务器本身之间相互作用,并且还和查询主机之间相互作用,如下:
局部名称服务器
    每个ISP一如大学、一个学院中的部门、一个雇员的公司或者一个居民区的ISP———都有一个局部名称服务器(也称为默认名称服务器)。当一台主机发布了DNS查询消息,该消息首先被发送到主机的局部名称服务器上。局部名称服务器上的IP地址通常是在主机中手动设置的(在一台Wlndows机器上可以用你的PC机通过如下过程找到:首先打开控制面板,然后选择“网络”,然后选择己安装的TCP/1P组件,查看它的属性)。局部名称服务器通常是在客户端“附近”的。在一个教育公共机构的ISP情况下,它可能会和客户端主机位于同一个局域网中;对于一个住宅区的ISP来说,名称服务器通常是和客户端主机仅通过少量路由器分隔开来的。如果一个主机为另一属于同一个ISP的主机请求解析,那么局部名称服务器将能够立即提供所请求的IP地址。例如,当主机surf.yesky.com求baie yesky.com的IP地址时,yesky.com的局部名称服务器将不用和任何其他名称服务器联络就能够提供所请求的IP地址。
根名称服务器
   因特网中有十几个左右的根名称服务器,它们目前大多数都位于北美。当一个局部名称服务器无法立即满足一个从主机到来的查询的时候(因为它没有被请求的主机名称记录),局部名称服务器就会作为一个DNS客户端并向根名称服务器查询。如果根名称服务器有该主机的记录,它就会给局部名称服务器发送一个DNS应答消息,并且局部名称服务器给发出查询的主机做以应答。但是根名称服务器可能也没有该主机的记录。相反,根名称服务器知道一个有详细的主机名称映射的“权威名称服务器”的IP地址。
域名解析过程
(a)DNS客户向本地的DNS服务器发出个查询请求
(b)如果该DNS本身具有客户想要查询的数据,专无提业则直接返回给客户, 如果没有,则该服务器和其他命名服务器联系,从其他服务器上获取信息,育然后返回给用户。
(c) 最不妙的情况是,提本地的DNS服务器查询了所有其他的命名服务器,获得用户要查询的信息。
DNS和WINS的集成
   我们知道DNS是静态的配置,而WINS完全是动态的;DNS能用于非Microsoft客户,而WINS不行。将DNS和WINS集成起来,充分利用各自的优越性,使得域名解析过程更完美。
  通过DNS和WINS的集成能实现“动态的DNS”,其基本原理为:由DNS解析较高层的域名,而将解析的结果传给WINS,并由WINS得到最终的IP地址。WINS将解析结果传给客户,好象是DNS服务器处理了整个解析过程一样。
 
 
 
 
关于我们  相关知识  |  典型案例 代理合作 联系我们 客服中心
版权所有©时创网络江阴网站建设 kvov信息发布平台