[发明专利]Hadoop环境下多维索引结构OBF-Index的实现方法有效
申请号: | 201711426263.9 | 申请日: | 2017-12-26 |
公开(公告)号: | CN108121807B | 公开(公告)日: | 2021-06-04 |
发明(设计)人: | 李劲;刘建坤;窦奇伟;何臻力;周维 | 申请(专利权)人: | 云南大学 |
主分类号: | G06F16/22 | 分类号: | G06F16/22;G06F16/27 |
代理公司: | 成都行之专利代理事务所(普通合伙) 51220 | 代理人: | 温利平;陈靓靓 |
地址: | 650091*** | 国省代码: | 云南;53 |
权利要求书: | 查看更多 | 说明书: | 查看更多 |
摘要: | |||
搜索关键词: | hadoop 环境 多维 索引 结构 obf index 实现 方法 | ||
1.一种Hadoop环境下多维索引结构OBF-Index的实现方法,其特征在于包括以下步骤:
S1:对数据集进行划分得到数据分片;
S2:对每个数据分片分别生成一个OBF索引文件并存储,构建得到OBF-Index,生成OBF索引文件的具体方法为:首先对数据分片进行处理,如果是一维数据则不作任何操作,如果是多维数据,将其映射为一维数据;为数据分片初始化一个OBF索引对象,该OBF索引对象中每个位置的初始值为绝对大值,依次读取数据分片的一维数据中的第n个元素an,n=1,2,…,N,将其插入OBF索引对象,插入方法为:根据K个哈希函数hk计算得到其K个位置hk(an),记位置hk(an)原有值为F0(hk(an)),令第hk(an)个位置的值F(hk(an))=min{k,F0(hk(an))};将得到的OBF索引对象序列化为OBF索引文件;
S3:在需要使用数据集时,首先设置需要使用的数据集合A,然后分别读取每个数据分片的OBF索引文件并反序列化得到OBF索引对象,利用OBF索引对象查询数据集合A中的数据是否存在于该数据分片中,如果是,则将该数据分片传递给相应的Mapper,否则不作任何操作;查询方法为:记需要查询的数据为x,根据K个哈希函数hk计算得到K个位置hk(x),记hk(x)对应位置的原有值为F0(hk(x)),如果所有k≥F0(hk(x))均为真,则该数据存在该OBF索引对象对应的数据分片中,否则不存在。
2.根据权利要求1所述的Hadoop环境下多维索引结构OBF-Index的实现方法,其特征在于,采用MapReduce的方式进行所述OBF索引文件的生成,具体方法为:设置Reducer个数为0,在Map方法中,将每一条记录按分隔符分隔开,转换为一维数据;然后按照插入方法依次将一维数据中每个元素插入到OBF索引对象中;当处理完所有记录后,将当前数据分片的路径和偏移量组合为id,并将此id作为输出文件名的一部分,将OBF索引对象按字节的形式存储到HDFS上,即序列化为OBF索引文件存储。
3.根据权利要求1所述的Hadoop环境下多维索引结构OBF-Index的实现方法,其特征在于,在OBF-Index构建之前,先对OBF-Index构建的相关参数进行分析,分析方法为:预先收集若干OBF-Index构建时的索引环境,索引环境包括集群、数据集、索引三个对象的属性,如果能成功构建OBF-Index则记其标签为1,否则为0,将索引环境作为输入,对应标签作为期望输出,训练得到回归模型;然后在OBF-Index构建之构建前,将其索引环境输入回归模型,根据输出判定是否能构建成功,如果能构建成功,则构建OBF-Index,否则提示操作人员检查索引环境。
该专利技术资料仅供研究查看技术是否侵权等信息,商用须获得专利权人授权。该专利全部权利属于云南大学,未经云南大学许可,擅自商用是侵权行为。如果您想购买此专利、获得商业授权和技术合作,请联系【客服】
本文链接:http://www.vipzhuanli.com/pat/books/201711426263.9/1.html,转载请声明来源钻瓜专利网。