CN106576118B - 基于dns的动态服务发现 - Google Patents

基于dns的动态服务发现 Download PDF

Info

Publication number
CN106576118B
CN106576118B CN201580040777.3A CN201580040777A CN106576118B CN 106576118 B CN106576118 B CN 106576118B CN 201580040777 A CN201580040777 A CN 201580040777A CN 106576118 B CN106576118 B CN 106576118B
Authority
CN
China
Prior art keywords
dns
query
computing device
metadata
services
Prior art date
Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
Active
Application number
CN201580040777.3A
Other languages
English (en)
Other versions
CN106576118A (zh
Inventor
拉尔夫·多莫斯
蒂莫西·P·多纳休
Current Assignee (The listed assignees may be inaccurate. Google has not performed a legal analysis and makes no representation or warranty as to the accuracy of the list.)
Cisco Technology Inc
Original Assignee
Cisco Technology Inc
Priority date (The priority date is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the date listed.)
Filing date
Publication date
Application filed by Cisco Technology Inc filed Critical Cisco Technology Inc
Publication of CN106576118A publication Critical patent/CN106576118A/zh
Application granted granted Critical
Publication of CN106576118B publication Critical patent/CN106576118B/zh
Active legal-status Critical Current
Anticipated expiration legal-status Critical

Links

Images

Classifications

    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L61/00Network arrangements, protocols or services for addressing or naming
    • H04L61/45Network directories; Name-to-address mapping
    • H04L61/4541Directories for service discovery
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L41/00Arrangements for maintenance, administration or management of data switching networks, e.g. of packet switching networks
    • H04L41/12Discovery or management of network topologies
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L61/00Network arrangements, protocols or services for addressing or naming
    • H04L61/45Network directories; Name-to-address mapping
    • H04L61/4505Network directories; Name-to-address mapping using standardised directories; using standardised directory access protocols
    • H04L61/4511Network directories; Name-to-address mapping using standardised directories; using standardised directory access protocols using domain name system [DNS]
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L61/00Network arrangements, protocols or services for addressing or naming
    • H04L61/50Address allocation
    • H04L61/5076Update or notification mechanisms, e.g. DynDNS

Landscapes

  • Engineering & Computer Science (AREA)
  • Computer Networks & Wireless Communication (AREA)
  • Signal Processing (AREA)
  • Computer And Data Communications (AREA)
  • Information Transfer Between Computers (AREA)
  • Telephonic Communication Services (AREA)

Abstract

用于执行动态DNS‑SD的技术被提供。在实施例中,装置包括:一个或多个数据库;一个或多个收发器,用于从第一计算设备接收第一域名系统(DNS)查询,第一DNS查询定义第一服务发现名称空间;以及一个或多个处理器,与一个或多个数据库和一个或多个收发器中的每项进行通信。一个或多个处理器生成与第一计算设备相关联的第一元数据并将其附加于第一DNS查询。一个或多个收发器将第一DNS查询和第一元数据发送到域名系统(DNS)服务器计算机,从DNS服务器计算机接收响应于第一DNS查询的第一响应,并将第一响应中继到第一计算设备。

Description

基于DNS的动态服务发现
相关申请的交叉引用
本申请要求于2014年7月30日提交的美国专利申请No.14/447,475的优先权,针对如本文充分阐述的所有目的,该申请的全部内容通过引用结合于此。
技术领域
本公开涉及通信网络。更具体地,本公开涉及用于基于域名系统(DNS)来执行动态服务发现的计算机实现的技术。
背景技术
本节描述的方法是可被推行的方法,但不必是之前已被构思或推行的方法。因此,除非另有说明,否则不应假设本节描述的任何方法仅由于它们被包括在本节中而作为现有技术。
域名系统(DNS)查询通常用于获取与特定域名相对应并与网络中的特定设备相关联的互联网协议(IP)地址。标准DNS查询还可辅助服务发现。标准DNS查询可被理解为网络或域中可用的期望服务的发现实例。该类型的服务发现被称为基于DNS的服务发现(DNS-SD)。
响应于与DNS-SD相关联的DNS查询,做出响应的计算机提供域中能够提供由做出请求的设备所指定的期望服务的设备实例的列表。做出请求的设备在DNS查询中指定期望服务的类型、以及做出请求的设备寻找该服务的特定域。例如,做出请求的设备可能正在寻找其本地网络中的打印机服务,并且可发送DNS查询以找出网络中可用的打印机服务。若第二设备也做出相同的DNS查询,则相同的设备实例的列表被返回到该第二设备;相同的DNS查询通常返回相同的响应。一旦做出请求的设备已获取可用的打印机服务的列表,则它可提供后续DNS查询以正确地找出如何联系该服务(例如,经由提供服务的设备的名称和/或IP地址)。
然而,可能实际上并非响应列表中的每个设备实例都与做出请求的设备有关或对于做出请求的设备有用。例如,若做出请求的设备位于地理上较大的校园域(包括建筑A到Z)的建筑A中,则接收建筑A到Z中的打印机使能实例的列表可能超过做出请求的设备需求。做出请求的设备的用户将不太可能打印到位于建筑A之外的打印机使能实例。
附图说明
在附图中:
图1根据某些实施例示出了用于执行动态DNS-SD的示例系统;
图2根据某些实施例示出了用于在图1的系统中执行动态DNS-SD的示例流程图;
图3根据某些实施例示出了示例框图,该示例框图示出了关于包括在图1的系统中的动态服务发现合成器的额外细节;
图4示出了示例计算机系统的框图,本公开的实施例可在该示例计算机系统上被实现。
示例实施例
在下列描述中,为了解释的目的,许多特定细节被阐述以便提供对本公开的透彻的理解。然而,将显而易见的是,本公开可在没有这些特定细节的情况下被实施。在其他实例中,公知的结构和设备以框图形式被示出,以便避免不必要地模糊本公开。
1.0概览
在实施例中,装置包括:一个或多个数据库;一个或多个收发器,用于从第一计算设备接收第一域名系统(DNS)查询,第一DNS查询定义第一服务发现名称空间;以及一个或多个处理器,与一个或多个数据库和一个或多个收发器中的每项进行通信。一个或多个处理器生成与第一计算设备相关联的第一元数据并将其附加于第一DNS查询,第一元数据的至少一部分从一个或多个数据库被获取。一个或多个收发器执行下述操作:将第一DNS查询和第一元数据发送到域名系统(DNS)服务器计算机;从DNS服务器计算机接收响应于第一DNS查询的第一响应,该第一响应包括对一个或多个服务的标识,该一个或多个服务根据与第一计算设备相关联的第一元数据和第一DNS查询来提供第一服务发现名称空间的子集中的计算设备;以及将第一响应中继到第一计算设备。
在实施例中,数据处理方法包括:在域名系统(DNS)服务器计算机处接收第一计算设备所生成的基于域名系统的服务发现(DNS-SD)查询;基于与第一计算设备相关联的元数据和DNS-SD查询来从DNS资源记录动态地选择提供计算设备的一个或多个服务;使用DNS服务器计算机来合成与被动态地选择的提供计算设备的一个或多个服务相对应的查询响应,该查询响应包括与被动态地选择的提供计算设备的一个或多个服务相关联的指针(PTR)资源记录;使用DNS服务器计算机来将查询响应发送到第一计算设备;以及其中,方法通过一个或多个计算设备被执行。
在实施例中,非暂态计算机可读数据存储介质存储一个或多个指令序列,该指令序列当由一个或多个处理器执行时使得执行方法,该方法包括:在域名系统(DNS)服务器计算机处接收第一计算设备所生成的基于域名系统的服务发现(DNS-SD)查询;基于与第一计算设备相关联的元数据和DNS-SD查询来从DNS资源记录动态地选择提供计算设备的一个或多个服务;合成与被动态地选择的提供计算设备的一个或多个服务相对应的查询响应,该查询响应包括与被动态地选择的提供计算设备的一个或多个服务相关联的指针(PTR)资源记录;以及将查询响应发送到第一计算设备;
2.0结构&功能示例
在实施例中,程序化方法使用标准域名系统(DNS)查询来使能执行基于域名系统(DNS)的动态服务发现(DNS-SD)。希望发现特定服务类型的可用实例的列表的设备生成标准DNS-SD查询。DNS-SD查询经由至少一个中继机器或计算机被发送到DNS服务器。描述做出请求的设备或与做出请求的设备相关联的元数据还通过DNS-SD查询被提供给DNS服务器或在DNS服务器处被提供。元数据可由做出请求的设备、中继机器、和/或DNS服务器来生成。在实施例中,DNS服务器基于与设备相关联的元数据在DNS-SD查询中所指定的域内执行特定服务类型的实例的动态发现;因此,在某些实施例中,元数据可能是搜索范围或发现响应中所返回的相关数据的范围上的约束的来源。在其他实施例中,DNS服务器基于与做出请求的设备相关联的元数据和预定义选择规则在DNS-SD查询中所指定的域内执行特定服务类型的实例的动态发现。元数据包括与设备相关联和/或描述设备的一个或多个特性、账户、用户、或环境。预定义选择规则包括可以不必特定于设备的额外的实例选择约束。在其他实施例中,设备用来执行服务发现的搜索域由来自DNS服务器的响应来配置,这些响应自身是基于与做出请求的设备和/或服务发现浏览器相关联的元数据被选择的。
本文描述的动态DNS-SD技术可提供进行查询的设备中的服务发现浏览器使用同一查询的潜在不同的搜索域列表来被自动地配置的方法。甚至在不改变服务发现浏览器或DNS-SD查询的情况下,本文描述的动态DNS-SD技术提供将服务发现灵活地限制于DNS-SD查询中实际定义的域的子集或特定逻辑域的方法。因此,不同服务发现浏览器发布的同一DNS-SD查询或同一服务发现浏览器在不同时间发布的同一DNS-SD查询可能返回不同的查询响应。若两个不同的设备做出相同的查询,则两个设备中的每个设备可能接收不同的实例列表,这是由于与两个设备中的每个设备相关联的元数据可能是彼此不同的。若处于两个不同设备状态的同一设备做出同一查询,则查询还可使得每次返回不同的实例列表。特定设备状态被反映在与做出请求的设备相关联的元数据中。
对实施例的各种修改对于本领域技术人员将是非常显而易见的,并且在不脱离本公开的精神和范围的情况下,本文定义的一般原理可被应用于其他实施例和应用。此外,在下列描述中,许多细节为了解释的目的被阐述。然而,本领域普通技术人员将认识到,本公开的实施例可在不使用这些特定细节的情况下被实施。在其他实例中,公知的结构和处理未以框图形式被示出,以便避免不必要的细节模糊本公开的描述。因此,本公开不旨在被限制于所示出的实施例,而是被赋予与本文公开的原理和特征相一致的最广泛的范围。
图1根据某些实施例示出了辅助动态DNS-SD技术的示例系统100。系统100包括DNS服务器102、数据库106、动态主机配置协议(DHCP)服务器108、中继器(relay)110、数据库112、一个或多个设备114、一个或多个实例118、以及网络120。DNS服务器102、数据库106、DHCP服务器108、中继器110、以及实例118的至少一个或多个实例中的每项与网络120有线或无线通信。设备114、数据库112、以及实例118的至少一个或多个实例中的每项与中继器110直接或间接地有线或无线通信。
DNS服务器102包括被配置为经由网络120与数据库106、DHCP服务器108、和/或中继器110进行通信的一个或多个服务器、计算机、处理器、或数据库。DNS服务器102可位于一个或多个地理上分布的位置。DNS服务器102存储并维护多个DNS资源记录(RR),该多个RR将域名映射到互联网协议(IP)地址和互联网协议版本6(IPv6或IP6)地址。DNS RR还包括关于与指针(PTR)记录、服务定位器(SRV)记录、文本(TXT)记录等中的IP/IP6地址相关联的相应资源的信息。DNS RR还可被称为DNS-SD记录或DNS-SD RR,并且RR还可被称为记录。关于DNSRR的额外细节在2013年2月的互联网工程任务组(IETF)、请求注解(RFC)6763,DNS-BasedService Discovery(基于DNS的服务发现)(以下称为“RFC 6763”)中被提供。DNS服务器102包括用于辅助动态DNS-SD技术的实现的动态服务发现合成器104(在下面被详细讨论)。如在下面详细讨论的,DNS服务器102处理DNS查询。
数据库106包括用于存储DNS服务器102所使用的数据和/或指令的一个或多个数据库或存储设备。数据库106可包括DNS RR、与DNS RR相关联的额外数据(无标准记录已被定义)、或与所映射的资源相关联的其他信息中的至少一些。数据库106被配置为经由网络120与DNS服务器102进行通信。替代地,数据库106可以在不使用网络120的情况下与DNS服务器102进行通信。在某些实施例中,当DNS服务器102能够存储所有DNS相关数据时,数据库106可以是可选的。在某些实施例中,数据库106可被包括在DNS服务器102中。
DHCP服务器108包括被配置为将IP地址分配给新的资源并创建与新分配相对应的DNS RR的一个或多个服务器、计算机、处理器或数据库。在分配处理期间,DHCP服务器108还可获取或确定关于补充DNS RR的资源的额外信息。例如,所有权信息可被获取。一旦分配被完成,则DNS RR被发送到DNS服务器102以辅助DNS查询的处理。补充DNS RR的数据可被维护在DHCP服务器108上、被发送到DNS服务器102、和/或被发送到数据库106。DHCP服务器108经由网络120与DNS服务器102进行通信。替代地,DHCP服务器108可以在不使用网络120的情况下与DNS服务器102进行通信。
中继器110包括一个或多个中继代理。可被用在各个实施例中的中继代理的示例包括路由器、交换机、网关、防火墙、转发器(repeater)等。在实施例中,中继器110用作设备114经由网络120到DNS服务器102的中介。中继器110辅助其本地网络中的数据通信的流量监测和管理。中继器110包括数据库和/或与外部数据库(例如,数据库112)进行通信,以便在将所接收的数据转发到预期的接受者之前潜在地分析、处理、格式化信息和/或将信息附加于所接收的数据。中继器110经由到设备114中的每个设备的有线和/或无线连接进行通信。中继器110经由网络120与DNS服务器102进行通信。
设备114包括计算设备。可被用在各个实施例中的设备114的示例包括工作站、个人计算机、通用计算机、膝上型计算机、互联网设备、手持设备、无线设备、有线设备、便携式设备、可穿戴计算机、蜂窝或移动电话、便携式数字助理(PDA)、智能电话、平板计算机、多处理器系统、基于微处理器的或可编程的消费性电子产品、游戏机、机顶盒、网络PC、小型计算机等。设备114中的每个设备包括应用、软件、或指令以辅助本文描述的动态DNS-SD。在实施例中,设备114中的每个设备托管或执行服务发现浏览器116,该服务发现浏览器116被配置为以本文进一步描述的方式来处理DNS请求。设备114还可包括额外的应用或其他必要的接口能力以便与DNS服务器102、中继器110、和/或实例118中的一个或多个实例进行通信。设备114可彼此和/或与中继器110在地理上分散布置。为了示出清楚示例的目的,两个(2)设备114在图1中被示出,但在其他实施例中,任意数目的设备可被包括在系统100中。设备114还被称为客户端、主机、做出请求的设备、做出请求的客户端、做出请求的主机、做出请求的机器、请求者等。
实例118包括能够提供设备114所请求的一个或多个服务(或一个或多个类型的服务)的计算设备,包括但不限于:打印机、传真机、扫描仪、影印机、显示器、投影仪、电视、机顶盒、游戏机、多媒体消费设备、视频输出设备、音频输出设备、存储设备、输入设备、输出设备、网络服务设备、网络管理系统、SDN控制器、移动控制器、认证服务器、时间服务器、物联网类型设备、恒温器、照明开关、冰箱、洗碗机、咖啡机、洗衣机、烘干机、建筑安全控制器、住宅或商业建筑电器、或其他服务提供设备。在某些实施例中,实例118可包括服务请求设备和对应的服务提供设备(设备114)。在其他实施例中,设备114和实例118中的每项可请求服务以及向设备114和实例118中的其他项提供服务。实例118中的每个实例包括应用、软件、或指令以辅助本文描述的动态DNS-SD以及与DNS服务器102、中继器110、和/或一个或多个设备114进行通信。实例118还被称为客户端、设备、服务提供设备、服务提供客户端、服务提供商、目标、目标设备等。
图1示出了两(2)组实例118,第一组是在中继器110的有线或无线通信范围内并且第二组是在网络120的有线或无线通信范围内。第一组实例118以及设备114可包括本地网络中的设备,而第二组实例118可包括在本地网络之外的、但设备114经由中继器110和网络120仍可访问的设备。
网络120包括通信网络,例如,局域网(LAN)、无线LAN(WLAN)、广域网(WAN)、无线WAN(WWAN)、城域网(MAN)、自组网、内联网、外联网、虚拟专用网(VPN)、互联网的一部分、互联网、公用交换电话网(PSTN)的一部分、或蜂窝网络的任意组合。当网络120包括公共网络时,安全特征(例如,VPN/SSL安全传输)可被包括以确保系统100中的授权访问。在某些实施例中,网络120包括与包括示例118、中继器110、以及设备114的本地网络相比更广的网络。
在一个实施例中,用于动态服务发现的DNS查询使用特殊DNS完全限定域名(FQDN)(包括五个特殊前缀中的一个和适当的DNS域、以及请求SRV记录)被创建。存在为服务发现浏览域的配置而被保留的五个特殊前缀,如在RFC 6763中阐述的下列项:
b._dns-sd._udp.
db._dns-sd._udp.
r._dns-sd._udp.
dr._dns-sd._udp.
1b._dns-sd._udp.
对于示例域名“example.com”,相关联的RR名称将是下列项:
b._dns-sd._udp.example.com.
db._dns-sd._udp.example.com.
r._dns-sd._udp.example.com.
dr._dns-sd._udp.example.com.
1b._dns-sd._udp.example.com.
并且,通过执行这些RR名称的PTR记录请求查询,传统的查询结果包括下列项:
●对于b.dns-sd.udp.(还称为b.查询):推荐浏览的实例名称的列表。
●对于db.dns-sd.udp.(还称为db.查询):推荐浏览的单一默认域。
●对于r.dns-sd.udp.(还称为r.查询):推荐使用动态更新来注册服务的域的列表。
●对于dr.dns-sd.udp.(还称为dr.查询):推荐注册服务的单一默认域。
●对于lb.dns-sd.udp.(还称为1d.查询):一个或多个“传统浏览”或“自动浏览”域。
与特殊前缀有关的更多细节参考RFC 6763。
例如,假设组织具有域名“example.com”,并且该组织的DNS名称空间被分成至少四个部分,建筑BXB200的第一层、建筑BXB200的第二层、建筑SJC01的第一层、以及建筑SJC01的第二层中的每项各一部分。设备114进入该组织的建筑并想要知道组织的域中能够提供某些服务的(一个或多个)实例118。设备114为了获取该信息而形成的DNS查询可以是:b._dns-sd._udp.example.com.。
图2根据某些实施例示出了执行动态DNS-SD的示例过程。图2结合图1和3在下面被描述。图3根据某些实施例示出了框图,该框图示出了关于包括在DNS服务器102中的动态服务发现合成器104的额外细节。
在图2的方框202中,设备114接收和/或生成期望服务的DNS查询。期望服务的DNS查询(还称为DNS-SD查询)由包括在设备114中的服务发现浏览器116来配置。DNS查询被自动地生成的程度取决于服务发现浏览器116的特征。例如,与设备114相接口连接的用户可直接输入DNS查询;浏览器116可提供用户界面(UI)以帮助用户组成合适的DNS查询;用户可在浏览器116中指示期望的服务,并且浏览器116基于期望的服务来创建DNS查询;用户试图访问服务(例如,用户发起打印文档),并且浏览器116自动地生成DNS查询以满足服务请求;或当设备114进入新的网络区域或体验某些状态变化时,浏览器116自动地生成DNS查询。
在一个实施例中,DNS查询请求服务的特定实例的FQDN的列表。这些FQDN被存储在感兴趣的服务的FQDN所标识的TXT RR中。所有服务名称的列表被维护在互联网地址编码分配机构(IANA)服务名称和传输协议端口号注册表中。
例如,互联网打印协议(IPP)是常用网络化打印机所广泛使用的流行的打印服务。为了发现提供IPP服务的设备,针对ipp.tcp.example.com的查询可返回下列项:
_ipp._tcp.example.com PTR printer 1._ipp._tcp.example.com
_ipp._tcp.example.com PTR printer2._ipp._tcp.example.com,
这些项指示存在IPP服务的两个实例,名称为打印机1和打印机2。
然后在方框204中,浏览器116访问设备元数据和/或用户元数据以附加于在方框202中所生成的DNS查询。设备元数据包括关于设备114的数据,包括但不限于:设备114的IP地址(还称为源IP地址)、设备114的系统信息(例如,其操作系统,如iOS、Android、Windows、MacOS、Linux、Blackberry)、设备114的连接特性(例如,有线或无线、估计带宽)、与设备114相关联的授权信息、设备114的地理位置、对设备114的工作负载的测量、设备114在网络中的拓扑位置等。用户元数据包括关于与设备114相接口连接的用户的数据,包括但不限于:用户标识符信息、基于用户所选偏好或用户历史的用户偏好(例如,用户优选彩色打印机而不是单色打印机)、与用户相关联的授权信息等。由于可能存在多个设备和用户元数据,浏览器116可仅使用这类元数据的一部分。例如,还在中继器110或DNS服务器102中可用的特定元数据不需要被附加于DNS查询。作为另一示例,被附加于DNS查询的特定元数据可取决于所请求的特定服务。作为另一示例,设备114可能位于最优位置以便具有某些当前数据,并因此是采集这类数据并与系统100中的其他组件共享这类数据的天然来源。在任何情况下,被选择/生成以便补充DNS查询的特定设备和/或用户元数据是辅助动态服务发现的数据。
在某些实施例中,方框204可以是可选的,这取决于与中继器110和/或DNS服务器102中的设备114相关联的元数据的可用性或处理。作为示例,中继器110或DNS服务器102为了认证目的可优选使用其与设备114相关联的元数据。作为另一示例,浏览器116可针对最小通信复杂度或带宽使用被配置,并且因此,不建议DNS查询之外的数据。在其他实施例中,浏览器116可不被配置为在将DNS查询发送到中继器110之前,将元数据附加于DNS查询。在其他实施例中,浏览器116包括被配置为生成DNS查询的传统服务发现浏览器,并且用于将DNS查询发送到中继器110的通信技术自动地将与该传输相关联的一些设备(和/或用户)元数据附加于DNS查询。例如,头部信息可以是标识传输的源的通信分组的一部分。
一旦DNS查询和设备/用户元数据(若是适用的或可用的)被创建,则在方框206中,浏览器116将DNS查询和适用的设备/用户元数据传输到中继器110。设备114经由到中继器110的有线或无线连接进行传输。图1示出了特定做出请求的设备(例如,设备1114)和中继器110之间的示例通信130。通信130包括DSN查询(表示为“Q”)和适用的设备/用户元数据(表示为“M”)到中继器110的单播传输。
在方框208中,所发送的DNS查询和适用的设备/用户元数据由中继器110接收(见图2)。然后在方框210中,中继器110访问与设备114相关联的中继元数据。中继元数据包括中继器110已知的或中继器110所维护的关于设备114的数据。中继元数据可复制设备114所发送的设备/用户元数据中的至少一些元数据。中继元数据被访问以便确认所接收的设备/用户元数据中的至少一部分设备/用户元数据的精度、补充所接收的设备/用户元数据、替代设备/用户元数据中的至少一部分设备/用户元数据、确认到本地网络的认证访问、和/或在没有来自设备114的元数据的情况下向DNS服务器102提供元数据。
响应于接收到DNS查询,例如,中继器110访问身份管理服务以确认认证访问并查找特定设备114的身份。设备身份映射到设备的IP地址,其可被附加于DNS查询。中继器110的内部配置信息可包括与特定设备114和/或与特定设备114相关联的用户相关联的中继元数据。例如,若中继器110是无线中继器,则无线位置服务被访问以便从访问点搜集信息,并使用无线信号强度来三角测量设备114的位置。作为另一示例,若中继器110是有线中继器,则中继器110使用关于有线连接的端点中的每个端点的位置的已知信息来确定设备114的位置。这类位置信息可被附加于DNS查询。身份和内部配置信息被包括在中继器110和/或数据库112中。作为另一示例,被附加于DNS查询的特定元数据可取决于所请求的特定服务。
在某些实施例中,若元数据将由DNS服务器102提供,则方框210可以是可选的,如针对方框216在本文所讨论的。
然后,在方框212中,中继器110经由网络120将DNS查询和元数据(适当的和/或可用的设备元数据、用户元数据、和/或中继元数据)二者发送到DNS服务器102。在图1中,示例通信132被示出,表示从中继器110到DNS服务器102的传输。通信132包括DNS查询(表示为“Q”)和所附加的元数据(表示为“M”)的单播传输。
在方框214处,通信132由DNS服务器102接收。作为响应,在方框216处,包括在DNS服务器102中的动态服务发现合成器104访问与做出查询的特定设备114相关联的服务器元数据。服务器元数据包括DNS服务器102、DHCP服务器108、和/或数据库106已知的或所维护的关于设备114的数据,以及可能与对查询的回复有关的其他数据。服务器元数据可复制中继器110所发送的元数据中的一些数据。服务器元数据被访问以确认所接收的元数据中的至少一部分元数据的真实性、补充所接收的元数据、替代元数据中的至少一部分元数据、和/或确认到DNS服务器102的认证访问。服务器元数据的示例包括但不限于:做出请求的机器或订户身份(例如,经由设备114的IP地址的DHCP或AAA查找)、查询的源的地理位置(例如,建筑标识符、特定建筑的楼层、特定建筑的一部分、经由DHCP或AAA查找、经由中继器110的位置)、机器或订户人事关系(例如,经由DHCP或AAA查找)、日期或时间、目标设备(例如,实例118)的当前负载或可用性、目标设备特性、机器或订户系统信息(例如,Android、iOS、MacOS、Windows、Linux、应用)、机器或订户连接特性(例如,有线或无线、估计带宽)等。
当做出请求的设备首次被添加到系统100时,服务器元数据中的至少一部分可由DHCP服务器108在特定设备114的IP地址分配处理期间获取。DHCP服务器108可已经请求设备114提供某些信息,例如,其人事关系或身份信息(经由授权处理)、和/或自动获取的或检测到的关于设备114的其他信息,例如,位置信息(经由中继代理的位置的先验知识),以便将设备的IP地址映射到与设备有关的元数据。DHCP服务器108然后可将IP地址和相关联的元数据推送到DNS服务器102以便存储和维护。DNS服务器102进而可将这类信息存储在数据库106中。替代地,这类信息可由DHCP服务器108来保留,并且当DNS查询是由特定设备114做出时,DNS服务器102可从DHCP服务器108请求信息。
当首次被添加到系统100时,实例118中的每个实例与DHCP服务器108相类似地经历IP地址分配处理。当实例118首次被添加到系统100时,实例118发出通知其(一个或多个)服务的可用性的DNS消息。例如,若特定实例118是彩色打印机,则它通知其打印能力。DNS消息由DNS服务器102接收。DNS服务器102进而与DHCP服务器108协调以生成该实例118的一组DNS-SD记录,并提供唯一IP地址。关于实例118的信息也在此时被获取,与上面的讨论相类似。例如,实例118所在的位置(例如,所在的建筑)、实例118的所有权或人事关系、身份信息(例如,用户友好地分配的名称)、实例118能够提供的(一个或多个)服务的具体种类(例如,与单色打印相对的彩色打印)等。在某些实施例中,关于实例118的这类信息被存储在DNS-SD记录中。在其他实施例中,这类信息可被存储在分离的记录或数据库中,或作为DHCP服务器或DNS服务器102所维护的、但不在DNS-SD记录中的元数据。
在某些实施例中,DNS服务器102可补充DHCP服务器108针对设备114和/或实例118之前所获取的元数据。例如,可与DNS查询同时存在的元数据,例如,做出请求的设备114的当前日期和/或时间或当前位置(例如,经由转发DNS查询的中继器110的已知位置,其中,中继器110的位置由于中继器110的短通信范围能力而被假设为设备114的位置的代理)。此外,可与DNS查询同时存在并与实例118有关的元数据,例如,当前负载、可用性、或与由感兴趣的实例118中的每个实例提供服务有关的其他条件。
服务器元数据可相应地包括下列两部分:DNS服务器102和/或与设备114相关联的DHCP服务器108所维护的或已知的元数据,以及DNS服务器102和/或与实例118相关联的DHCP服务器108所维护的或已知的元数据。
在某些实施例中,若元数据是由如上面讨论的设备114和/或中继器110提供的,则方框216可以是可选的。
在方框218中,动态服务发现合成器104从与DNS查询和元数据相匹配的一组实例118中动态地选择(一个或多个)实例118。动态服务发现合成器104以对于做出请求的设备114透明的方式基于不仅仅是DNS查询来执行服务发现。在一个实施例中,合成器104基于与做出请求的设备114相关联的元数据和DNS查询,根据预定义选择规则或约束来执行动态选择。如结合方框204、210以及216在上面所讨论的,与做出请求的设备114相关联的元数据包括:设备114所提供的设备元数据和/或用户元数据;中继器110所提供的中继元数据;和/或DNS服务器102和/或DHCP服务器108所提供的服务器元数据。
图3示出了描绘合成器104所执行的动态选择的示例框图。与做出请求的设备114相关联的元数据304和DNS查询302是到合成器104的输入。合成器104包括一个或多个预定义选择规则或约束308。基于DNS查询302、元数据304、以及选择规则/约束308,合成器104输出与选择标准相匹配的(一个或多个)实例118的动态响应列表306。动态响应列表306包括与(一个或多个)匹配实例118相对应的PTR记录的列表。
选择规则/约束308可包括定义下述内容的任意规则:哪些DNS查询302和元数据304应被用于搜索(一个或多个)匹配实例118和/或DNS查询302和元数据304应被如何用于搜索(一个或多个)匹配实例118。选择规则/约束308可包括非特定于设备114或实例118的或除了DNS查询和元数据之外的额外选择标准。选择规则/约束308的示例包括但不限于下列项:
●为了实现负载均衡:基于DNS查询302和元数据304所发现的(一个或多个)实例118还基于那些(一个或多个)实例118的当前负载条件被细化,以实现负载均衡。
●为了证明不同类别的用户(例如,学生、教师、行政人员)之间的区分:至少与元数据304中所标识的做出请求的设备114相关联的用户被用于确定用户的类别,并且然后不同类别的用户映射到(一个或多个)特定实例118。
●为了通过提供特定搜索域来将一类设备分配到一组服务。
●为了实现功率管理:某些(一个或多个)实例118在某些小时或天可被关闭以节能,以便使得它们在那些时间是不可用的。
●为了考虑实例118的实时或近实时条件:由于故障、维护、或其他不可用性,当前不可用的实例118从动态响应列表306中被排除。
●为了指定所使用的元数据304:如上面讨论的,元数据304可包括关于设备114的多个信息。此规则指定在查询DNS-SD记录中使用多个信息中的哪些特定信息。例如,位置接近可能是最高搜索标准。作为另一示例,位置接近和最快连接可能是最高搜索标准。
●为了维护到实例118的安全访问:若匹配实例118位于请求通过安保人员或其他安全措施的安全区域,但与设备114相关联的用户不具有安全许可或在当前时间将不被允许进入安全区域,则该实例118从动态响应列表306中被排除。
●为了限制于彼此合理的位置接近:仅位于同一建筑、建筑的同一层、或到设备114的其他预定义同一接近距离内的(一个或多个)实例118可被包括在响应列表306中。
●当前时间。
●两个或更多个上面的规则的组合。
●无规则/约束。
随着更多的或不同的规则被添加时和/或随着规则自身根据预定义调度可以是可适用的,合成器104所使用的特定选择规则/约束308可随时间变化。
DNS服务器102使用至少下列项来动态地发现一个或多个实例118:与DNS查询302相匹配的DNS-SD记录的SRV和TXT记录、与设备114相关联的元数据304、以及选择规则/约束308。元数据304和/或选择规则/约束308使得服务发现被限制于特定的逻辑域或子集域,该特定的逻辑域或子集域与DNS查询302中指定的实际域相比在范围上更狭窄。即使所生成并被发送到DNS服务器102的DNS查询包括传统的或标准的DNS查询(包括FQDN前缀和域),受限的服务发现发生。
替代地,选择规则/约束308可被省略,并且动态响应列表306可基于下列操作来确定:基于DNS查询302和元数据304来搜索DNS-SD记录。
返回图2,一旦与搜索或查询标准相匹配的(一个或多个)实例118被发现,则在方框220中,合成器104实时地或接近实时地合成动态响应列表306。PTR记录列表的合成可包括使用文本字符串操作的PTR记录的文本构造。继续上面的示例,还假设选择规则/约束308包括将服务发现限制于做出请求的设备114当前所在的同一建筑。在大型组织中,可能不期望浏览器116在整个组织的服务发现名称空间上执行服务发现。返回位于该组织的所有建筑(特别是当存在许多建筑时)中的匹配实例118的列表对于用户不是特别有用。替代地,在一个实施例中,匹配实例的列表可通过被返回到浏览器的搜索域(例如,BXB200-1.example.com)来控制。位于建筑BXB200中的设备114所做出的b.dns-sd.udp.example.com查询(例如,DNS查询302)仅返回与也位于建筑BXB200中的匹配实例118相关联的那些PTR记录(例如,响应列表306):
b._dns-sd._udp.example.com.PTR BXB200-1.example.com
b._dns-sd._udp.example.com.PTR BXB200-2.example.com,
其中,第一实例118位于建筑BXB200的第一层,并且第二实例位于建筑BXB200的第二层。
相反地,若同一做出请求的设备114位于建筑SJC01中,则同一b.dns-sd.udp.example.com查询使得仅与位于建筑SJC01中的匹配实例118相关联的那些PTR记录将被返回到设备114:
b._dns-sd._udp.example.com.PTR SJC01-1.example.com
b._dns-sd._udp.example.com.PTR SJC02-2.example.com,
其中,第一实例118位于建筑SJC01的第一层,并且第二实例位于建筑SJC02的第二层。
因此,同一DNS查询根据附加有DNS查询的元数据可返回与不同实例118相关联的不同PTR记录。这与传统DNS-SD不同,在传统DNS-SD中,相同的查询返回相同的PTR记录的列表,而不管发布查询的设备114的特性或属性。在传统DNS-SD下,b.dns-sd.udp.example.com查询返回位于组织的所有建筑中的实例118的PTR记录,即:
b._dns-sd._udp.example.com.PTR BXB200-1.example.com
b._dns-sd._udp.example.com.PTR BXB200-2.example.com
b._dns-sd._udp.example.com.PTR SJC01-1.example.com
b._dns-sd._udp.example.com.PTR SJC02-2.example.com。
在另一实施例中,PTR响应的列表可由DNS服务器102基于与查询相关联的元数据和对于DNS服务器102可用的其他信息来合成。例如,考虑在example.com处可用的IPP打印服务的下列四个实例:
_ipp._tcp.example.com PTR printerl._ipp._tcp.example.com
_ipp._tcp.example.com PTR printer2._ipp._tcp.example.com
_ipp._tcp.example.com PTR printer3_ipp._tcp.example.com
_ipp._tcp.example.com PTR printer4_ipp._tcp.example.com
若DNS服务器102接收针对_ipp._tcp.example.com的查询,则其将评估与查询相关联的元数据,以及对于DNS服务器102可用的其他信息,并合成查询感兴趣的PTR RR的列表。在此示例中,若打印机1位于与做出请求的设备不同的建筑中并且打印机3是关机的,则DNS服务器102仅将打印机2和打印机4的RR返回到做出请求的设备。
在方框222中,所合成的响应列表通过DNS服务器102经由网络120被传输到中继器110。在方框224中,中继器110从DNS服务器102接收响应列表,并将响应列表中继到做出请求的设备114。在某些实施例中,中继器110可在向设备114中继之前执行一个或多个处理操作和/或将信息(例如,头部信息或认证信息)附加于响应列表。
作为响应,在方框226中,设备114接收与DNS查询相对应的响应列表。图1示出了示例通信134,该示例通信134表示响应列表响应于DNS查询经由网络120和中继器110从DNS服务器102返回到设备114。通信134包括响应列表(表示为“R”)的单播传输。返回图2,在方框228中,包括在设备114中的服务发现浏览器116在设备114的显示器上展示响应列表。在某些实施例中,浏览器116可在设备114上显示用户友好版本的响应列表,例如,显示响应列表中所标识的(一个或多个)实例118的用户可识别名称的列表,而不是PTR记录自身。浏览器116还可提供关于所列出的(一个或多个)实例118中的每个实例的信息,例如,指示每个实例相对于设备114所在的位置。因此,本文描述的动态DNS-SD技术根据与响应列表中所返回的实例118相对应的不同配置信息或名称,允许浏览器116的不同配置。
在方框230中,设备114从响应列表(或其等同物)中接收特定实例118的用户选择。并且响应于用户选择,在方框232中,浏览器116针对与所选实例118相对应的SRV RR来生成并传输DNS查询。此DNS查询请求与所选实例118相关联的FQDN和其他信息,如包含在SRV RR中的特定实例的FQDN和其他信息。此DNS查询在建立设备114和所选实例118之间的连接的准备过程中被生成,以便从所选实例118获取期望的服务。
在方框234中,DNS查询由中继器110接收并通过中继器110被中继到DNS服务器102。中继器110可在向DNS服务器102传输之前执行一个或多个处理操作和/或将信息附加于DNS查询。在方框236中,DNS服务器102接收DNS查询。作为响应,在方框238中,DNS服务器102在与所选实例118相关联的DNS RR中执行查找,以便获取与所选实例118(位于SRV RR中)相关联的所请求的FQDN和其他信息,以及与FQDN(位于A和/或AAAA RR中)相关联的一个或多个IP地址。在方框240中,FQDN和(一个或多个)IP地址从DNS服务器102被返回到中继器110。
在方框242中,中继器110进而将DNS名称和IP地址中继到设备114。设备114所接收的IP地址(方框244中)被设备114用于建立与所选实例118的连接(方框246中)。
因此,即使DNS-SD查询自身被配置用于域的整个名称空间上的服务发现,本文描述的动态DNS-SD技术提供将服务发现限制于域中的特定逻辑域的灵活性。DNS服务器通过根据与做出查询的设备相关联的元数据搜索查询中所指定的域的名称空间来响应DNS-SD查询。被附加于DNS-SD查询的元数据包括与设备和/或与做出查询的设备相关联的用户的身份、特性、和/或属性有关的信息。元数据包括不能被编码在用于定位实例的适当配置名称的DNS查询前缀中的信息。元数据可通过做出DNS查询的设备、将DNS查询转发到DNS服务器的任意中继其、和/或DNS服务器来提供。元数据包括对于做出查询的设备透明的额外查询参数。示例元数据包括但不限于:位置、身份、角色、或源IP地址。在某些实施例中,选择标准还可包括可独立于做出请求的设备的选择规则或约束。选择规则或约束的示例包括但不限于:节能管理规则、目标实例的当前负载、或目标实例的当前可用性。
通过将向同一给定DNS-SD查询返回可变的或不同的回复(例如,与目标设备相对应的不同的PTR记录的列表),一种技术被提供,其中,包括在做出请求的设备中的不同服务发现浏览器可使用同一给定DNS-SD查询的不同搜索域列表来配置。响应于同一给定DNS-SD查询而被返回的配置信息或名称不需要是恒定的或固定的,而不管做出请求的设备的特性。以这种方式,DNS-SD查询回复中所标识的目标设备被动态地选择,以便与做出查询的特定设备的当前状态和周围环境的状态直接相关。
3.0硬件概览
根据一个实施例,本文描述的技术通过一个或多个专用计算设备来实现。专用计算设备可以是硬连线的以执行技术,或可包括数字电子设备,例如,被永久地编程以便执行技术的一个或多个专用集成电路(ASIC)或现场可编程门阵列(FPGA),或可包括被编程为依照固件、存储器、其他存储设备、或组合中的程序指令来执行技术的一个或多个通用硬件处理器。这类专用计算设备还可将定制硬连线逻辑、ASIC、或FPGA与定制编程相结合以完成技术。专用计算设备可以是台式计算机系统、便携式计算机系统、手持设备、联网设备或结合硬连线和/或程序逻辑以实现技术的任意其他设备。
例如,图4是示出了计算机系统400的框图,本公开的实施例在计算机系统400上可被实现。计算机系统400包括用于传送信息的总线402或其他通信机制,以及与总线402相耦合并用于处理信息的硬件处理器404。例如,硬件处理器404可以是通用微处理器。
计算机系统400还包括耦合于总线402并用于存储信息和处理器404所执行的指令的主存储器406,例如,随机存取存储器(RAM)或其他动态存储设备。主存储器406还可用于在指令由处理器404执行期间存储临时变量或其他中间信息。当被存储在处理器404可访问的非暂态存储介质中时,这类指令将计算机系统400转化为被定制为执行指令中所指定的操作的专用机器。
计算机系统400还包括耦合于总线402并用于存储静态信息和处理器404的指令的只读存储器(ROM)408或其他静态存储设备。诸如磁盘或光盘之类的存储设备410被提供并耦合于总线402以便用于存储信息和指令。
计算机系统400可经由总线402耦合于显示器412(例如,阴极射线管(CRT)或液晶显示器(LCD)),以便向计算机用户显示信息。包括字母数字键和其他键的输入设备414被耦合于总线402以便将信息和命令选择传送到处理器404。另一类型的用户输入设备是光标控制设备416,例如,鼠标、轨迹球、或用于将方向信息和命令选择传送到处理器404并用于控制光标在显示器412上的运动的光标方向键。该输入设备通常具有允许设备在平面中来指定位置的两个轴(第一轴(例如,x)和第二轴(例如,y))上的两个自由度。
计算机系统400可使用定制的硬连线逻辑、一个或多个ASIC或FPGA、固件和/或程序逻辑来实现本文描述的技术,这些项与计算机系统相结合使得计算机系统400为专用机器或将计算机系统400编程为专用机器。根据一个实施例,本文的技术响应于处理器404执行主存储器406中所包含的一个或多个指令的一个或多个序列,而由计算机系统400来执行。这类指令可从另一存储介质(例如,存储设备410)被读取到主存储器406中。主存储器406中所包含的指令的序列的执行使得处理器404执行本文描述的处理步骤。在替代实施例中,硬连线电路可替代或结合软件指令来使用。
本文使用的术语“存储介质”指存储使得机器以特定方试操作的数据和/或指令的任意非暂态介质。这类存储介质可包括非易失性介质和/或易失性介质。例如,非易失性介质包括光盘或磁盘,例如,存储设备410。易失性介质包括动态存储器,例如,主存储器406。例如,一般形式的存储介质包括软盘、软磁盘、硬盘、固态硬盘、磁带、或任意其他磁数据存储介质、CD-ROM、任意其他光数据存储介质、具有孔图案(patterns of holes)的任意物理介质、RAM、PROM、以及EPROM、FLASH-EPROM、NVRAM、任意其他存储器芯片或内存匣。
存储介质与传输介质不同,但可结合传输介质来使用。传输介质参与在存储介质之间传输信息。例如,传输介质包括将包括总线402的线包括在内的同轴电缆、铜线以及光纤。传输介质还可采取声波或光波的形式,例如,在无线电波和红外数据传送期间生成的那些声波或光波。
各个形式的介质可涉及将一个或多个指令的一个或多个序列运载到处理器404以便执行。例如,指令可被初始地运载在远程计算机的磁盘或固态硬盘上。远程计算机可将指令加载到其动态存储器中并使用调制解调器经由电话线来发送指令。计算机系统400本地的调制解调器可接收电话线上的数据并使用红外发射器来将数据转换为红外信号。红外检测器可接收红外信号中运载的数据,并且适当的电路可以将数据放置在总线402上。总线402将数据运载到主存储器406,处理器404从主存储器406取回数据并执行指令。主存储器406所接收的指令可选地可以在被处理器404执行之前或之后被存储在存储设备410上。
计算机系统400还包括耦合于总线402的通信接口418。通信接口418提供到连接于本地网络422的网络链路420的两路数据通信耦合。例如,通信接口418可以是综合业务数字网(ISDN)卡、电缆调制解调器、卫星调制解调器、或提供到相应类型的电话线的数据通信连接的调制解调器。作为另一示例,通信接口418可以是提供到兼容局域网(LAN)的数据通信连接的LAN卡。无线链路还可被实现。在任意这类实现方式中,通信接口418发送和接收运载表示各种类型的信息的数字数据流的电子、电磁或光信号。
网络链路420通常通过一个或多个网络来提供到其他数据设备的数据通信。例如,网络链路420可通过本地网络422来提供到主机计算机424或因特网服务提供商(ISP)426所操作的数据装置的连接。ISP 426反过来通过世界范围分组数据通信网络(现在通常称为“因特网”)428来提供数据通信服务。本地网络422和因特网428都使用运载电子数据流的电子、电磁或光信号。将数字数据运载到计算机系统400以及从计算机系统400运载数字数据的贯穿各个网络的信号和网络链路420上的信号以及贯穿通信接口418的信号是传输介质的示例形式。
计算机系统400可通过(一个或多个)网络、网络链路420以及通信接口418来发送消息并接收包括程序代码的数据。在因特网示例中,服务器430可通过因特网428、ISP 426、本地网络422以及通信接口418来传输应用程序的请求代码。
所接收的代码在其被接收时可由处理器404执行、和/或被存储在存储设备410、或其他非易失性存储设备中用于较晚执行。
4.0其他公开内容
1.一种装置,包括:
一个或多个数据库;
一个或多个收发器,所述一个或多个收发器用于从第一计算设备接收第一域名系统(DNS)查询,所述第一DNS查询定义第一服务发现名称空间;
一个或多个处理器,所述一个或多个处理器与所述一个或多个数据库和所述一个或多个收发器中的每项进行通信,
其中,所述一个或多个处理器生成与所述第一计算设备相关联的第一元数据并将所述第一元数据附加于所述第一DNS查询,所述第一元数据的至少一部分从所述一个或多个数据库被获取,以及
其中,所述一个或多个收发器执行下述操作:将所述第一DNS查询和所述第一元数据发送到域名系统(DNS)服务器计算机;从所述DNS服务器计算机接收响应于所述第一DNS查询的第一响应,所述第一响应包括对一个或多个服务的标识,所述一个或多个服务根据与所述第一计算设备相关联的所述第一元数据和所述第一DNS查询来提供所述第一服务发现名称空间的子集中的计算设备;以及将所述第一响应中继到所述第一计算设备。
2.如条款1所述的装置,其中,所述第一元数据包括下列项中的至少一项:设备身份、用户身份、地理位置、设备人事关系、用户人事关系、日期或时间、提供计算设备的服务中的一个或多个服务的当前负载、提供计算设备的服务中的一个或多个服务的当前可用性、设备系统信息、设备操作系统信息、设备连接特性、设备连接类型、或设备特性。
3.如条款1所述的装置,其中,所述第一响应包括对所述一个或多个服务的标识,所述一个或多个服务根据所述第一DNS查询、与所述第一计算设备相关联的所述第一元数据、以及来自所述DNS服务器计算机的与所述第一计算设备相关联的第二元数据来提供所述第一服务发现名称空间的所述子集中的计算设备的。
4.如条款1所述的装置,其中,所述第一响应中所标识的提供计算设备的服务中的至少一个服务位于所述第一计算设备的本地网络之内或所述第一计算设备的所述本地网络之外,其中,所述第一DNS查询包括完全限定域名(FQDN),所述FQDN包括域名和特殊前缀中的一个特殊前缀,所述域名定义所述第一服务发现名称空间。
5.如条款1所述的装置,其中,所述一个或多个收发器经由与所述第一计算设备的有线或无线连接来接收所述第一DNS查询。
6.如条款1所述的装置,其中,所述装置包括下列项中的至少一项:中继器、路由器、交换机、网关、防火墙、或转发器。
7.一种数据处理方法,包括:
在域名系统(DNS)服务器计算机处接收第一计算设备所生成的基于域名系统的服务发现(DNS-SD)查询;
使用所述DNS服务器计算机,基于与所述第一设备相关联的元数据和所述DNS-SD查询从DNS资源记录动态地选择提供计算设备的一个或多个服务;
使用所述DNS服务器计算机,合成与所述被动态地选择的提供计算设备的一个或多个服务相对应的查询响应,所述查询响应包括与所述被动态地选择的提供计算设备的一个或多个服务相关联的指针(PTR)资源记录;
使用所述DNS服务器计算机,将所述查询响应发送到所述第一计算设备;以及
其中,所述方法通过一个或多个计算设备被执行。
8.如条款7所述的方法,其中,所述DNS-SD查询包括完全限定域名(FQDN),所述FQDN包括域名和特殊前缀中的一个特殊前缀,所述域名定义服务发现名称空间,并且所述元数据将服务发现限制于所述服务发现名称空间中的特定逻辑域。
9.如条款7所述的方法,还包括:
接收第二计算设备所生成的第二DNS-SD查询,其中,所述第二DNS-SD查询与所述DNS-SD查询相同;
基于与所述第二计算设备相关联的第二元数据和所述第二DNS-SD查询,从所述DNS-SD资源记录动态地选择提供计算设备的一个或多个第二服务;
合成与所述被动态地选择的提供计算设备的一个或多个第二服务相对应的第二查询响应,其中,所述第二查询响应与所述查询响应不同;以及
将所述第二查询响应发送到所述第二计算设备。
10.如条款7所述的方法,其中,接收所述DNS-SD查询包括接收附加有所述DNS-SD查询的元数据。
11.如条款10所述的方法,其中,所述元数据由通信地位于所述第一计算设备和所述DNS服务器计算机之间的中继器生成。
12.如条款10所述的方法,其中,所述元数据由所述第一计算设备生成。
13.如条款7所述的方法,其中,所述元数据由所述DNS服务器计算机或动态主机配置协议(DHCP)服务器生成。
14.如条款7所述的方法,其中,动态地选择提供计算设备的所述一个或多个服务包括:基于与所述第一计算设备相关联的所述元数据和所述DNS-SD查询,根据预定义选择规则从所述DNS-SD资源记录动态地选择提供计算设备的所述一个或多个服务。
15.一种存储有一个或多个指令序列的非暂态计算机可读数据存储介质,所述一个或多个指令序列当由一个或多个处理器执行时使得执行方法,所述方法包括:
在域名系统(DNS)服务器计算机处接收第一计算设备所生成的基于域名系统的服务发现(DNS-SD)查询;
基于与所述第一设备相关联的元数据和所述DNS-SD查询从DNS资源记录动态地选择提供计算设备的一个或多个服务;
合成与所述被动态地选择的提供计算设备的一个或多个服务相对应的查询响应,所述查询响应包括与所述被动态地选择的提供计算设备的一个或多个服务相关联的指针(PTR)资源记录;以及
将所述查询响应发送到所述第一计算设备。
16.如条款15所述的非暂态计算机可读数据存储介质,其中,所述DNS-SD查询包括完全限定域名(FQDN),所述FQDN包括域名和特殊前缀中的一个特殊前缀,所述域名定义服务发现名称空间,并且所述元数据将服务发现限制于所述服务发现名称空间中的特定逻辑域。
17.如条款15所述的非暂态计算机可读数据存储介质,还包括指令,所述指令当被执行时使得执行下列操作:
接收第二计算设备所生成的第二DNS-SD查询,其中,所述第二DNS-SD查询与所述DNS-SD查询相同;
基于与所述第二计算设备相关联的第二元数据询和所述第二DNS-SD查,从所述DNS-SD资源记录动态地选择提供计算设备的一个或多个第二服务;
合成与所述被动态地选择的提供计算设备的一个或多个第二服务相对应的第二查询响应,其中,所述第二查询响应与所述查询响应不同;以及
将所述第二查询响应发送到所述第二计算设备。
18.如条款15所述的非暂态计算机可读数据存储介质,其中,接收所述DNS-SD查询包括接收附加有所述DNS-SD查询的元数据。
19.如条款18所述的非暂态计算机可读数据存储介质,其中,所述元数据由下列项中的至少一项生成:通信地位于所述第一计算设备和所述DNS服务器计算机之间的中继器、所述第一计算设备、以及所述DNS服务器计算机或动态主机配置协议(DHCP)服务器。
20.如条款15所述的非暂态计算机可读数据存储介质,其中,动态地选择提供计算设备的所述一个或多个服务包括:基于与所述第一计算设备相关联的所述元数据和所述DNS-SD查询,根据预定义选择规则从所述DNS-SD资源记录动态地选择提供计算设备的所述一个或多个服务,其中,所述预定义选择规则包括下列项中的至少一项:功率管理规则、物理可访问规则、负载均衡规则、设备类别区分规则、或设备类别服务区分规则。
5.0扩展和替代
在上述说明书中,本公开的实施例参考许多特定细节(可以随实施例而变化)已被描述。因此,说明书和附图将被视为说明性的而非限制性的。本公开的范围,以及本申请预期作为本公开的范围的唯一且独有的指示,是本申请以下列特定形式产出的一组权利要求的字面的和等价的范围:这些权利要求包括任意后续的修正。

Claims (20)

1.一种数据处理装置,包括:
一个或多个数据库;
一个或多个收发器,所述一个或多个收发器用于从第一计算设备接收第一域名系统DNS查询,所述第一DNS查询定义第一服务发现名称空间;
一个或多个处理器,所述一个或多个处理器与所述一个或多个数据库和所述一个或多个收发器中的每项进行通信,
其中,所述一个或多个处理器生成与所述第一计算设备相关联的第一元数据并将所述第一元数据附加于所述第一DNS查询,所述第一元数据的至少一部分从所述一个或多个数据库被获取,并且包括对向所述第一计算设备提供服务的服务提供商的搜索范围的约束,并且所述约束随时间变化,
其中,所述一个或多个收发器执行下述操作:将所述第一DNS查询和所述第一元数据发送到域名系统DNS服务器计算机;从所述DNS服务器计算机接收响应于所述第一DNS查询的第一响应,所述第一响应包括对一个或多个服务的标识,所述一个或多个服务根据与所述第一计算设备相关联的所述第一元数据和所述第一DNS查询来提供至少部分地基于所述第一元数据中包括的所述约束选自所述第一服务发现名称空间的子集中的计算设备;以及将所述第一响应中继到所述第一计算设备,并且
其中,从所述第一计算设备接收到的所述第一DNS查询不包括所述第一元数据。
2.如权利要求1所述的装置,其中,所述第一元数据包括下列项中的至少一项:设备身份、用户身份、地理位置、设备人事关系、用户人事关系、日期或时间、提供计算设备的服务中的一个或多个服务的当前负载、提供计算设备的服务中的一个或多个服务的当前可用性、设备系统信息、设备操作系统信息、设备连接特性、设备连接类型、或设备特性。
3.如权利要求1-2中的任一项所述的装置,其中,所述第一响应包括对所述一个或多个服务的标识,所述一个或多个服务根据所述第一DNS查询、与所述第一计算设备相关联的所述第一元数据、以及来自所述DNS服务器计算机的与所述第一计算设备相关联的第二元数据来提供所述第一服务发现名称空间的所述子集中的计算设备的。
4.如权利要求1-2中的任一项所述的装置,其中,所述第一响应中所标识的提供计算设备的服务中的至少一个服务位于所述第一计算设备的本地网络之内或所述第一计算设备的所述本地网络之外,其中,所述第一DNS查询包括完全限定域名FQDN,所述FQDN包括域名和特殊前缀中的一个特殊前缀,所述域名定义所述第一服务发现名称空间。
5.如权利要求1-2中的任一项所述的装置,其中,所述一个或多个收发器经由与所述第一计算设备的有线或无线连接来接收所述第一DNS查询。
6.如权利要求1-2中的任一项所述的装置,其中,所述装置包括下列项中的至少一项:中继器、路由器、交换机、网关、防火墙、或转发器。
7.一种数据处理方法,包括:
在域名系统DNS服务器计算机处接收第一计算设备所生成的基于域名系统的服务发现DNS-SD查询和附加到所述DNS-SD查询并与所述第一计算设备相关联的元数据;
其中,所述元数据从一个或多个数据库被获取,并且包括对向所述第一计算设备提供服务的服务提供商的搜索范围的约束,并且所述约束随时间变化;
使用所述DNS服务器计算机,基于所述DNS-SD查询和附加到所述DNS查询并与所述第一计算设备相关联的所述元数据中包含的约束从DNS资源记录动态地选择提供计算设备的一个或多个服务;
使用所述DNS服务器计算机,合成与所述被动态地选择的提供计算设备的一个或多个服务相对应的查询响应,所述查询响应包括与所述被动态地选择的提供计算设备的一个或多个服务相关联的指针PTR资源记录;
使用所述DNS服务器计算机,将所述查询响应发送到所述第一计算设备;以及
其中,所述方法通过一个或多个计算设备被执行,并且
其中,所述第一计算设备所生成的所述DNS-SD查询不包括所述元数据。
8.如权利要求7所述的方法,其中,所述DNS-SD查询包括完全限定域名FQDN,所述FQDN包括域名和特殊前缀中的一个特殊前缀,所述域名定义服务发现名称空间,并且所述元数据将服务发现限制于所述服务发现名称空间中的特定逻辑域。
9.如权利要求7-8中的任一项所述的方法,还包括:
接收第二计算设备所生成的第二DNS-SD查询,其中,所述第二DNS-SD查询与所述DNS-SD查询相同;
基于与所述第二计算设备相关联的第二元数据和所述第二DNS-SD查询,从所述DNS-SD资源记录动态地选择提供计算设备的一个或多个第二服务;
合成与所述被动态地选择的提供计算设备的一个或多个第二服务相对应的第二查询响应,其中,所述第二查询响应与所述查询响应不同;以及
将所述第二查询响应发送到所述第二计算设备。
10.如权利要求7-8中的任一项所述的方法,其中,接收所述DNS-SD查询包括接收附加有所述DNS-SD查询的元数据。
11.如权利要求10所述的方法,其中,所述元数据由通信地位于所述第一计算设备和所述DNS服务器计算机之间的中继器生成。
12.如权利要求10所述的方法,其中,所述元数据由所述第一计算设备生成。
13.如权利要求7-8中的任一项所述的方法,其中,所述元数据由所述DNS服务器计算机或动态主机配置协议DHCP服务器生成。
14.如权利要求7-8中的任一项所述的方法,其中,动态地选择提供计算设备的所述一个或多个服务包括:基于与所述第一计算设备相关联的所述元数据和所述DNS-SD查询,根据预定义选择规则从所述DNS-SD资源记录动态地选择提供计算设备的所述一个或多个服务。
15.一种存储有一个或多个指令的非暂态计算机可读数据存储介质,所述一个或多个指令当由一个或多个处理器执行时使得执行方法,所述方法包括:
在域名系统DNS服务器计算机处接收第一计算设备所生成的基于域名系统的服务发现DNS-SD查询和附加到所述DNS-SD查询并与所述第一计算设备相关联的元数据;
其中,所述元数据从一个或多个数据库被获取,并且包括对向所述第一计算设备提供服务的服务提供商的搜索范围的约束,并且所述约束随时间变化;
基于所述DNS-SD查询和附加到所述DNS查询并与所述第一计算设备相关联的所述元数据中包含的约束从DNS资源记录动态地选择提供计算设备的一个或多个服务;
合成与所述被动态地选择的提供计算设备的一个或多个服务相对应的查询响应,所述查询响应包括与所述被动态地选择的提供计算设备的一个或多个服务相关联的指针PTR资源记录;以及
将所述查询响应发送到所述第一计算设备,
其中,所述第一计算设备所生成的所述DNS-SD查询不包括所述元数据。
16.如权利要求15所述的非暂态计算机可读数据存储介质,其中,所述DNS-SD查询包括完全限定域名FQDN,所述FQDN包括域名和特殊前缀中的一个特殊前缀,所述域名定义服务发现名称空间,并且所述元数据将服务发现限制于所述服务发现名称空间中的特定逻辑域。
17.如权利要求15-16中的任一项所述的非暂态计算机可读数据存储介质,还包括指令,所述指令当被执行时使得执行下列操作:
接收第二计算设备所生成的第二DNS-SD查询,其中,所述第二DNS-SD查询与所述DNS-SD查询相同;
基于与所述第二计算设备相关联的第二元数据查询和所述第二DNS-SD查询,从所述DNS-SD资源记录动态地选择提供计算设备的一个或多个第二服务;
合成与所述被动态地选择的提供计算设备的一个或多个第二服务相对应的第二查询响应,其中,所述第二查询响应与所述查询响应不同;以及
将所述第二查询响应发送到所述第二计算设备。
18.如权利要求15-16中的任一项所述的非暂态计算机可读数据存储介质,其中,接收所述DNS-SD查询包括接收附加有所述DNS-SD查询的元数据。
19.如权利要求18所述的非暂态计算机可读数据存储介质,其中,所述元数据由下列项中的至少一项生成:通信地位于所述第一计算设备和所述DNS服务器计算机之间的中继器、所述第一计算设备、以及所述DNS服务器计算机或动态主机配置协议DHCP服务器。
20.如权利要求15-16中的任一项所述的非暂态计算机可读数据存储介质,其中,动态地选择提供计算设备的所述一个或多个服务包括:基于与所述第一计算设备相关联的所述元数据和所述DNS-SD查询,根据预定义选择规则从所述DNS-SD资源记录动态地选择提供计算设备的所述一个或多个服务,其中,所述预定义选择规则包括下列项中的至少一项:功率管理规则、物理可访问规则、负载均衡规则、设备类别区分规则、或设备类别服务区分规则。
CN201580040777.3A 2014-07-30 2015-06-30 基于dns的动态服务发现 Active CN106576118B (zh)

Applications Claiming Priority (3)

Application Number Priority Date Filing Date Title
US14/447,475 2014-07-30
US14/447,475 US9712485B2 (en) 2014-07-30 2014-07-30 Dynamic DNS-based service discovery
PCT/US2015/038637 WO2016018557A1 (en) 2014-07-30 2015-06-30 Dynamic dns-based service discovery

Publications (2)

Publication Number Publication Date
CN106576118A CN106576118A (zh) 2017-04-19
CN106576118B true CN106576118B (zh) 2021-08-31

Family

ID=53546264

Family Applications (1)

Application Number Title Priority Date Filing Date
CN201580040777.3A Active CN106576118B (zh) 2014-07-30 2015-06-30 基于dns的动态服务发现

Country Status (4)

Country Link
US (2) US9712485B2 (zh)
EP (1) EP3175605A1 (zh)
CN (1) CN106576118B (zh)
WO (1) WO2016018557A1 (zh)

Families Citing this family (24)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US9917905B2 (en) * 2013-05-13 2018-03-13 International Business Machines Corporation Location-based domain name system service discovery
US9906605B2 (en) * 2014-05-23 2018-02-27 Qualcomm Connected Experiences, Inc. Enhanced DNS-based service discovery in an internet of things (IoT) environment
US9712485B2 (en) * 2014-07-30 2017-07-18 Cisco Technology, Inc. Dynamic DNS-based service discovery
US10057208B2 (en) 2014-10-31 2018-08-21 Cisco Technology, Inc. Visibility control for domain name system service discovery
CN107926004B (zh) * 2015-08-06 2022-03-18 三星电子株式会社 用于执行载波间d2d通信的方法和装置
US10652271B2 (en) * 2016-03-25 2020-05-12 Verisign, Inc. Detecting and remediating highly vulnerable domain names using passive DNS measurements
US10412177B2 (en) * 2016-03-30 2019-09-10 Konica Minolta Laboratory U.S.A., Inc. Method and system of using IPV6 neighbor discovery options for service discovery
US10992536B2 (en) 2016-08-15 2021-04-27 At&T Intellectual Property I, L.P. Method and apparatus to control anycast traffic using a software defined network controller
US10356124B2 (en) 2017-03-01 2019-07-16 Cisco Technology, Inc. Dynamic device isolation in a network
US11895200B2 (en) * 2017-03-24 2024-02-06 Lenovo Enterprise Solutions (Singapore) Pte. Ltd. Access to an operator panel over an out-of-band local network domain
US10897475B2 (en) * 2017-08-10 2021-01-19 Cisco Technology, Inc. DNS metadata-based signaling for network policy control
CN107592377A (zh) * 2017-09-25 2018-01-16 深圳市茁壮网络股份有限公司 一种指令处理方法、域名解析服务器及客户端设备
EP3855708A4 (en) * 2018-09-17 2022-04-20 Nokia Solutions and Networks Oy SERVICE DISTRIBUTION DEVICE AND METHOD IN A SOFTWARE DEFINED NETWORK AND STORAGE MEDIUM
WO2020079313A1 (en) * 2018-10-16 2020-04-23 Kone Corporation Data network services discovery in elevators and escalators
US10425912B1 (en) * 2019-01-17 2019-09-24 Cisco Technology, Inc. Characterizing movement behaviors of wireless nodes in a network
KR20200119945A (ko) 2019-04-10 2020-10-21 삼성전자주식회사 저 지연 dns 처리를 지원하는 전자 장치
WO2020209703A1 (en) * 2019-04-12 2020-10-15 Samsung Electronics Co., Ltd. Method and system for discovering edge-server or edge-service through domain name server (dns) resolution
WO2020261570A1 (ja) * 2019-06-28 2020-12-30 日本電信電話株式会社 機器推定装置、機器推定方法、および、機器推定プログラム
DE102019126486A1 (de) * 2019-10-01 2021-04-01 Perinet GmbH Verfahren zur Identifikation von Diensten in einem Netzwerk mit Internet-of-Things Sensoren/Aktoren
FR3104865A1 (fr) * 2019-12-13 2021-06-18 Orange Procédé de traitement de requêtes de résolution de nom de domaine.
WO2021253301A1 (en) * 2020-06-17 2021-12-23 Lenovo (Beijing) Limited Method and apparatus for providing server discovery information
US11509536B2 (en) * 2020-10-20 2022-11-22 Cisco Technology, Inc. Relay functionality in an application centric infrastructure (ACI) fabric
CN115190105B (zh) * 2021-04-06 2024-03-29 维沃移动通信有限公司 信息处理方法、装置和通信设备
US20230062068A1 (en) * 2021-09-02 2023-03-02 Cisco Technology, Inc. Techniques for performing domain name system support

Citations (6)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US6154777A (en) * 1996-07-01 2000-11-28 Sun Microsystems, Inc. System for context-dependent name resolution
US7228359B1 (en) * 2002-02-12 2007-06-05 Cisco Technology, Inc. Methods and apparatus for providing domain name service based on a client identifier
CN101827011A (zh) * 2009-03-04 2010-09-08 华为技术有限公司 一种主机通信的方法、系统和设备
US8161184B2 (en) * 2004-06-25 2012-04-17 Apple Inc. Method and apparatus for facilitating long-lived DNS queries
KR20130103145A (ko) * 2012-03-09 2013-09-23 서정환 사용자 정보에 기반한, 도메인 네임 시스템 및 도메인 네임 서비스 방법
CN103891247A (zh) * 2011-09-20 2014-06-25 西门子公司 用于基于域名系统的设备和目标发现的方法和系统

Family Cites Families (22)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US8284774B2 (en) * 1998-04-03 2012-10-09 Megawave Audio Llc Ethernet digital storage (EDS) card and satellite transmission system
WO2002069073A2 (en) * 2000-11-13 2002-09-06 Starguide Digital Networks, Inc. Ethernet digital storage (eds) card and satellite transmission system including faxing capability
US20050030917A1 (en) * 2001-08-17 2005-02-10 Amit Haller Device, system, method and computer readable medium obtaining a network attribute, such as a DNS address, for a short distance wireless network
JP4161758B2 (ja) * 2003-03-19 2008-10-08 日本電気株式会社 ネットワーク情報検出装置および方法
KR100567326B1 (ko) * 2003-12-24 2006-04-04 한국전자통신연구원 Sonet/sdh, pdh, 그리고 이더넷 신호의 통합스위칭/전달 장치 및 그 방법
US8130718B2 (en) * 2004-12-09 2012-03-06 Interdigital Technology Corporation Method and system for interworking of cellular networks and wireless local area networks
US20070086382A1 (en) * 2005-10-17 2007-04-19 Vidya Narayanan Methods of network access configuration in an IP network
US8122113B2 (en) * 2007-09-21 2012-02-21 Cisco Technology, Inc. Dynamic host configuration protocol (DHCP) message interception and modification
US8897952B1 (en) * 2011-05-20 2014-11-25 Brian Palmer Vehicle diagnostic communications system and application
US9525749B2 (en) * 2010-11-17 2016-12-20 Telefonaktiebolaget L M Ericsson (Publ) DNS server arrangement and method
CN103444136B (zh) 2011-03-25 2016-08-17 日本电气株式会社 通信设备、通信系统和通信方法
CN102843391B (zh) * 2011-06-21 2017-04-05 中兴通讯股份有限公司 一种信息发送方法及网关
US8793343B1 (en) * 2011-08-18 2014-07-29 Amazon Technologies, Inc. Redundant storage gateways
US9231903B2 (en) 2011-12-30 2016-01-05 Time Warner Cable Enterprises Llc System and method for resolving a DNS request using metadata
US9407567B2 (en) 2012-12-24 2016-08-02 Telefonaktiebolaget Lm Ericsson (Publ) Enabling external access to multiple services on a local server
US10284659B2 (en) 2013-01-25 2019-05-07 Apple Inc. Hybrid unicast/multicast DNS-based service discovery
US9107164B1 (en) 2013-03-08 2015-08-11 Amazon Technologies, Inc. Wake on one-to-many communication
GB201306628D0 (en) * 2013-04-11 2013-05-29 F Secure Oyj Detecting and marking client devices
US9774709B2 (en) 2013-11-18 2017-09-26 Cable Television Laboratories, Inc. Service discovery
US9417831B2 (en) 2014-03-05 2016-08-16 Tricerat Method and system of providing computer network based limited visibility service discovery
US9712485B2 (en) * 2014-07-30 2017-07-18 Cisco Technology, Inc. Dynamic DNS-based service discovery
US10057208B2 (en) 2014-10-31 2018-08-21 Cisco Technology, Inc. Visibility control for domain name system service discovery

Patent Citations (6)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US6154777A (en) * 1996-07-01 2000-11-28 Sun Microsystems, Inc. System for context-dependent name resolution
US7228359B1 (en) * 2002-02-12 2007-06-05 Cisco Technology, Inc. Methods and apparatus for providing domain name service based on a client identifier
US8161184B2 (en) * 2004-06-25 2012-04-17 Apple Inc. Method and apparatus for facilitating long-lived DNS queries
CN101827011A (zh) * 2009-03-04 2010-09-08 华为技术有限公司 一种主机通信的方法、系统和设备
CN103891247A (zh) * 2011-09-20 2014-06-25 西门子公司 用于基于域名系统的设备和目标发现的方法和系统
KR20130103145A (ko) * 2012-03-09 2013-09-23 서정환 사용자 정보에 기반한, 도메인 네임 시스템 및 도메인 네임 서비스 방법

Also Published As

Publication number Publication date
WO2016018557A1 (en) 2016-02-04
US20170317968A1 (en) 2017-11-02
US10742592B2 (en) 2020-08-11
US9712485B2 (en) 2017-07-18
EP3175605A1 (en) 2017-06-07
CN106576118A (zh) 2017-04-19
US20160036762A1 (en) 2016-02-04

Similar Documents

Publication Publication Date Title
CN106576118B (zh) 基于dns的动态服务发现
KR102047197B1 (ko) 사물 인터넷을 위한 광역 서비스 발견
US10044816B2 (en) Location-based domain name system service discovery
US10057208B2 (en) Visibility control for domain name system service discovery
CN103973830B (zh) 基于混合单播/多播dns的服务发现
JP2019041395A (ja) 仮想ネットワークインタフェースオブジェクト
JP4730118B2 (ja) ドメインネームシステム
CN104427010A (zh) 应用于动态虚拟专用网络的网络地址转换方法和装置
CN101083594A (zh) 一种网络设备的管理方法及装置
KR101710033B1 (ko) 유동 ip기기 간 상시 연결성 유지 방법 및 이를 위한 장치
US10904037B2 (en) Relaying apparatus, relaying method, and relaying system
US20180375818A1 (en) Dns-based method of transmitting data
US20200344157A1 (en) Receiver Directed Anonymization of Identifier Flows in Identity Enabled Networks
JP6470640B2 (ja) 通信装置及びその制御方法、コンピュータプログラム
JP4434062B2 (ja) Webサーバ搭載機器への自動アクセス方法
EP3313038B1 (en) Method and apparatus for updating internet protocol (ip) address, and gateway
JP2003283570A (ja) 通信ネットワークシステムおよびデータ通信方法
JP2007251267A (ja) ネットワーク機器
JP2005072823A (ja) 情報処理装置

Legal Events

Date Code Title Description
PB01 Publication
PB01 Publication
SE01 Entry into force of request for substantive examination
SE01 Entry into force of request for substantive examination
GR01 Patent grant
GR01 Patent grant