[发明专利]一种历史版本对象列举方法、装置及其介质在审
申请号: | 202210832787.2 | 申请日: | 2022-07-15 |
公开(公告)号: | CN115114232A | 公开(公告)日: | 2022-09-27 |
发明(设计)人: | 袁圣骐;赵煜 | 申请(专利权)人: | 济南浪潮数据技术有限公司 |
主分类号: | G06F16/11 | 分类号: | G06F16/11;G06F16/13;G06F16/16 |
代理公司: | 北京集佳知识产权代理有限公司 11227 | 代理人: | 薛娇 |
地址: | 250101 山东省济南市自由贸易试验区*** | 国省代码: | 山东;37 |
权利要求书: | 查看更多 | 说明书: | 查看更多 |
摘要: | |||
搜索关键词: | 一种 历史 版本 对象 列举 方法 装置 及其 介质 | ||
本申请公开了一种历史版本对象列举方法、装置及其介质,涉及对象存储技术领域,用于对历史版本对象进行列举,针对目前的列举历史版本对象的方法效率低下且对存储系统性能影响大的问题,提供了一种历史版本对象列举方法,利用对象存储底层机制中支持根据指定的前缀名来获取索引分片上特定记录的机制,使得在进行历史版本对象的列举时,可以获取包括历史版本前缀名的所有键值对记录,进而遍历获取对象的基本信息,将其作为列举结果返回,完成历史版本对象列举过程。无需遍历每一索引分片中的所有键值对,避免了无效遍历的时间消耗,同时也减轻了存储系统进行历史版本对象列举时的工作量,降低对其性能的影响。
技术领域
本申请涉及对象存储技术领域,特别是涉及一种历史版本对象列举方法、装置及其介质。
背景技术
随着互联网技术的发展,互联网数据量,尤其是非结构化数据的数据量增长的越来越块,分布式对象存储应运而生。这种新兴的存储方式,适用于图片、视频等非结构化数据的存储。它同时又具有块存储高速直接访问磁盘的特点以及文件存储分布式共享的特点,因此一经推出就得到广泛的发展与应用。分布式对象存储具有多版本功能,当向同一个存储桶内重复上传同名文件时,为每一个同名文件设置随机生成的版本id,用于唯一的标识不同版本的对象,同时区别于同名文件覆盖机制,多版本不会删除之前的同名文件,而是将同名文件指定了版本id后存储在系统中。
目前,在用户请求列举分布式对象存储系统中保存数据的历史版本时,需要遍历存储桶中的每一索引分片,每一索引分片又存储着大量键值对(key-value),其中,key包括对象名和版本id,value包括对象的基本信息。遍历所有的索引分片、以及每一索引分片下的所有键值对后,将带有历史版本标记的对象作为列举结果返回。这种遍历所有存储对象的方式耗时长、效率低,当存储对象数量巨大时,还会严重影响存储系统的性能。
所以,现在本领域的技术人员亟需要一种历史版本对象列举方法,解决目前的列举历史版本对象的方法效率低下且对存储系统性能影响大的问题。
发明内容
本申请的目的是提供一种历史版本对象列举方法、装置及其介质,以解决目前的列举历史版本对象的方法效率低下且对存储系统性能影响大的问题。
为解决上述技术问题,本申请提供一种历史版本对象列举方法,包括:
当接收到历史版本对象列举请求时,根据历史版本前缀名获取目标键值对;其中,历史版本前缀名为当有同名对象新增时,添加并存储在历史版本对象键值对中的前缀名;
遍历获取到的目标键值对,以获取历史版本对象的对象信息;
将历史版本对象的对象信息作为列举结果返回。
优选的,还包括:
接收由用户端上传的对象文件,并保存在对应的存储桶中;
若对象文件为存储桶中已有对象的同名对象文件时,为已有对象新增键值对记录;其中,键值对中的key包括:历史版本前缀名、对象名和版本id。
优选的,历史版本列举请求还包括:请求对象名;
对应的,还包括:
对获取到的目标键值对根据请求对象名进行筛选,滤除对象名不为请求对象名的键值对,以获取新的目标键值对。
优选的,历史版本列举请求还包括:请求版本id;
对应的,还包括:
对获取到的目标键值对根据请求版本id进行筛选,滤除版本id不为请求版本id的键值对,以获取新的目标键值对。
优选的,在为已有对象新增键值对记录之后,还包括:
将已有对象的原键值对记录删除。
优选的,保存在对应的存储桶中包括:
该专利技术资料仅供研究查看技术是否侵权等信息,商用须获得专利权人授权。该专利全部权利属于济南浪潮数据技术有限公司,未经济南浪潮数据技术有限公司许可,擅自商用是侵权行为。如果您想购买此专利、获得商业授权和技术合作,请联系【客服】
本文链接:http://www.vipzhuanli.com/pat/books/202210832787.2/2.html,转载请声明来源钻瓜专利网。
- 上一篇:一种测试用例生成方法、系统及装置
- 下一篇:防堵落料管