[发明专利]读写分离的固态存储设备的数据分布方法在审

专利信息
申请号: 202110217313.2 申请日: 2016-03-17
公开(公告)号: CN113377695A 公开(公告)日: 2021-09-10
发明(设计)人: 王利虎;王田;欧阳涛;吴忠杰 申请(专利权)人: 北京忆恒创源科技有限公司
主分类号: G06F13/16 分类号: G06F13/16;G06F13/42
代理公司: 北京卓特专利代理事务所(普通合伙) 11572 代理人: 段旺
地址: 100192 北京市海淀区西小口*** 国省代码: 北京;11
权利要求书: 查看更多 说明书: 查看更多
摘要:
搜索关键词: 读写 分离 固态 存储 设备 数据 分布 方法
【权利要求书】:

1.一种数据写入方法,所述方法包括:

将数据写入缓冲区,向写请求发出方应答写入成功;

将缓存区中的数据聚合成指定大小的数据集;以及

将数据集顺序写入活动存储对象,其中为写数据分配空存储对象后,所分配的空存储对象成为活动存储对象,存储对象包括多个条带;其中,由第一线程组的线程执行所述将缓存区中的数据聚合成指定大小的数据集,以及将数据集顺序写入存储对象的操作。

2.根据权利要求1所述的方法,其中,第一线程组中包括第一线程与第二线程,第一线程获得活动存储对象使用权后,向活动存储对象写入数据,释放活动存储对象使用权;第二线程获得活动存储对象使用权后,向活动存储对象写入数据,释放活动存储对象使用权。

3.根据权利要求1所述的方法,其中,存储系统中存在多个活动存储对象;第一线程组中包括第一线程与第二线程,第一线程将数据集写入一个或多个第一活动存储对象,第二线程将数据集写入一个或多个第二活动存储对象。

4.根据权利要求3所述的方法,其中,所述一个或多个第一活动存储对象仅由第一线程写入数据,所述一个或多个第二活动存储对象仅由第二线程写入数据。

5.根据权利要求1-4之一所述的方法,其中,写请求同逻辑设备相关联,将访问相同逻辑设备的多个写请求写入同一个的活动存储对象。

6.根据权利要求5所述的方法,其中访问不同的逻辑设备的两个写请求不会被写入相同的活动存储对象。

7.根据权利要求1所述的方法,其中,第一线程组中包括第一线程与第二线程,第一线程维护一个或多个第一活动存储对象,第二线程维护一个或多个第二活动存储对象;写请求来自多个逻辑设备,第一线程将来自第一逻辑设备的数据聚合成第一数据集,并写入第一活动存储对象,第二线程将来自第二逻辑设备的数据聚合成第二数据集,并写入第二活动存储对象。

8.根据权利要求1-7之一所述的方法,其中,存在多个活动存储对象,第一多个活动存储对象用于存储冷数据,第二活动存储对象用于存储热数据;在接收到写请求时,基于所写入数据的特点,将数据写入第一多个活动存储对象或第二多个活动存储对象。

9.一种IO请求处理方法,所述方法包括:

接收读请求,所述读请求将读取第一数据,

若所述第一数据尚未被分配存储对象,从缓冲区中获取第一数据;

若已经为所述第一数据分配存储对象,存储对象是活动状态,但第一数据尚未完成持久化,则从缓冲区中获取第一数据;其中为写数据分配空存储对象后,所分配的空存储对象变为活动状态,存储对象包括多个条带;

若已经为第一数据分配容器存储对象,且存储对象是只读状态,从为第一数据分配的存储对象中获取第一数据;

所述方法还包括:

根据权利要求1-8之一所述的数据写入方法。

10.一种信息处理设备,包括存储器、处理器及存储在存储器上并可在处理器上运行的程序,其特征在于,所述处理器执行所述程序时实现根据权利要求1-9之一所述的方法。

下载完整专利技术内容需要扣除积分,VIP会员可以免费下载。

该专利技术资料仅供研究查看技术是否侵权等信息,商用须获得专利权人授权。该专利全部权利属于北京忆恒创源科技有限公司,未经北京忆恒创源科技有限公司许可,擅自商用是侵权行为。如果您想购买此专利、获得商业授权和技术合作,请联系【客服

本文链接:http://www.vipzhuanli.com/pat/books/202110217313.2/1.html,转载请声明来源钻瓜专利网。

×

专利文献下载

说明:

1、专利原文基于中国国家知识产权局专利说明书;

2、支持发明专利 、实用新型专利、外观设计专利(升级中);

3、专利数据每周两次同步更新,支持Adobe PDF格式;

4、内容包括专利技术的结构示意图流程工艺图技术构造图

5、已全新升级为极速版,下载速度显著提升!欢迎使用!

请您登陆后,进行下载,点击【登陆】 【注册】

关于我们 寻求报道 投稿须知 广告合作 版权声明 网站地图 友情链接 企业标识 联系我们

钻瓜专利网在线咨询

周一至周五 9:00-18:00

咨询在线客服咨询在线客服
tel code back_top