Zeroconf 与 UPnP 技术研究.doc
精品论文Zeroconf 与 UPnP 技术研究李志鹏1 曹艺坪2 温向明11北京邮电大学信息与通信工程学院,北京 (100876)2信息产业部电信研究院,北京 (100083)E-mail:zhpengli摘 要:网络设备的大量出现在带给我们很大方便的同时也带来了网络终端配置复杂的问题,Zeroconf 技术与 UPnP 技术的出现正是为了解决这个问题,通过使用 Zeroconf 或 UPnP 技术可 以实现终端在不需要人工干预的情况下接入网络并自动进行诸如 IP 地址配置、相关服务的发现 等操作,从而达到网络终端设备的零配置目的。本文将对二者的协议结构、工作过程等方面做 以详细研究及对比,并在此基础上给出结论。关键字:ZeroconfUPnP零配置服务发现 中图分类号:TP3931.引言随着网络技术的发展,越来越多的网络设备大量出现,但是网络设备普遍存在的配置复杂 的问题却在一定程度上限制了设备更大范围的应用。那么一台网络设备能否像台灯那样,接上 电源,打开开关后就能够正常工作呢?这就需要有一种自动配置或者是零配置技术的出现。2.零配置技术介绍当前终端的零配置技术主要有IETF零配置工作组提出的Zeroconf技术1、Sun公司提出的Java智能网络基础设施(Jini)技术2以及UPnP论坛提出的通用即插即用(UPnP)技术3等。IETF 为实现网络的零配置目标而于 1999 年 9 月成立了零配置工作组,并于当年 11 月份召 开了第一次工作组官方会议,Zeroconf 技术正是由该工作组提出的, 其目标是在网络设备不需要进行任何手工操作以及其它服务(DHCP、DNS)等的支持下,通过自动配置自动组网并正常工作。UPnP 技术是由 UPnP 论坛制定,该论坛是由微软、英特尔等公司于 1999 年 10 月份发 起创建,UPnP 技术是针对局域网范围内的对等设备互联而设计的一种技术,其目的与 Zeroconf技术类似,是为家庭、小型企业、公共场所提供基于 IP 技术、易于使用的网络服务自动发现机 制,同时提供互连设备的远程操作控制和信息共享。Jini 技术基本思想是将 Java 应用环境从单一主机的虚拟机向网络化发展,通过由 Java 语言定义的接口来实现编程,其更接近于一种分布 式的应用程序接口及对象应用环境,这里不再对其进行详细分析。接下来,本文将会对 Zeroconf和 UPnP 技术的做进一步的研究,并在此基础上对二者做以比较在最后给出结论。3.Zeroconf技术3.1 结构Zeroconf技术是IETF Zeroconf工作组专门提出的用于终端零配置的技术,从功能上来讲, 它可以被划分为三个部分,即本地IP地址的自动获得、多播DNS技术(mDNS)4、基于DNS 的服务发现技术(DNS-SD)56等。其中,mDNS和DNS-SD被用于实现服务发现与定位。3.2 工作过程简单来讲,Zeroconf 技术通过两个过程就可以实现零配置组网的目标:本地 IP 地址的自动 获得、服务的发现与定位,其中服务发现与定位过程使用了 DNS-SD 来完成服务的发现,使用了 mDNS 来完成域名到 IP 地址的转换即服务的定位。第一步:本地 IP 地址的自动获取。为了自动获取 IP 地址,Zeroconf 并不要求网络中有 DHCP 服务器。在没有 DHCP 服务器的情况下,设备可以使用链路-本地 IP 地址,首先设备会使用一 定的算法选择一个 169.254.1.0 到 169.254.254.255 范围内的 IP 地址,选定 IP 地址之后,设备通5精品论文过发送一个 ARP 探测消息来检查该 IP 地址是否已经有人使用。这个 ARP 探测消息是一个 ARP 请求,在这个请求中源 MAC 地址使用该设备的 MAC 地址,把源 IP 地址和目标 MAC 置为空, 把目标 IP 置为这个刚刚选中的 IP 地址,之后设备开始侦听是否有别的设备已经使用了该 IP 地 址。如果设备侦听到一个源 IP 地址是该所选择地址,但是源 MAC 地址与自己的 MAC 地址不 同时,这意味着已经有别的设备使用了该地址。这时该设备可以通过:1,立即换用别的本地链路 IP;2,如果此时设备已经建立 TCP 连接或由于其他原因需要继续使用这个 IP 地址,那么它就 需要在收到 IP 冲突的 ARP 消息一段时间后通过广播一个源 MAC 是自己 MAC 地址,源 IP 是自己想保留的 IP 地址的 ARP 消息来尝试保留这个 IP 地址。如果设备在这之后又收到了 IP 冲突 的 ARP,则该设备必须立即更换一个新的本地链路 IP 地址。在选定使用某个 IP 地址后,设备再通过发送源 IP 地址和目标 IP 地址都是这个已选定的 IP 的 ARP 消息来告知其他设备不要再尝 试使用这个地址,并且这样做也可以告知其他设备来更新他们的 ARP 表。第二步:服务发现与定位。Zeroconf使用mDNS4来实现域名到IP地址的转换。首先,在局 域网内的设备具有了本地链路IP地址之后,设备就可以使用一个以.local.为前缀的本地域名,这个本地域名只是在设备所在的局域网内有效,而且只是在当前时刻有效。如果在其他LAN内或 者在本LAN内的不同时间见到同样一个本地域名,这都不代表这个设备与之前见到的设备有任何关系。本地链路上的每一台设备在多播DNS端口 53537侦听,而需要查询本地域名的设备则向多 播DNS地址 224.0.0.251(IPv4)7/FF02:FB(IPv6)8发送mDNS查询包,如果所查询的本地域名与正 在侦听的某台设备一致,则这台设备就会回应。由于本地域名可能会改变,在某一时刻得到的 查询结果可能已经不是最新的了,所以查询设备时还需要通过不断的发送mDNS查询包来实时 更新查询结果。为了防止发送大量的mDNS查询包引起网络的拥塞,要求mDNS查询包发送时间 间隔要长,比如一个小时发送一次。但是这样的话,如果有了新的设备在本次查询刚刚结束时 增加进来,下一次查询将会是在一小时之后,这样这台新加入的设备必须在一小时之后才能被 发现,这样做肯定不行。所以每台新加入网络的设备需要在加入网络后通过多播一个mDNS响 应消息来宣告自己进入网络。另外,mDNS查询及响应都使用的是多播,这样看似增加网络的 流量,但实际上对于多播回应,网络中其他设备都会收到,并且记录结果,在以后需要的时候 就不必再进行查询了。Zeroconf 使用了 DNS-SD 来实现服务的发现。DNS-SD 并不是一个专门的协议,它的消息 结构与普通 DNS 消息一样,只是 DNS-SD 查询消息中并不是使用的“Type=A”这样的查询类 型,而是使用了 SRV 与 PTR 的查询类型。DNS-SD 通过查询某一服务类型来获取所有关于该类 服务的信息,服务类型使用的是 IETF RFC2782 中所定义的 SRV 类型,设备通过发送查询请求 类型为 PTR 的 DNS 查询请求,来得到关于某个服务类型的所有 PTR,每个 PTR 指向一个提供 某项服务的 DNS 记录。通过使用该 DNS 消息就可以实现查询某个服务类型的目的。首先DNS-SD 客户端发出 PTR 查询消息来查询某种服务类型,例如:_http._tcp.local 或_http._tcp.dns-sd.org如果网络上有所查询的服务,则会返回一条或多条 PTR 记录,例如:032Zeroconf._http._tcp.dns-sd.orgDNS-SD 中服务类型可以有子类型,比如可以通过使用查询:_news._sub ._http._tcp.dns-sd.org来更精确的查找一个符合更多条件的服务。另外,Zeroconf还利用了动态DNS-UL、DNS-LLQ以及NAT-PMP等1技术来支持WAN范围 内的零配置机制。4.UPnP技术4.1 结构UPnP(Universal Plug and Play)39技术扩展了应用于计算机外设中Plug and Play(PnP)技术, 它将网络中的设备包括了进来。支持UPnP技术的网络设备可以实现动态地加入一个网络并自动 获得IP地址、告知别的设备自己的能力和服务并且获知网络上其他设备的能力和服务等。UPnP 技术是建立在TCP/IP协议之上的,使用了IP、UDP、TCP、HTTP、XML、SOAP、GENA等网 络协议与技术,使用UPnP建立起来的网络不需要设备驱动,不使用特定的API,与介质无关。 UPnP 结构中包括了控制点、服务和设备,服务和控制点属于逻辑上的概念,一台设备可能会包含有零或多个服务,也可以包括控制点,它的协议栈如下表所示:表 1 UPnP 协议栈UPnP 设备商自己的定义UPnP 论坛专业委员会的设备定义UPnP 设备体系定义SSDPSOAPGENAHTTPMUHTTPUHTTPHTTPUDPTCPIP 层其中,第一层是 IP 层,所有的消息都是基于 IP 传送的,第二层和第三层属于传送层,传送的内容经过 XML 封装后使用 UDP 之上的 HTTPU/HTTPMU 协议或 TCP 之上的 HTTP 协议传送, 而第四层中的 SSDP、SOAP、GENA 正是所传送内容的数据格式;再上一层则是 UPnP 论坛专业委员会定义的厂商相关信息;设备体系定义是一个抽象的公用模型,所有的设备都要使用到 这一层;最上层则是 UPnP 设备制造商的自己进行的一些定义,包括特定的厂商信息等。下面一节中将会对 UPnP 的详细工作过程做以说明。4.2 工作过程UPnP整个工作过程分为六个阶段9,包括设备IP寻址、服务发现、设备和服务的描述、设 备控制、事件和服务呈现。第一步,获取 IP 地址。IP 地址是 UPnP 的基础,一台网络设备可以通过 DHCP 来获取一个IP 地址,设备进入网络后,首先尝试使用 DHCP 方式获取 IP 地址,如果 DHCP 获取方式失败, 设备就开始使用 Auto-IP 技术来获取一个链路-本地 IP 地址。Auto-IP 技术与上述的 Zeroconf 中链路-本地 IP 地址自动获得过程是一样的,这里就不再赘述。第二步,服务发现。获取 IP 地址之后就开始发现过程,UPnP 使用 SSDP 来进行服务发现,SSDP 是 UPnP 提出的专门用于服务发现的一个协议。SSDP 使用了两种方法:M-SEARCH 和NOTIFY,在 HTTP 请求中,M-SEARCH 被用来发现设备或者控制点,NOTIFY 方法被用来告 知设备或控制点的加入网络或离开网络。当有设备加入网络或离开网络时,设备的 SSDP 服务通过向网络多播发送一个 NTS 值为ssdp:alive 或 ssdp:byebye 的 NOTIFY 消息来告知网络中其他设备。当有控制点进入网络时,控 制点可以通过发送消息类型为 M-SEARCH 设备搜索消息来得到他感兴趣的设备的信息。这个搜索消息包括了值为 ssdp:discover 的头域和搜索目标类型以及延迟时长 MX;如果需要搜索网络上的所有设备,控制点可以发出一个 ST 值为 ssdp:all 的 M-SEARCH 消息。 当网络中有设备收到 M-SEARCH 消息后,如果这个 M-SEARCH 消息的 ST 头域值为 ssdp:all、ssdp:rootdevice,或者与自己的 UUID 相同的 UUID 值时,该设备就需要对这个 M-SEARCH 消 息进行回应了。回应消息除了消息头为 HTTP/1.1 200 OK,以及除了 NOTIFY 宣告消息中头域NT 在这里是 ST 以外,其他的头域如 CACHE-CONTROL、LOCATION、USN 等都与 NOTIFY宣告消息一致。 第三步,设备和服务描述。当一个控制点发现了网络中的一台设备后,控制点对这台设备的信息知道的还不是很多,这就需要控制点通过使用发现阶段得到的这台设备的 URL 来和这台设备进行交互并尝试获得更多的该设备及该设备所提供的服务的详细描述。UPnP 关于一台设备 的描述分为两个部分:设备描述和服务及能力的描述。UPnP 设备描述包含了厂商信息、序列号等,包括了该设备提供的所有服务列表、每个服务 的服务描述、控制 URL、事件 URL 等。设备描述是由每个设备厂商来写的,厂商在写这些设 备描述的时候应当使用 XML 语言并按照 UPnP 论坛专业委员会定义好的设备描述模板来写。服务描述包括了命令列表、动作列表、每个命令的参数等,它包括了一系列的变量,通过 使用这些变量以及这些变量的数据类型、范围等定义了在服务运行过程中的状态。服务描述也是由设备制造商使用 XML 语言并按照 UPnP 论坛专业委员会定义的服务描述模板来写的。控制点可以通过发送一个请求 URL 为发现过程中得到的设备或服务描述 URL 的 HTTP GET 请求来获取设备的设备描述或服务描述。第四步,设备控制。当控制点知道了设备及其服务描述后,控制点就可以调用一些控制动 作并接收这些动作的结果。调用服务的动作是一个远程调用过程,控制点通过向某一服务的控制 URL 发送一个控制请求来调用服务,并让服务进行特定的动作,这些控制 URL 是在设备描 述中关于服务的控制 URL 子集中提供给控制点的。控制请求是通过使用 HTTP POST 请求或者HTTP M-POST 请求及回应来传送以 SOAP 格式封包的动作或结果。UPnP 论坛专业委员会和设 备厂商已经定义了一些控制来使得控制点可以很明确的知道当前服务的状态。第五步,事件。当服务的状态发生改变时就产生一个事件,如果某个控制点订阅了这个事 件,则服务就会将该状态改变上报给控制点。为了订阅某个事件,控制点需要首先向服务发送一个订阅消息,订阅消息使用了 SUBSCRIBE 请求头,如果订阅请求被接受,则事件产生方(一 般是设备)会回应一个订阅超时时长以及一个 SID(订阅 ID)。如果订阅者不再需要这些事件时,它可以发送一个取消订阅的消息给事件提供者,取消订阅消息使用UNSUBSCRIBE 请求头, 并带上需要取消的 SID。事件消息使用 NOTIFY 请求头告知事件订阅者,每一个事件消息的消息体中包含了一个或多个状态变量的名字以及当前这些状态变量的值,这些名字和值也是用 XML 语言描述的。第一次订阅成功时,事件提供者会发送一个初始事件消息,这个初始事件消 息中包含了所有变量的名字以及变量值,订阅者就可以通过它来初始化该服务的状态模型了。第六步,服务呈现。呈现属于 UPnP 的可选功能,当设备加入网络并获取地址、对它感兴 趣的控制点发现了该设备并获取了该设备的服务描述和设备描述以及获取设备所能提供的能力后,就可以将其展示给用户了。当一个设备提供了描述 URL,控制点就可以通过这个 URL 获 取一个页面,并将这个页面载入到浏览器中提供给用户,用户就可以通过该页面来控制设备或者读取设备的状态信息等。5.Zeroconf与UPnP对比通过上述对二者结构、工作过程等的分析,我们可以看到,在 IP 地址的获取上,Zeroconf 和 UPnP 技术是完全一样的;在域名到 IP 地址的转换上,Zeroconf 使用的是 mDNS 技术,而 UPnP 没有与之对应的技术,一般情况下,如果需要直接访问某台设备时,Zeroconf 可以通过访 问设备的本地域名来访问这台设备或者服务,而 UPnP 就需要使用 IP 地址,而这个所使用的 IP 地址可能是从设备描述中得来的,也可能是由专门的域名转换系统(比如 DNS)得来,但由于 这个地址可能会变化,所以有时候 UPnP 这么做就行不通;服务发现与定位过程中,Zeroconf 使用的是 mDNS/DNS-SD 来进行服务发现的,使用了统一的 SRV 定义,UPnP 使用的是 SSDP 协议来进行服务发现,在 UPnP 采用 SSDP 作为服务发现协议的时候,该协议还没有完成,并 且后来由于该协议自身的复杂性使得在网络条件差(比如 802.11 无线网络环境中丢包率过大) 时不能保证其可靠性以及其它方面的原因,SSDP 并没有公开发表而是被取消了,而由于 mDNS/DNS-SD 的有效性以及使用了重复查询压缩等功能,Zeroconf 就不存在这方面的问题。 在应用层,Zeroconf 并不关心用户使用什么样的应用层协议,它只是通过使用 IP 自动获得、 mDNS/DNS-SD 的服务发现来提供一个可靠的、自动配置的网络,对于这一层面 Zeroconf 并没 有做任何规定与说明,用户可以根据自己的需要使用自己的应用层协议;而这一层恰恰正是 UPnP 所最关心的,它定义了大量的设备类型、服务类型,定义了如何去描述一个服务、如何去 调用一个服务等。6.结论从上述分析可以看出,单纯说 Zeroconf 与 UPnP 是两种互相竞争的技术是不全面的。首先, Zeroconf 与 UPnP 在某些层面上是相同或相似的,比如二者都使用了相同的链路-本地 IP 地址获 得方式;在某些层面上又存在不同或竞争的一方面的,比如在服务发现上前者使用的是 mDNS/DNS-SD 方式,而后者使用的是 SSDP 方式;其次二者的侧重点不同,前者的侧重点是 为了解决普遍性的问题,即不管设备类型与应用层协议,通过 Zeroconf 技术可以提供一个零配 置后就能使用的可靠的网络,后者侧重点是为了解决特定的问题,除了解决网络零配置中提到 的 IP 地址获得、服务发现定位等,还重点规定了针对具体设备类型的具体操作与控制。Zeroconf 给出了一个如何在不需要人工干预或其它服务的协助下网络实现自动配置的方法,利用这个方 法用户可以开展自己的应用,使用自己的应用层协议等,Zeroconf 给出的是一个水平意义上的 零配置技术;而 UPnP 更像是一套完整的工业标准,它指出了用户开展自己 UPnP 应用的具体 途径,它给出的是一个垂直层面上自上而下的解决方法。参考文献1 Stuart Cheshire, Daniel H. Steinberg, Zero Configuration Networking, The Definitive Guide, O'Reilly, 2005 2 SUN Microsystems, Inc. Jini Network technology, 20013 UPnP Forum, UPnP Device Architecture V1.0, 2006.74 IETF draft, draft-cheshire-dnsext-multicastdns-06.txt, 2006.8 5 IETF draft, draft-cheshire-dnsext-dns-sd.txt, 2006.86 IETF RFC 2782, A DNS RR for specifying the location of services (DNS SRV), 2000.2 7 http:/www.iana.org/assignments/multicast-addresses8 http:/www.iana.org/assignments/ipv6-multicast-addresses9 http:/www.upnp.org/download/UPnP_Vendor_Implementation_Guide_Jan2001.htmResearch of Zeroconf and UPnPLi Zhipeng1, Cao Yiping2, Wen Xiangming11 Department of Information and Communication Engineering, Beijing University of Posts andTelecommunications, Beijing, PRC, (100876)2 China Academy of Telecommunications Research of Ministry of Information Industry, Beijing, PRC, (100083)AbstractThe great amount of network devices provides a great convenience to us, at the same time, it also brings theissue of complex network terminal configuration. The emergence of Zeroconf and UPnP is to solve this problem. Using Zeroconf and UPnP, terminals can access the network and automatically complete some operations such as IP configuration, discovery of related services without artificial interference, so as to achieve the objective of zero configuration. This paper will give conclusion on the basis of the research and compare to these two techniques protocol structures and work processes.Keywords: ZeroconfUPnP Zero ConfigurationService Discovery