CN104115146A - 在分布式系统中存储和搜索带标签的内容项的方法 - Google Patents
在分布式系统中存储和搜索带标签的内容项的方法 Download PDFInfo
- Publication number
- CN104115146A CN104115146A CN201380008653.8A CN201380008653A CN104115146A CN 104115146 A CN104115146 A CN 104115146A CN 201380008653 A CN201380008653 A CN 201380008653A CN 104115146 A CN104115146 A CN 104115146A
- Authority
- CN
- China
- Prior art keywords
- key
- content item
- word
- grand
- cloth
- 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.)
- Pending
Links
- 238000000034 method Methods 0.000 title claims abstract description 28
- 238000001914 filtration Methods 0.000 claims abstract description 4
- 239000004744 fabric Substances 0.000 claims description 35
- 230000007246 mechanism Effects 0.000 description 6
- 230000006870 function Effects 0.000 description 5
- 230000004044 response Effects 0.000 description 3
- 230000008901 benefit Effects 0.000 description 2
- 230000004048 modification Effects 0.000 description 2
- 238000012986 modification Methods 0.000 description 2
- 238000004590 computer program Methods 0.000 description 1
- 230000007547 defect Effects 0.000 description 1
- 230000001419 dependent effect Effects 0.000 description 1
- 238000001514 detection method Methods 0.000 description 1
- 230000001815 facial effect Effects 0.000 description 1
- 230000006855 networking Effects 0.000 description 1
- 238000006386 neutralization reaction Methods 0.000 description 1
- 238000005457 optimization Methods 0.000 description 1
- 230000008447 perception Effects 0.000 description 1
- 230000008569 process Effects 0.000 description 1
- 238000012163 sequencing technique Methods 0.000 description 1
- 239000000126 substance Substances 0.000 description 1
Classifications
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F16/00—Information retrieval; Database structures therefor; File system structures therefor
- G06F16/90—Details of database functions independent of the retrieved data types
- G06F16/907—Retrieval characterised by using metadata, e.g. metadata not derived from the content or metadata generated manually
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F16/00—Information retrieval; Database structures therefor; File system structures therefor
- G06F16/90—Details of database functions independent of the retrieved data types
- G06F16/95—Retrieval from the web
- G06F16/953—Querying, e.g. by the use of web search engines
- G06F16/9535—Search customisation based on user profiles and personalisation
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F16/00—Information retrieval; Database structures therefor; File system structures therefor
- G06F16/20—Information retrieval; Database structures therefor; File system structures therefor of structured data, e.g. relational data
- G06F16/22—Indexing; Data structures therefor; Storage structures
- G06F16/2228—Indexing structures
- G06F16/2255—Hash tables
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F16/00—Information retrieval; Database structures therefor; File system structures therefor
- G06F16/20—Information retrieval; Database structures therefor; File system structures therefor of structured data, e.g. relational data
- G06F16/28—Databases characterised by their database models, e.g. relational or object models
- G06F16/284—Relational databases
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F16/00—Information retrieval; Database structures therefor; File system structures therefor
- G06F16/30—Information retrieval; Database structures therefor; File system structures therefor of unstructured textual data
- G06F16/31—Indexing; Data structures therefor; Storage structures
- G06F16/316—Indexing structures
- G06F16/325—Hash tables
Landscapes
- Engineering & Computer Science (AREA)
- Databases & Information Systems (AREA)
- Theoretical Computer Science (AREA)
- Data Mining & Analysis (AREA)
- Physics & Mathematics (AREA)
- General Engineering & Computer Science (AREA)
- General Physics & Mathematics (AREA)
- Software Systems (AREA)
- Library & Information Science (AREA)
- Information Retrieval, Db Structures And Fs Structures Therefor (AREA)
Abstract
一种在分布式数据交换系统用于存储带标签的内容项的方法,包括:A1.为与内容项相关的标签生成布隆1滤波器;A2.生成由布隆1滤波器的成员字与布隆1滤波器的成员字索引的并列组成的键,成员字表示布隆1过滤器的非空部分;A3.生成包括与所述内容项相关的所有标签的紧凑表示以及对所述内容项的存储位置的引用的值;和A4.添加由键和值组成的键值对到分布式哈希表,所述方法进一步包括针对检索带标签的内容项的以下步骤:B1.接收包含多个关键字的搜索查询;B2.选择关键字;B3.从分布式哈希表中检索具有以关键字作为相关标签的内容项的第一引用列表;以及B4.通过所有标签的所述紧凑表示过滤所述第一列表,以获得到包括以搜索的所有关键字作为相关标签的内容项的第二引用列表。
Description
技术领域
本发明一般地涉及在例如云计算系统、社会网络等的大型分布式数据交换系统中存储和搜索带标签的内容项。在这样的系统中,大量的联网计算设备协作以提供用于存储和检索用户标记或机器标记的内容项的基础设施,这样的内容项例如数据文件、图片、电影、服务和/或其他资源。与内容项相关的标签表示可以被用户生成,或者可以例如通过照片被上传到系统时的面部识别软件或诸如此类而被自动生成的元数据。典型地,数百万用户同时通过多个关键字查询分布式环境中搜索内容项。因此,本发明一般的目的是提供一种有效的、可扩展的计算机实现的方法和应用,用于在分布式数据交换系统存储内容项以及对存储在这种系统中的内容项执行多关键字搜索。
背景技术
在大规模分布式数据系统中存在用于多关键字搜索的各种机制。在一般情况下,这些现有的机制或者是由于使用单点故障而不可靠,或者是由于通过过度节点访问和处理资源的使用而效率低下,这将在下面解释。
关系数据库是使内容可搜索的最常用方法。虽然这样的关系数据库使用各种技术来避免成为比如对复制和备份的单点故障,他们基本上依赖于昂贵的、集中的基础设施。关系型数据库基础架构通常受制于尺寸问题,即鉴于实际的或预期的系统负载的过度供应或供应不足,或者受制于可靠性、可维护性和可升级性方面的问题,例如由于这样的关系型数据库的集中性的而影响到服务。
已经部署了可代替关系数据库、不再依赖于中央实体的对等系统。但是在这样的对等系统中执行多关键字搜索仍然是一个复杂而高成本的操作,通常包括到索引的外部搜索引擎并提供对内容项的访问。以下段落描述了如今在这样的对等系统中最常用的多关键字搜索机制。
非结构化搜索依赖于向分布式系统中的所有节点广播所述多关键字搜索查询。每个接收搜索查询的节点返回存储在该节点中和具有所需的键作为相关标签的一组内容项。
非结构化搜索以搜索查询淹没了分布式系统中的节点或服务器。在大规模分布式系统中,每个节点需要处理数以百万计的搜索查询,即使搜索查询与该服务器不相关,这会导致过载、响应时间慢和处理资源的低效率使用。
在分布式哈希表或者DHT中,指向内容项的指针,即因内容本身的而不同的元数据,例如URL、标签、大小、日期、作者等,存储在对应于与内容项相关的每个标签的地址上。与内容项相关的每个标签被散列,以便获得DHT中相应的地址,其中指向内容项的指针将被存储在DHT中。指向内容项的地址和指针表示键-值对。在基于DHT的系统中执行多关键字搜索包括散列形成搜索查询的一部分的关键字、在对应于散列键的地址上访问DHT、利用存储在这些地址中的指针来检索关于含有至少一个所需关键字的内容的元数据、并在合并操作中过滤不包含所有所需的关键字的内容项。
DHT的缺点在于多关键词查询的每个关键字需要被散列,以及元数据(即内容的标签、到内容的指针等)必须从分布式系统中的节点针对每个关键字进行检索,从而导致低效的网络使用率、重复的结果、非相关指针等,另外,必须执行相当复杂和计算密集型的合并操作。
布隆过滤器是位阵列,可以用于检测多关键字搜索查询的多个或所有关键字是否在与内容项相关的标签中出现。与内容项相关的每个标签经过若干哈希函数的被映射到位阵列的特定位置。位排列在这些位置被设置为“1”,而在阵列中的其它位保持为“0”。为了执行多关键字搜索,在搜索查询中的每个关键字被散列以生成搜索查询布隆过滤器。该布隆过滤器与针对所有内容项而生成的布隆过滤器相比较,以便在搜索查询布隆过滤器中选择至少具有位设置“1”的内容项。
基于布隆过滤器的搜索没有生成假阴性,但由于在不同的标签/关键字的上的哈希函数生成的位阵列位置的重叠,假阳性搜索结果是有可能的。假阳性的数量随着与内容项相关的标签数量而增加,并且随着多关键字搜索查询的关键字数量而增加。其结果是,例如的标签精确字符串匹配的额外机制可能会被采用以在额外步骤中除去假阳性中。
文献中已经提出了上述机制的若干组合。对于大规模分布式数据交换系统的多关键字搜索,作者为Xing Jin、W.-P.Ken Yiu和S.-H Gary Chan,出版于IEEE ICC 2006Proceedings的文章“Supporting Multiple-KeywordSearch in a Hybrid Structured Peer-to-Peer Network”描述了基于布隆过滤器的Mkey方案。当大量标签与内容项相关时,例如每个内容项超过30个标签,Mkey方案在存储的数据指针和搜索的地址中提供了好处。对于大多数数据共享的应用程序,这样大量的标签关联是不同寻常的。
因此,本发明的目的是公开一种计算机实现的方法和应用,用于在分布式数据交换系统中存储带标签的内容项,以及用于在解决了现有机制的上述缺陷的系统中执行多关键字搜索。更具体地讲,本发明的目的在于公开一种用于存储/检索带标签的内容项的方法及应用,以有效的方式保持可扩展性、达到同时数百万个多个关键字搜索的产品规模,即具有内容标签关联的紧凑表示,到分布式存储器的访问减少,并且假阳性的出现下降。
发明内容
根据本发明,通过权利要求1所限定的用于在分布式数据交换系统中存储和检索带标签的内容项来实现上述定义的目标,
针对带标签的内容项的存储以及针对与所述内容项相关的每个标签,所述方法包括以下步骤:
A1.为标签生成布隆1过滤器;
A2.生成键,所述键由所述布隆1过滤器的成员字与所述布隆1过滤器的成员字索引的并列组成,所述成员字表示所述布隆1过滤器的非空部分;
A3.生成值,所述值包括与所述内容项相关的所有标签的紧凑表示以及对所述内容项的存储位置的引用;和
A4.添加键值对到分布式哈希表,所述键值对由所述键和所述值组成,
所述方法进一步包括针对检索带标签的内容项的以下步骤:
B1.接收包含多个关键字的搜索查询;
B2.从所述多个关键字中选择出关键字;
B3.从所述分布式哈希表中检索具有以所述关键字作为相关标签的内容项的第一引用列表;以及
B4.通过所有标签的所述紧凑表示过滤所述第一列表,以获得到包括以所述搜索的所有关键字作为相关标签的内容项的第二引用列表。
为了保持数千同时存在的用户和数百万带标签的内容项,分布式哈希表被用作分布式系统的结构化覆盖。在与内容项相关的每个标签上计算的布隆过滤器1的非空部分,即布隆过滤器1的成员字(membership word),与布隆过滤器1会员字索引一起,被用作分布式哈希表中的键,用于存储指向数据对象的指针。因此,本发明结合了两者的优点,即,分布式哈希表的可扩展性以及由布隆过滤器提供的标签内容项关联的紧凑表示。存储的内容项的指针的拷贝数,即到存储位置的引用,与关联到内容项的标签数量呈线性增长。对象指针的长度也与相关的标签的数目成线性比例。在分布式环境中的多关键字搜索是通过单个键的查询执行的,因此只需要单一存取操作。要被处理的内容项记录的数量可以进一步通过可选的优化技术来减少,这将在下面说明。布隆1过滤器的使用,即能够在通过它们的成员字和成员字索引在存储器中紧凑表示的大布隆过滤器,显著减少了假阳性的发生。
优选地,由如权利要求2所限定的,选择的关键字是从多个关键字中选出的最不受欢迎关键字,即遍历所有内容项具有最少出现次数的关键字。
实际上,通过选择最不受欢迎或不常用的关键字时,指针的第一列表被最小化,并在同一时间,分布式系统必须被咨询的节点数也被最小化(只有一个)。为了能够选择最不受欢迎的关键字,跟踪适当的标签受欢迎度的表或数据库可以被保持并且在每个多关键字搜索时被查询。或者,可以使用基于词熵(word entropy)或长度的试探法。
可选地,由权利要求3所限定,所述值还包括在布隆1过滤器中非空过滤器字的数量;以及
检索第一引用列表包括:
-计算所述多个关键字的所有关键字上的布隆1过滤器;以及
-只从所述分布式哈希表检索对这些项的引用,所述项包含等于或者大于所述布隆1过滤器中的所述非空字的数量的字量。
事实上,第二优化可以包括在搜索查询的所有关键字上计算布隆1过滤器并且限制对包含等于或大于布隆1过滤器中非空字的数量的量的内容项的搜索。
根据进一步可选的方面,如权利要求4所定义的,所述值还包括指示所述内容项的所有权和/或访问控制的信息。
因此,可选地,存储在分布式哈希表中的该值或信息可能包含所有权和访问控制信息,所述访问控制信息能够控制指向内容项的指针是否被允许响应于搜索查询而被返回,这取决于例如谁执行的搜索查询或从哪儿执行的搜索查询。
除了由权利要求1所限定的方法之外,如权利要求5所述,本发明涉及一种在分布式数据交换系统中用于存储和检索带标签的内容项的计算机执行的应用程序,所述应用程序包括用于存储带标签的内容项的以下装置:
A1.用于为与所述内容项相关的所述标签生成布隆1过滤器的装置;
A2.用于生成键的装置,所述键由所述布隆1过滤器的成员字与所述布隆1滤波器的成员字索引的并列组成,所述成员字表示所述布隆1过滤器的非空部分;
A3.用于生成值的装置,所述值包括与所述内容项相关的所有标签的紧凑表示以及对所述内容项的存储位置的引用;和
A4.用于添加键值对到分布式哈希表的装置,所述键值对由所述键和所述值组成,
所述应用程序进一步包括用于检索带标签的内容项的以下装置:
B1.用于接收包含多个关键字的搜索查询的接口;
B2.用于从所述多个关键字中选择出关键字的装置;
B3.用于从所述分布式哈希表中检索具有以所述关键字作为相关标签的内容项的第一引用列表的装置;以及
B4.用于通过所有标签的所述紧凑表示过滤所述第一列表,以获得到包括以所述搜索的所有关键字作为相关标签的内容项的第二引用列表的装置。
附图说明
图1示出了根据本发明的用于存储和搜索带标签的内容项的方法的第一实施例;
图2示出在降低假阳性率方面,本发明改进的性能;以及
图3示出在待处理返回对象记录的平均量方面,本发明的改进的效率。
具体实施方式
在图1所示的第一实施例中,多关键字搜索功能由分布式系统提供,并作为社交网络和文件共享应用程序的用户之间的数据交换的基础。用户或用户激活的软件组件可以用适当的接口或呈现装置向系统提交多关键词查询并接收作为响应的匹配数据项列表,所述适当的接口或呈现允许访问、下载、或以其它方式对一个或多个所检索的数据项进行操作。
在图1中,第一实施例是由对等体实施来代表。图1中绘制的数据交换网络采用大量的具有与网络109(如IP网络)的连通性110的最终用户PC100的形式,每个都运行包括以下子集的软件应用101:
-对等体发现模块102,发现对等体,以便检测其他哪些节点存在于网络上,所述对等体即运行在其他用户PC上的软件应用101的其他实例;
-网络加入模块103,作为对等体加入到数据交换网,以使参与其中和在网络上发布呈现信息;
-数据发现模块104,发现终端用户的本地网络的数据,包括但不限于运行软件应用程序上的PC机;换句话说,这是一个使自己的内容或数据为他人可用的可选履带(crawler);
-元数据发布模块105,在数据交换网络发布与发现的自己的内容项有关的元数据,包括但不限于描述该项的项目名称、关键字/标签、指向发现的项目或提供到该项目的访问的指针、访问限制、以及布隆过滤器1,总结了一套与该项目相关的关键字;
-元数据存储模块106,在数据交换网络中存储关于可用项目的子集的元数据;
-搜索引擎107,用于在数据交换网络中基于多关键字搜索查询和基于根据以下描述的本发明的方法搜索内容项;
-用户接口108,使得用户能够输入多关键字搜索查询的关键字/标签来搜索数据交换网络中的数据项。
对于每一个要被存储数据对象或项目,对象记录在对应于所述相关的标签的键的每一个上被保存在分布式哈希表(DHT)中。这样的对象记录包括:
-项的标签的紧凑表示,其在于完整的标签集上计算的布隆1过滤器的非空部分,表示为形式<索引;字>的一组元组;
-满的布隆1过滤器中的非空布隆1过滤器字的数量;
-项目的URL或统一资源标识符;
-最终对象所有权和访问控制信息;和
-最终的额外元数据。
有兴趣寻找与某话题相关的一个或多个项目的用户,在接口108输入一个或多个关键字,虽然在例子中假设用户生成一个查询,应该注意到,多个查询可以由例如计算机程序、感知的日期等的其他源生成。基于这些关键字来计算布隆1过滤器,布隆1过滤器用于发现数据交换网络中知道哪些数据项匹配所有输入的关键字的节点。匹配的项的列表-可能是部分的-被呈现给用户。
搜索这些项包括以下操作:
-在发出查询的那些中选择单个标签和通过查阅分布式哈希表检索与其相关的对象指针的列表;和
-过滤检索的指针来获取指向那些含有至少所有查询中的标签的指针;过滤是通过存储在DHT中的项目的标签的紧凑表示完成。
上面搜索方法的第一操作,可以通过优化适当选择单个标签/关键字以在形成了发出查询的一部分的所有关键字中查找。合适的标签是包含查询所包含的最不频繁使用的字。为了选择好的键,跟踪全局标签的受欢迎程度的表格,可以被保持,即使是近似的,以在搜索时进行查询。或者可以使用基于字信息熵和/或长度的简单试探法。
在上面的搜索方法的第二操作,可以通过在所有查询标签上计算布隆1过滤器并限制对对象指针的检索来进行优化,其中所说的对象指针包含等于或大于布隆1过滤器的非空查询字的数量。
值得注意,第一实施例中也可以用替代方式实现。特别地,一些实施可能涉及运行软件应用程序的一部分并可能拥有或控制部署软件的硬件的服务提供商的出现。不考虑部署方法,本领域技术人员将认识到,这种实现仅代表同一第一实施例的某种不同形式,因为它使用上述的相同目的中描述的相同功能,但具有构成分布式计算系统的网络硬件上的软件应用的模块102到108(或其子集)的不同的重新划分。
在第二实施例中,云计算基础设施的机器发布有关其资源的信息,如核心数、当前CPU负载、可用带宽、在其上运行的服务的数量、物理位置、可用内存等。发布的信息在分布式多关键字搜索引擎中被索引。网络配置工具可以询问分布式搜索引擎在云计算基础设施中发现与负载、带宽、内存、位置等需求数量精确匹配的那些机器。
第二实施例也可以用任何一个充分分散的对等系统的形式实现,云计算基础设施的各个机器都运行与第一实施例中的软件应用程序101基本类似的软件应用程序。可选地,第二实施例可以实现为分布式系统,其中只有可用的硬件的子集是专门用于支持根据本发明的搜索引擎特性,其他节点充当向系统发布最新信息的简单客户端。
图2示出一个表格,其中根据本发明的方法的假阳性率与现有技术中已知的基于Mkey的方案进行比较。对于相同的键空间的大小,即128个字节的前缀长度,对于n=100标签,假阳性率pF从基于Mkey实施方式的62,47%下降到本发明的基于布隆1过滤器或B1F方法的1.875310-10%。
图3显示了列出使用基于布隆1或B1过滤器的根据本发明的方法相对于基于Mkey的实施方式,每10.000随机成功的多关键字搜索返回的对象指针的平均数。“更智能”的版本实现了基于标签受欢迎度的标签选择优化,如上所述。由于标签受欢迎度信息的损失(标签被编码在布隆过滤器中),这样的优化在基于Mkey的实施中是不可用的。表中通过举例示出了要检索和处理的对象记录的数量从基于Mkey实施方式的570个记录下降到根据本发明的基于布隆1或B1过滤器的33。
虽然本发明已经参考具体实施例作了描述,但对于本领域技术人员来说显而易见的,本发明不限于前述说明性实施例的细节,并且本发明可以在不脱离其范围的情况下用各种变化和改进实施。因此,本实施例在所有方面都是说明性的,而不是限制性的,本发明的范围由所附的权利要求书而不是由前面的描述限定,因此权利要求的等同范围内的含义和范围内的所有改变都旨在被包含在其中。换言之,可以预期覆盖落入本专利申请的基本原理的范围内任何和所有修改、变化或等同物,并且其本质属性都在本专利申请者要求保护以及。此外,本专利申请的读者应当理解,用词“包括”或“包含括”不排除其他元件或步骤,词语“一”或“一个”不排除多个,并且单个元件,例如计算机系统,处理器或另一个集成单元可以实现权利要求中所述的几个装置的功能。在权利要求中的任何附图标记不应当被解释为限制有关的权利要求。当在说明书或权利要求中使用时引入的术语“第一”、“第二”、“第三”、“A”、“B”、“C”等,在类似的元件或步骤之间进行区分使用,不一定描述顺序或时间顺序。类似地,术语“顶部”、“底部”、“之上”、“之下”等等被引入用于描述的目的并且不一定表示相对的位置。可以理解的是,这样使用的术语在适当情况下是可互换的,并且本发明的实施例能够根据本发明以与上述实施例中不同的其他顺序、或方向上进行操作。
Claims (5)
1.一种在分布式数据交换系统用于存储和检索带标签的内容项的方法,针对带标签的内容项的存储以及针对与所述内容项相关的每个标签,所述方法包括以下步骤:
A1.为与所述内容项相关的所述标签生成布隆1滤波器;
A2.生成键,所述键由所述布隆1滤波器的成员字与所述布隆1滤波器的成员字索引的并列组成,所述成员字表示所述布隆1过滤器的非空部分;
A3.生成值,所述值包括与所述内容项相关的所有标签的紧凑表示以及对所述内容项的存储位置的引用;和
A4.添加键值对到分布式哈希表,所述键值对由所述键和所述值组成,
所述方法进一步包括针对检索带标签的内容项的以下步骤:
B1.接收包含多个关键字的搜索查询;
B2.从所述多个关键字中选择出关键字;
B3.从所述分布式哈希表中检索具有以所述关键字作为相关标签的内容项的第一引用列表;以及
B4.通过所有标签的所述紧凑表示过滤所述第一列表,以获得到包括以所述搜索的所有关键字作为相关标签的内容项的第二引用列表。
2.根据权利要求1所述的方法,其中选择的所述关键字是从所述多个关键字中选出的最不受欢迎关键字。
3.根据权利要求1所述的方法,其中,所述值还包括在所述布隆1过滤器中非空滤波器字的数量;以及
检索第一引用列表包括:
-计算所述多个关键字的所有关键字上的布隆1过滤器;和
-只从所述分布式哈希表检索到这些项的引用,所述项包含等于或者大于所述布隆1过滤器中的所述非空字的数量的字量。
4.根据权利要求1所述的方法,其中,所述值还包括指示所述内容项的所有权和/或访问控制的信息。
5.一种在分布式数据交换系统中用于存储和检索带标签的内容项的计算机执行的应用程序,所述应用程序包括用于存储带标签的内容项的以下装置:
A1.用于为与所述内容项相关的所述标签生成布隆1滤波器的装置;
A2.用于生成键的装置,所述键由所述布隆1滤波器的成员字与所述布隆1滤波器的成员字索引的并列组成键,所述成员字表示所述布隆1过滤器的非空部分;
A3.用于生成值的装置,所述值包括与所述内容项相关的所有标签的紧凑表示以及对所述内容项的存储位置的引用;和
A4.用于添加键值对到分布式哈希表的装置,所述键值对由所述键和所述值组成,
所述应用程序进一步包括用于检索带标签的内容项的以下装置:
B1.用于接收包含多个关键字的搜索查询的接口;
B2.用于从所述多个关键字中选择出关键字的装置;
B3.用于从所述分布式哈希表中检索具有以所述关键字作为相关标签的内容项的第一引用列表的装置;以及
B4.用于通过所有标签的所述紧凑表示过滤所述第一列表,以获得到包括以所述搜索的所有关键字作为相关标签的内容项的第二引用列表的装置。
Applications Claiming Priority (3)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
EP12290053.3 | 2012-02-14 | ||
EP12290053.3A EP2629212A1 (en) | 2012-02-14 | 2012-02-14 | Method for storing and searching tagged content items in a distributed system |
PCT/EP2013/052665 WO2013120798A1 (en) | 2012-02-14 | 2013-02-11 | Method for storing and searching tagged content items in a distributed system |
Publications (1)
Publication Number | Publication Date |
---|---|
CN104115146A true CN104115146A (zh) | 2014-10-22 |
Family
ID=47739235
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
CN201380008653.8A Pending CN104115146A (zh) | 2012-02-14 | 2013-02-11 | 在分布式系统中存储和搜索带标签的内容项的方法 |
Country Status (4)
Country | Link |
---|---|
US (1) | US20150039629A1 (zh) |
EP (1) | EP2629212A1 (zh) |
CN (1) | CN104115146A (zh) |
WO (1) | WO2013120798A1 (zh) |
Cited By (12)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN106445645A (zh) * | 2016-09-06 | 2017-02-22 | 北京百度网讯科技有限公司 | 用于执行分布式计算任务的方法和装置 |
CN107924408A (zh) * | 2015-08-25 | 2018-04-17 | 华为技术有限公司 | 在文件系统中搜索元数据和标签的异构索引的系统和方法 |
CN108021678A (zh) * | 2017-12-07 | 2018-05-11 | 北京理工大学 | 一种结构紧凑的键值对存储结构及快速键值对查找方法 |
CN108170672A (zh) * | 2017-12-22 | 2018-06-15 | 武汉数博科技有限责任公司 | 一种中文机构名称实时分析方法及系统 |
CN108268769A (zh) * | 2016-12-31 | 2018-07-10 | 中国移动通信集团四川有限公司 | 对用户执行数据访问授权的方法及系统 |
CN108959991A (zh) * | 2018-03-13 | 2018-12-07 | 中国科学院信息工程研究所 | Rfid标签检测方法、阅读器、rfid标签和后端服务器 |
CN110291515A (zh) * | 2017-02-13 | 2019-09-27 | 微软技术许可有限责任公司 | 计算系统中的分布式索引搜索 |
CN110427538A (zh) * | 2019-07-30 | 2019-11-08 | 北京奇艺世纪科技有限公司 | 一种数据查询方法、存储方法、装置及电子设备 |
CN111247518A (zh) * | 2017-10-25 | 2020-06-05 | 国际商业机器公司 | 数据库分片 |
CN111581328A (zh) * | 2020-04-21 | 2020-08-25 | 浙江华途信息安全技术股份有限公司 | 一种数据比对检测方法及系统 |
CN114328545A (zh) * | 2022-03-03 | 2022-04-12 | 北京蚂蚁云金融信息服务有限公司 | 数据存储及查询方法、装置及数据库系统 |
CN111247518B (zh) * | 2017-10-25 | 2024-05-14 | 国际商业机器公司 | 用于数据库分片的方法和系统 |
Families Citing this family (14)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
KR101436874B1 (ko) * | 2013-10-18 | 2014-09-11 | 한국전자통신연구원 | 침입 탐지 시스템의 탐지 성능 향상 장치 및 방법 |
US9847951B2 (en) * | 2013-11-04 | 2017-12-19 | Ciena Corporation | Dynamic bandwidth allocation systems and methods using content identification in a software-defined networking controlled multi-layer network |
US9668020B2 (en) | 2014-04-07 | 2017-05-30 | The Nielsen Company (Us), Llc | Signature retrieval and matching for media monitoring |
US9438940B2 (en) | 2014-04-07 | 2016-09-06 | The Nielsen Company (Us), Llc | Methods and apparatus to identify media using hash keys |
CN104333585B (zh) * | 2014-10-30 | 2016-06-22 | 中南大学 | 一种分布式环境下依赖性程序文件集的传输优化调度方法 |
US10282438B2 (en) | 2016-02-12 | 2019-05-07 | International Business Machines Corporation | Locating data in a set with a single index using multiple property values |
US10210195B2 (en) | 2016-02-12 | 2019-02-19 | International Business Machines Corporation | Locating data in a set with a single index using multiple property values |
US10594620B1 (en) | 2016-03-23 | 2020-03-17 | Amazon Technologies, Inc. | Bit vector analysis for resource placement in a distributed system |
US10749668B2 (en) | 2017-05-03 | 2020-08-18 | International Business Machines Corporation | Reduction in storage usage in blockchain |
US10839093B2 (en) | 2018-04-27 | 2020-11-17 | Nutanix, Inc. | Low latency access to physical storage locations by implementing multiple levels of metadata |
US10831521B2 (en) * | 2018-04-27 | 2020-11-10 | Nutanix, Inc. | Efficient metadata management |
US10970393B1 (en) * | 2018-12-18 | 2021-04-06 | Altiris, Inc. | Probabilistic set membership using bloom filters |
DK3859552T3 (da) * | 2020-01-30 | 2021-12-20 | Ovh | Fremgangsmåde og system til håndtering af indhold af datapakke/rammer under anvendelse af et tilpasset bloom-filter |
CN111651406B (zh) * | 2020-05-21 | 2023-07-25 | 杭州明讯软件技术有限公司 | 一种自动化载波调度系统文件读取方法及装置 |
Citations (3)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN102246172A (zh) * | 2008-10-13 | 2011-11-16 | 法卢资产有限公司 | 用于电子内容的分布式索引搜索的系统及方法 |
CN102253820A (zh) * | 2011-06-16 | 2011-11-23 | 华中科技大学 | 一种流式重复数据检测方法 |
US20120011150A1 (en) * | 2009-07-14 | 2012-01-12 | Ashwin Swaminathan | Methods and Apparatus for Efficiently Processing Multiple Keyword Queries on a Distributed Network |
-
2012
- 2012-02-14 EP EP12290053.3A patent/EP2629212A1/en not_active Withdrawn
-
2013
- 2013-02-11 US US14/378,402 patent/US20150039629A1/en not_active Abandoned
- 2013-02-11 WO PCT/EP2013/052665 patent/WO2013120798A1/en active Application Filing
- 2013-02-11 CN CN201380008653.8A patent/CN104115146A/zh active Pending
Patent Citations (3)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN102246172A (zh) * | 2008-10-13 | 2011-11-16 | 法卢资产有限公司 | 用于电子内容的分布式索引搜索的系统及方法 |
US20120011150A1 (en) * | 2009-07-14 | 2012-01-12 | Ashwin Swaminathan | Methods and Apparatus for Efficiently Processing Multiple Keyword Queries on a Distributed Network |
CN102253820A (zh) * | 2011-06-16 | 2011-11-23 | 华中科技大学 | 一种流式重复数据检测方法 |
Non-Patent Citations (2)
Title |
---|
MICHAEL T.GOODRICH等: "Invertible Bloom Lookup Tables", 《COMMUNICATION,CONTROL,AND COMPUTING(ALLERTON),2011 49TH ANNUAL ALLERTON CONFERENCE ON》 * |
YAN QIAO等: "One Memory Access Bloom Filters and their Generalization", 《INFOCOM,2011 PROCEEDINGS IEEE》 * |
Cited By (17)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN107924408A (zh) * | 2015-08-25 | 2018-04-17 | 华为技术有限公司 | 在文件系统中搜索元数据和标签的异构索引的系统和方法 |
CN107924408B (zh) * | 2015-08-25 | 2020-09-04 | 华为技术有限公司 | 在文件系统中搜索元数据和标签的异构索引的系统和方法 |
CN106445645A (zh) * | 2016-09-06 | 2017-02-22 | 北京百度网讯科技有限公司 | 用于执行分布式计算任务的方法和装置 |
CN108268769A (zh) * | 2016-12-31 | 2018-07-10 | 中国移动通信集团四川有限公司 | 对用户执行数据访问授权的方法及系统 |
CN110291515A (zh) * | 2017-02-13 | 2019-09-27 | 微软技术许可有限责任公司 | 计算系统中的分布式索引搜索 |
CN110291515B (zh) * | 2017-02-13 | 2023-08-15 | 微软技术许可有限责任公司 | 计算系统中的分布式索引搜索 |
CN111247518A (zh) * | 2017-10-25 | 2020-06-05 | 国际商业机器公司 | 数据库分片 |
CN111247518B (zh) * | 2017-10-25 | 2024-05-14 | 国际商业机器公司 | 用于数据库分片的方法和系统 |
CN108021678B (zh) * | 2017-12-07 | 2022-05-17 | 北京理工大学 | 一种结构紧凑的键值对存储结构及快速键值对查找方法 |
CN108021678A (zh) * | 2017-12-07 | 2018-05-11 | 北京理工大学 | 一种结构紧凑的键值对存储结构及快速键值对查找方法 |
CN108170672A (zh) * | 2017-12-22 | 2018-06-15 | 武汉数博科技有限责任公司 | 一种中文机构名称实时分析方法及系统 |
CN108959991A (zh) * | 2018-03-13 | 2018-12-07 | 中国科学院信息工程研究所 | Rfid标签检测方法、阅读器、rfid标签和后端服务器 |
CN110427538A (zh) * | 2019-07-30 | 2019-11-08 | 北京奇艺世纪科技有限公司 | 一种数据查询方法、存储方法、装置及电子设备 |
CN110427538B (zh) * | 2019-07-30 | 2023-01-20 | 北京奇艺世纪科技有限公司 | 一种数据查询方法、存储方法、装置及电子设备 |
CN111581328A (zh) * | 2020-04-21 | 2020-08-25 | 浙江华途信息安全技术股份有限公司 | 一种数据比对检测方法及系统 |
CN114328545A (zh) * | 2022-03-03 | 2022-04-12 | 北京蚂蚁云金融信息服务有限公司 | 数据存储及查询方法、装置及数据库系统 |
CN114328545B (zh) * | 2022-03-03 | 2022-07-08 | 北京蚂蚁云金融信息服务有限公司 | 数据存储及查询方法、装置及数据库系统 |
Also Published As
Publication number | Publication date |
---|---|
WO2013120798A1 (en) | 2013-08-22 |
US20150039629A1 (en) | 2015-02-05 |
EP2629212A1 (en) | 2013-08-21 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
CN104115146A (zh) | 在分布式系统中存储和搜索带标签的内容项的方法 | |
Haase et al. | Bibster–a semantics-based bibliographic peer-to-peer system | |
Koloniari et al. | Peer-to-peer management of XML data: issues and research challenges | |
Römer et al. | Real-time search for real-world entities: A survey | |
Tang et al. | pSearch: Information retrieval in structured overlays | |
US8938459B2 (en) | System and method for distributed index searching of electronic content | |
Löser et al. | Semantic overlay clusters within super-peer networks | |
KR100803769B1 (ko) | 미디어 아이템들을 클러스터링 및 조회하기 위한 방법 | |
US7523130B1 (en) | Storing and retrieving objects on a computer network in a distributed database | |
US8688708B2 (en) | Storing and retrieving objects on a computer network in a distributed database | |
US20030182270A1 (en) | Resource searching | |
Hua et al. | SmartEye: Real-time and efficient cloud image sharing for disaster environments | |
US20070271228A1 (en) | Documentary search procedure in a distributed system | |
Bender et al. | The MINERVA project: Database selection in the context of P2P search | |
Skoutas et al. | Efficient semantic web service discovery in centralized and p2p environments | |
CN110413807B (zh) | 一种基于内容语义元数据的图像查询方法与系统 | |
Tang et al. | pfilter: Global information filtering and dissemination using structured overlay networks | |
WO2006025061A1 (en) | System and method for classifying, publishing, searching and locating electronic documents | |
Zhang et al. | Storing and querying semi-structured spatio-temporal data in hbase | |
Vlachou et al. | Peer-to-peer query processing over multidimensional data | |
Blank et al. | Sample-based creation of peer summaries for efficient similarity search in scalable peer-to-peer networks | |
Nottelmann et al. | Search and browse services for heterogeneous collections with the peer-to-peer network Pepper | |
Klampanos et al. | Searching in peer-to-peer networks | |
Liu et al. | Datalens: making a good first impression | |
Bettini et al. | A distributed architecture for management and retrieval of extended points of interest |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
C06 | Publication | ||
PB01 | Publication | ||
C10 | Entry into substantive examination | ||
SE01 | Entry into force of request for substantive examination | ||
RJ01 | Rejection of invention patent application after publication | ||
RJ01 | Rejection of invention patent application after publication |
Application publication date: 20141022 |