一种残膜回收机防缠绕挑膜装置的制 一种秧草收获机用电力驱动行走机构

一种读取数据的方法、系统、设备以及介质与流程

2022-06-01 10:08:53 来源:中国专利 TAG:


1.本发明涉及存储领域,具体涉及一种读取数据的方法、系统、设备以及存储介质。


背景技术:

2.随着互联网、云计算、物联网等技术的发展及广泛应用,在人类生活中,时时刻刻都会产生海量的数据需要处理及存储,信息技术的高速发展对存储系统的性能提出了更高的要求。固态硬盘因其读写速度快、能耗较低,而被广泛采用。但由于nand本身的特性,每个lun是执行读写擦等基本操作的最小单位,即每个物理lun上的读消息都需要串行处理,当ssd盘上lun的数量比较小时,对性能的影响是很大的。


技术实现要素:

3.有鉴于此,为了克服上述问题的至少一个方面,本发明实施例提出一种读取数据的方法,包括以下步骤:
4.在每一个lun下创建与每一个plane对应的第一列表;
5.响应于所述lun接收到新的读请求消息,判断每一个所述第一列表中是否存在已接收到的所述读请求消息;
6.响应于若干个所述第一列表中存在已接收到的所述读请求消息,根据所述新的读请求消息对应的位置参数将所述新的读请求消息放入相应plane对应的第一列表中;
7.响应于当前正在处理其他读请求消息处理完成,从每一个所述第一列表中取出一个读请求消息并组合以得到组合后的读请求消息;
8.下发组合后的读请求消息以进行数据读取。
9.在一些实施例中,还包括:
10.响应于每一个所述第一列表中均不存在已接收到的所述读请求消息,判断是否存在已下发且未完成处理的组合后的读请求消息;
11.响应于不存在已下发且未完成处理的组合后的读请求消息,直接将新接收到的所述读请求消息进行下发以进行数据读取。
12.在一些实施例中,还包括:
13.响应于所述组合后的读请求消息处理完成,将所述组合后的读请求消息对应的完成消息再按照plane进行拆分;
14.将拆分后的完成消息分别返回。
15.在一些实施例中,还包括:
16.响应于所述组合后的读请求消息下发,删除每一个所述第一列表中相应的读请求消息。
17.基于同一发明构思,根据本发明的另一个方面,本发明的实施例还提供了一种读取数据的系统,包括:
18.创建模块,配置为在每一个lun下创建与每一个plane对应的第一列表;
19.第一判断模块,配置为响应于所述lun接收到新的读请求消息,判断每一个所述第一列表中是否存在已接收到的所述读请求消息;
20.转发模块,配置为响应于若干个所述第一列表中存在已接收到的所述读请求消息,根据所述新的读请求消息对应的位置参数将所述新的读请求消息放入相应plane对应的第一列表中;
21.合并模块,配置为响应于当前正在处理其他读请求消息处理完成,从每一个所述第一列表中取出一个读请求消息并组合以得到组合后的读请求消息;
22.下发模块,配置为下发组合后的读请求消息以进行数据读取。
23.在一些实施例中,还包括第二判断模块,配置为:
24.响应于每一个所述第一列表中均不存在已接收到的所述读请求消息,判断是否存在已下发且未完成处理的组合后的读请求消息;
25.响应于不存在已下发且未完成处理的组合后的读请求消息,直接将新接收到的所述读请求消息进行下发以进行数据读取。
26.在一些实施例中,还包括返回模块,配置为:
27.响应于所述组合后的读请求消息处理完成,将所述组合后的读请求消息对应的完成消息再按照plane进行拆分;
28.将拆分后的完成消息分别返回。
29.在一些实施例中,还包括删除模块,配置为:
30.响应于所述组合后的读请求消息下发,删除每一个所述第一列表中相应的读请求消息。
31.基于同一发明构思,根据本发明的另一个方面,本发明的实施例还提供了一种计算机设备,包括:
32.至少一个处理器;以及
33.存储器,所述存储器存储有可在所述处理器上运行的计算机程序,其特征在于,所述处理器执行所述程序时执行如上所述的任一种读取数据的方法的步骤。
34.基于同一发明构思,根据本发明的另一个方面,本发明的实施例还提供了一种计算机可读存储介质,所述计算机可读存储介质存储有计算机程序,所述计算机程序被处理器执行时执行如上所述的任一种读取数据的方法的步骤。
35.本发明具有以下有益技术效果之一:本发明提出的方案通过整合消息,在消除了多plane上对地址的限制,明显增加了读消息的并发程度,尤其是在lun的数量比较少的场景下,减少了读的整体的等待时间,性能提升的效果比较明显。
附图说明
36.为了更清楚地说明本发明实施例或现有技术中的技术方案,下面将对实施例或现有技术描述中所需要使用的附图作简单地介绍,显而易见地,下面描述中的附图仅仅是本发明的一些实施例,对于本领域普通技术人员来讲,在不付出创造性劳动的前提下,还可以根据这些附图获得其他的实施例。
37.图1为本发明的实施例提供的读取数据的方法的流程示意图;
38.图2为本发明的实施例提供的每一个lun的结构示意图;
39.图3为本发明的实施例提供的读取数据系统的结构示意图;
40.图4为本发明的实施例提供的计算机设备的结构示意图;
41.图5为本发明的实施例提供的计算机可读存储介质的结构示意图。
具体实施方式
42.为使本发明的目的、技术方案和优点更加清楚明白,以下结合具体实施例,并参照附图,对本发明实施例进一步详细说明。
43.需要说明的是,本发明实施例中所有使用“第一”和“第二”的表述均是为了区分两个相同名称非相同的实体或者非相同的参量,可见“第一”“第二”仅为了表述的方便,不应理解为对本发明实施例的限定,后续实施例对此不再一一说明。
44.根据本发明的一个方面,本发明的实施例提出一种读取数据的方法,如图1所示,其可以包括步骤:
45.s1,在每一个lun下创建与每一个plane对应的第一列表;
46.s2,响应于所述lun接收到新的读请求消息,判断每一个所述第一列表中是否存在已接收到的所述读请求消息;
47.s3,响应于若干个所述第一列表中存在已接收到的所述读请求消息,根据所述新的读请求消息对应的位置参数将所述新的读请求消息放入相应plane对应的第一列表中;
48.s4,响应于当前正在处理其他读请求消息处理完成,从每一个所述第一列表中取出一个读请求消息并组合以得到组合后的读请求消息;
49.s5,下发组合后的读请求消息以进行数据读取。
50.本发明提出的方案通过整合消息,在消除了多plane上对地址的限制,明显增加了读消息的并发程度,尤其是在lun的数量比较少的场景下,减少了读的整体的等待时间,性能提升的效果比较明显。
51.在一些实施例中,步骤s1中,在每一个lun下创建与每一个plane对应的第一列表,具体的,如图2所示,每个ssd盘会包含多个lun,lun是直接命令的最小单位,lun内同时存在多个plane数量一般为1、2、4、6等。依据nand特性,每个plane对应一组nand cache,可以用来缓存从nand获取的数据,即这些数据都可以一次完成读取。这样,为了降低管理难度,可以预先将ssd内所有channel均分为多个区域(partition),比如4个part,然后对于每个partition内,每个lun下均会针对每一个plane建立一个pending list(第一列表)。
52.在一些实施例中,还包括:
53.响应于每一个所述第一列表中均不存在已接收到的所述读请求消息,判断是否存在已下发且未完成处理的组合后的读请求消息;
54.响应于不存在已下发且未完成处理的组合后的读请求消息,直接将新接收到的所述读请求消息进行下发以进行数据读取。
55.具体的,当第一列表中不存在已接收到的所述读请求消息时,说明当前lun没有消息处于空闲状态或者已经将上一个读请求消息下发但未处理完成。如果当lun上接收到新的读请求消息时,若当前每一个第一列表上均没有读请求消息处理,则无需等待,直接根据读请求消息读取响应的数据后下发到nand cache。
56.在一些实施例中,还包括:
57.响应于所述组合后的读请求消息处理完成,将所述组合后的读请求消息对应的完成消息再按照plane进行拆分;
58.将拆分后的完成消息分别返回。
59.具体的,当这个组合的消息处理完成后,将完成消息再按照plane进行拆分,分别给host返回完成消息。这样,将组合在一起的消息下发时,由于多个plane可以同时处理,即提高的消息的并发程度。并且将完成消息(即读取到的数据)在根据不同的plane进行拆分,这样在返回数据时可以根据接收到的读请求消息返回对应的host.
60.在一些实施例中,还包括:
61.响应于所述组合后的读请求消息下发,删除每一个所述第一列表中相应的读请求消息。
62.具体的,当将所述第一列表的消息下发后,则将消息从第一列表中删除。
63.本发明提出的方案通过整合消息,在消除了多plane上对地址的限制,明显增加了读消息的并发程度,尤其是在lun的数量比较少的场景下,减少了读的整体的等待时间,性能提升的效果比较明显。
64.基于同一发明构思,根据本发明的另一个方面,本发明的实施例还提供了一种读取数据的系统400,如图3所示,包括:
65.创建模块401,配置为在每一个lun下创建与每一个plane对应的第一列表;
66.第一判断模块402,配置为响应于所述lun接收到新的读请求消息,判断每一个所述第一列表中是否存在已接收到的所述读请求消息;
67.转发模块403,配置为响应于若干个所述第一列表中存在已接收到的所述读请求消息,根据所述新的读请求消息对应的位置参数将所述新的读请求消息放入相应plane对应的第一列表中;
68.合并模块404,配置为响应于当前正在处理其他读请求消息处理完成,从每一个所述第一列表中取出一个读请求消息并组合以得到组合后的读请求消息;
69.下发模块405,配置为下发组合后的读请求消息以进行数据读取。
70.在一些实施例中,还包括第二判断模块,配置为:
71.响应于每一个所述第一列表中均不存在已接收到的所述读请求消息,判断是否存在已下发且未完成处理的组合后的读请求消息;
72.响应于不存在已下发且未完成处理的组合后的读请求消息,直接将新接收到的所述读请求消息进行下发以进行数据读取。
73.在一些实施例中,还包括返回模块,配置为:
74.响应于所述组合后的读请求消息处理完成,将所述组合后的读请求消息对应的完成消息再按照plane进行拆分;
75.将拆分后的完成消息分别返回。
76.在一些实施例中,还包括删除模块,配置为:
77.响应于所述组合后的读请求消息下发,删除每一个所述第一列表中相应的读请求消息。
78.本发明提出的方案通过整合消息,在消除了多plane上对地址的限制,明显增加了读消息的并发程度,尤其是在lun的数量比较少的场景下,减少了读的整体的等待时间,性
能提升的效果比较明显。
79.基于同一发明构思,根据本发明的另一个方面,如图4所示,本发明的实施例还提供了一种计算机设备501,包括:
80.至少一个处理器520;以及
81.存储器510,存储器510存储有可在处理器上运行的计算机程序511,处理器520执行程序时执行如上的任一种读取数据的方法的步骤。
82.基于同一发明构思,根据本发明的另一个方面,如图5所示,本发明的实施例还提供了一种计算机可读存储介质601,计算机可读存储介质601存储有计算机程序指令610,计算机程序指令610被处理器执行时执行如上的任一种读取数据的方法的步骤。
83.最后需要说明的是,本领域普通技术人员可以理解实现上述实施例方法中的全部或部分流程,可以通过计算机程序来指令相关硬件来完成,程序可存储于一计算机可读取存储介质中,该程序在执行时,可包括如上述各方法的实施例的流程。
84.此外,应该明白的是,本文的计算机可读存储介质(例如,存储器)可以是易失性存储器或非易失性存储器,或者可以包括易失性存储器和非易失性存储器两者。
85.本领域技术人员还将明白的是,结合这里的公开所描述的各种示例性逻辑块、模块、电路和算法步骤可以被实现为电子硬件、计算机软件或两者的组合。为了清楚地说明硬件和软件的这种可互换性,已经就各种示意性组件、方块、模块、电路和步骤的功能对其进行了一般性的描述。这种功能是被实现为软件还是被实现为硬件取决于具体应用以及施加给整个系统的设计约束。本领域技术人员可以针对每种具体应用以各种方式来实现的功能,但是这种实现决定不应被解释为导致脱离本发明实施例公开的范围。
86.以上是本发明公开的示例性实施例,但是应当注意,在不背离权利要求限定的本发明实施例公开的范围的前提下,可以进行多种改变和修改。根据这里描述的公开实施例的方法权利要求的功能、步骤和/或动作不需以任何特定顺序执行。此外,尽管本发明实施例公开的元素可以以个体形式描述或要求,但除非明确限制为单数,也可以理解为多个。
87.应当理解的是,在本文中使用的,除非上下文清楚地支持例外情况,单数形式“一个”旨在也包括复数形式。还应当理解的是,在本文中使用的“和/或”是指包括一个或者一个以上相关联地列出的项目的任意和所有可能组合。
88.上述本发明实施例公开实施例序号仅仅为了描述,不代表实施例的优劣。
89.本领域普通技术人员可以理解实现上述实施例的全部或部分步骤可以通过硬件来完成,也可以通过程序来指令相关的硬件完成,程序可以存储于一种计算机可读存储介质中,上述提到的存储介质可以是只读存储器,磁盘或光盘等。
90.所属领域的普通技术人员应当理解:以上任何实施例的讨论仅为示例性的,并非旨在暗示本发明实施例公开的范围(包括权利要求)被限于这些例子;在本发明实施例的思路下,以上实施例或者不同实施例中的技术特征之间也可以进行组合,并存在如上的本发明实施例的不同方面的许多其它变化,为了简明它们没有在细节中提供。因此,凡在本发明实施例的精神和原则之内,所做的任何省略、修改、等同替换、改进等,均应包含在本发明实施例的保护范围之内。
再多了解一些

本文用于企业家、创业者技术爱好者查询,结果仅供参考。

发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表

相关文献