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

数据处理方法、装置、计算机设备及存储介质与流程

2023-01-15 17:29:09 来源:中国专利 TAG:


1.本发明实施例涉及计算机数据存储领域,尤其涉及一种数据处理方法、装置、计算机设备及存储介质。


背景技术:

[0002]“数字化转型”近来成为各行各业的热词,它对业务(流程、场景、关系、参与人)进行重新定义,涉及到计算、存储、传输、交互等it技术。其中,存储作为数字化转型的it基座,数字化转型对存储的需求巨大,国际数据公司预计到2025年全球数据总量将达175zb,因此,高性能、高可靠、低单位容量价格的存储系统成为存储业界的追求。it系统中的性能瓶颈大部分来自于存储,但目前ssd的单位价格是hdd单位价格的10倍以上,大部分业务系统的io模型都满足局部性原理,从而使用小容量的ssd作为大容量hdd的缓存(cache),成为一部分业务系统的低成本加速存储的解决方案,满足高性能和低单位容量价格的要求。
[0003]
块缓存(block cache,bcache)是业界使用比较普遍的hdd加速解决方案,但bcache中空间管理bucket状态机目前存在如下设计缺陷:bucket状态机为层次状态机,在进入第二层状态机后,会改变所有bucket状态,此时要求bucket不可淘汰重复使用,此时可用的bucket可能很多也可能很少。在出现大量随机小io写情况下,进入第二层状态机时,在元数据垃圾回收(garbagecollection,gc)过程中出现缓存空间淘汰流程无法启动,在无缓存盘空间时hang住写io,在业务上表现为业务性能归零的情况,归零时间较长导致业务io长时间不返回,有引发业务中断的风险。如图1所示,为现有的使用3节点ceph存储测试128并发8k随机写780秒,业务端统计有长达30s以上的归零时间。


技术实现要素:

[0004]
鉴于此,为解决上述技术问题或部分技术问题,本发明实施例提供一种数据处理方法、装置、计算机设备及存储介质。
[0005]
第一方面,本发明实施例提供一种数据处理方法,包括:
[0006]
获取待存储的应用数据,以及将所述应用数据按照预设数据结构缓存在缓存盘对应的第一存储空间中;
[0007]
实时检测所述缓存盘的全部第一存储空间的数据存储状态;
[0008]
在所述数据存储状态为第一状态时,将第一状态对应的第一存储空间中存储的数据转存到主存盘对应的第二存储空间中;
[0009]
在所述数据存储状态为第二状态时,控制垃圾回收程序对所述第二状态对应的第一存储空间中存储的数据进行清除。
[0010]
在一个可能的实施方式中,所述方法还包括:
[0011]
在所述垃圾回收程序对全部第一存储空间进行巡检时,控制全部第一存储空间的数据存储状态不变。
[0012]
在一个可能的实施方式中,所述方法还包括:
[0013]
基于第一存储空间中存储数据对应的数据结构,确定所述缓存盘的全部第一存储空间的数据存储状态。
[0014]
在一个可能的实施方式中,所述方法还包括:
[0015]
获取所述数据结构中标识的数据存储位置;
[0016]
若当前第一存储空间中存储的数据未存在于所述主存盘中,则确定当前第一存储空间的数据存储状态为第一状态;
[0017]
若当前第一存储空间中存储的数据存在于所述主存盘中,则确定当前第一存储空间的数据存储状态为第二状态。
[0018]
在一个可能的实施方式中,所述方法还包括:
[0019]
将数据清除后的第一存储空间释放,以用于重新缓存数据。
[0020]
在一个可能的实施方式中,所述缓存盘为一个,所述主存盘为多个;
[0021]
所述缓存盘与多个主存盘之间数据全映射。
[0022]
第二方面,本发明实施例提供一种数据处理装置,包括:
[0023]
获取模块,用于获取待存储的应用数据,以及将所述应用数据按照预设数据结构缓存在缓存盘对应的第一存储空间中;
[0024]
检测模块,用于实时检测所述缓存盘的全部第一存储空间的数据存储状态;
[0025]
存储模块,用于在所述数据存储状态为第一状态时,将第一状态对应的第一存储空间中存储的数据转存到主存盘对应的第二存储空间中;
[0026]
垃圾回收模块,用于在所述数据存储状态为第二状态时,控制垃圾回收程序对所述第二状态对应的第一存储空间中存储的数据进行清除。
[0027]
在一个可能的实施方式中,所述装置还包括:
[0028]
控制模块,用于在所述垃圾回收程序对全部第一存储空间进行巡检时,控制全部第一存储空间的数据存储状态不变。
[0029]
第三方面,本发明实施例提供一种计算机设备,包括:处理器和存储器,所述处理器用于执行所述存储器中存储的数据处理程序,以实现上述第一方面中所述的数据处理方法。
[0030]
第四方面,本发明实施例提供一种存储介质,包括:所述存储介质存储有一个或者多个程序,所述一个或者多个程序可被一个或者多个处理器执行,以实现上述第一方面中所述的数据处理方法。
[0031]
本发明实施例提供的数据处理方案,通过获取待存储的应用数据,以及将所述应用数据按照预设数据结构缓存在缓存盘对应的第一存储空间中;实时检测所述缓存盘的全部第一存储空间的数据存储状态;在所述数据存储状态为第一状态时,将第一状态对应的第一存储空间中存储的数据转存到主存盘对应的第二存储空间中;在所述数据存储状态为第二状态时,控制垃圾回收程序对所述第二状态对应的第一存储空间中存储的数据进行清除,相比于现有技术中元数据垃圾回收过程中出现缓存盘对数据存储不做处理,在业务上表现为业务性能归零的情况,由本方案,通过允许垃圾回收程序执行,但不允许垃圾回收过程中改变存储空间的数据存储状态,可以避免垃圾回收过程中出现缓存盘对数据存储不做处理引发业务中断以及时延较大的问题,提高数据处理效率。
附图说明
[0032]
图1为现有技术的缓存盘数据存储的性能曲线图;
[0033]
图2为本发明实施例提供的一种数据处理方法的流程示意图;
[0034]
图3为本发明实施例提供的另一种数据处理方法的流程示意图;
[0035]
图4为本发明实施例提供的一种缓存盘与多个主存盘的数据映射架构图;
[0036]
图5为本发明实施例提供的一种数据结构图;
[0037]
图6为本发明实施例提供的一种bucket空间管理结构图;
[0038]
图7为现有技术的状态机示意图;
[0039]
图8为本发明实施例提供的一种状态机示意图;
[0040]
图9为现有技术和本发明实施例的缓存盘数据存储的性能对比曲线图;
[0041]
图10为本发明实施例提供的一种数据处理装置的结构示意图;
[0042]
图11为本发明实施例提供的一种计算机设备的结构示意图。
具体实施方式
[0043]
为使本发明实施例的目的、技术方案和优点更加清楚,下面将结合本发明实施例中的附图,对本发明实施例中的技术方案进行清楚、完整地描述,显然,所描述的实施例是本发明一部分实施例,而不是全部的实施例。基于本发明中的实施例,本领域普通技术人员在没有做出创造性劳动前提下所获得的所有其他实施例,都属于本发明保护的范围。
[0044]
为便于对本发明实施例的理解,下面将结合附图以具体实施例做进一步的解释说明,实施例并不构成对本发明实施例的限定。
[0045]
图2为本发明实施例提供的一种数据处理方法的流程示意图,如图2所示,该方法具体包括:
[0046]
本发明主要优化现有linux内核中的盘级缓存模块,利用bcache进行数据管理,bcache模块将高速介质如ssd或scm抽象为一个缓存盘,支持writeback、writethrough、和writearound三种模式,在writeback模式下,数据在缓存盘内进行缓存,然后按照对主存盘例如hdd友好的顺序方式进行组织,将缓存数据写到主存盘中。
[0047]
bcache的数据映射方式可以看作为一种全相联映射的变种。bcache内部将主存盘抽象为设备逻辑id号,将整个缓存盘抽象为一个缓存集(cache_set),从而实现一个缓存盘和多个主存盘之间的数据全映射关系,对应实现了多个主存盘共享一个缓存盘的逻辑,简化了维护操作,架构如图4所示。
[0048]
s21、获取待存储的应用数据,以及将所述应用数据按照预设数据结构缓存在缓存盘对应的第一存储空间中。
[0049]
本发明实施例中,获取待存储的应用数据,并将该应用数据按照预设数据结构缓存在缓存盘对应的第一存储空间中,由于缓存盘和多个主存盘之间的数据全映射关系,缓存盘中除了缓存元数据位置,缓存盘的一个空间可能映射给主存盘的任意空间,所有的应用数据io的元数据组织成b 树的数据结构,这种数据结构能够加快查询速度和内存-磁盘间换入和换出速度,数据和元数据的组织关系如图5所示。
[0050]
缓存盘的数据布局采用分段布局的方式,空间管理以bucket为单位做空间管理。其中,第一个bucket用于存放缓存超级块信息,包含缓存的基本信息,超级块bucket的位置
在缓存盘上是固定的。
[0051]
紧邻超级块bucket的是日志bucket,日志bucket目前有多个功能,包括:1、记录应用io的元数据用于缓存更新加速;2、元数据b 树根bucket位置;3、存放所有bucket信息的链表头位置;4、存放所有主存盘uuid的bucket位置,日志bucket的位置在缓存盘上也是固定的。
[0052]
剩下的bucket中包括:1、b 树bucket;2、存放所有bucket信息的bucket;3、存放uuid的bucket均为随机分配并确定为元数据bucket;4、数据bucket。如图6所示的一种bucket空间管理结构图。本发明实施例中的第一存储空间可以为bucket。
[0053]
bcache管理磁盘空间的基本单位是bucket,每个待存储的应用数据进入缓存盘后都需要分配bucket空间,数据写入到bucket后插入b 树,一次写io即完成。采用这种方式,在writeback模式下bucket中写入数据进入数据占用状态后,目前社区采用的bcache状态机只能通过垃圾回收第二层状态机将bucket从数据占用状态迁移到非数据占用状态,状态机如图7所示。
[0054]
从状态机图中可以看出,垃圾回收程序启动后,进入第二层状态机,所有的bucket的状态都迁移到了gc_mark=0,此时如果淘汰事件产生将导致数据占用状态和非数据占用状态的bucket都会被淘汰重复使用,这将导致缓存盘上的和存储盘上的数据不一致。现有技术的解决方法就是垃圾回收过程中,不允许淘汰事件发生,此时bcache内的bucket可用空间可能很多,也可能只有1个,在大量小io的情况下,垃圾回收可能持续40多秒,耗尽最后一个bucket后,就会出现写io hung住即写io性能会归零,反复读同一个位置,缓存盘也无法缓存新的数据,造成读性能和hdd持平。
[0055]
s22、实时检测所述缓存盘的全部第一存储空间的数据存储状态。
[0056]
将bcache的第一存储空间的双层状态机变成单层状态机,实时检测缓存盘的全部第一存储空间的数据存储状态,其中,可以增加第一存储空间中dirty_data=0的事件,由该事件表征第一存储空间的数据存储状态,在第一存储空间中缓存数据后,且该数据未被存储到主存盘,则确定dirty_data=1,即第一存储空间的数据存储状态为第一状态,第一状态指第一存储空间中存储的数据未存在于主存盘中。
[0057]
可选的,在第一存储空间中未缓存数据时,则确定dirty_data=0,即第一存储空间的数据存储状态为第二状态,第二状态指第一存储空间中未存在缓存数据。
[0058]
s23、在所述数据存储状态为第一状态时,将第一状态对应的第一存储空间中存储的数据转存到主存盘对应的第二存储空间中。
[0059]
在所述第一存储空间的数据存储状态为第一状态时,将第一状态对应的第一存储空间中存储的数据转存到主存盘对应的第二存储空间中。
[0060]
s24、在所述数据存储状态为第二状态时,控制垃圾回收程序对所述第二状态对应的第一存储空间中存储的数据进行清除。
[0061]
在所述第一存储空间的数据存储状态为第二状态时,控制垃圾回收程序对第二状态对应的第一存储空间中存储的数据进行清除。
[0062]
需要说明的是,在所述垃圾回收程序对全部第一存储空间进行巡检时,控制全部第一存储空间的数据存储状态不变,即第一存储空间的双层状态机变成单层状态机,不再根据状态机改变数据存储状态。
[0063]
本发明实施例提供的数据处理方法,通过获取待存储的应用数据,以及将所述应用数据按照预设数据结构缓存在缓存盘对应的第一存储空间中;实时检测所述缓存盘的全部第一存储空间的数据存储状态;在所述数据存储状态为第一状态时,将第一状态对应的第一存储空间中存储的数据转存到主存盘对应的第二存储空间中;在所述数据存储状态为第二状态时,控制垃圾回收程序对所述第二状态对应的第一存储空间中存储的数据进行清除,相比于现有技术中元数据垃圾回收过程中出现缓存盘对数据存储不做处理,在业务上表现为业务性能归零的情况,由本方法,通过允许垃圾回收程序执行,但不允许垃圾回收过程中改变存储空间的数据存储状态,可以避免垃圾回收过程中出现缓存盘对数据存储不做处理引发业务中断以及时延较大的问题,提高数据处理效率。
[0064]
图3为本发明实施例提供的另一种数据处理方法的流程示意图,如图3所示,该方法具体包括:
[0065]
s31、获取所述数据结构中标识的数据存储位置。
[0066]
本发明实施例中,获取待存储的应用数据,并将该应用数据按照预设数据结构缓存在缓存盘对应的第一存储空间中,由于缓存盘和多个主存盘之间的数据全映射关系,缓存盘中除了缓存元数据位置,缓存盘的一个空间可能映射给主存盘的任意空间,所有的应用数据io的元数据组织成b 树的数据结构,这种数据结构能够加快查询速度和内存-磁盘间换入和换出速度,数据和元数据的组织关系如图5所示。
[0067]
根据数据和元数据的组织关系,可以获取数据结构中标识的数据存储位置(仅存在于缓存盘或缓存盘和主存盘均存在)。
[0068]
s32、若当前第一存储空间中存储的数据未存在于所述主存盘中,则确定当前第一存储空间的数据存储状态为第一状态。
[0069]
s33、若当前第一存储空间中存储的数据存在于所述主存盘中,则确定当前第一存储空间的数据存储状态为第二状态。
[0070]
在第一存储空间中缓存数据后,且该数据未存在于主存盘中,则确定dirty_data=1,即第一存储空间的数据存储状态为第一状态,第一状态指第一存储空间中存储的数据未存在于主存盘中。
[0071]
可选的,在第一存储空间中未缓存数据时,则确定dirty_data=0,即第一存储空间的数据存储状态为第二状态,第二状态指第一存储空间中未存在缓存数据。
[0072]
s34、控制垃圾回收程序对所述第二状态对应的第一存储空间中存储的数据进行清除。
[0073]
s35、将数据清除后的第一存储空间释放,以用于重新缓存数据。
[0074]
在第一存储空间的数据存储状态为第二状态时,控制垃圾回收程序对第二状态对应的第一存储空间中存储的数据进行清除,将数据清除后的第一存储空间释放,以用于重新缓存数据。
[0075]
需要说明的是,在垃圾回收程序对全部第一存储空间进行巡检时,控制全部第一存储空间的数据存储状态不变,即第一存储空间的双层状态机变成单层状态机,不再根据状态机改变数据存储状态,垃圾回收过程中允许淘汰事件产生,禁止垃圾回收期间触发第一存储空间的状态迁移。如图8为本发明实施例提供的单层状态机示意图。
[0076]
图9为现有技术和本发明实施例的缓存盘数据存储的性能对比曲线图,从图中可
以看出,本发明解决了bcache使用过程中写io性能归零或秒级时延的问题;3节点ceph,128并发,8kb随机写,性能提升40%以上,平均iops从25914.2提升至36412.9,平均时延从4.9ms降至3.5ms。
[0077]
本发明实施例提供的数据处理方法,通过获取待存储的应用数据,以及将所述应用数据按照预设数据结构缓存在缓存盘对应的第一存储空间中;实时检测所述缓存盘的全部第一存储空间的数据存储状态;在所述数据存储状态为第一状态时,将第一状态对应的第一存储空间中存储的数据转存到主存盘对应的第二存储空间中;在所述数据存储状态为第二状态时,控制垃圾回收程序对所述第二状态对应的第一存储空间中存储的数据进行清除,由本方法,通过允许垃圾回收程序执行,但不允许垃圾回收过程中改变存储空间的数据存储状态,可以避免垃圾回收过程中出现缓存盘对数据存储不做处理引发业务中断以及时延较大的问题,提高数据处理效率。
[0078]
图10为本发明实施例提供的一种数据处理装置的结构示意图,具体包括:
[0079]
获取模块1001,用于获取待存储的应用数据,以及将所述应用数据按照预设数据结构缓存在缓存盘对应的第一存储空间中;
[0080]
检测模块1002,用于实时检测所述缓存盘的全部第一存储空间的数据存储状态;
[0081]
存储模块1003,用于在所述数据存储状态为第一状态时,将第一状态对应的第一存储空间中存储的数据转存到主存盘对应的第二存储空间中;
[0082]
垃圾回收模块1004,用于在所述数据存储状态为第二状态时,控制垃圾回收程序对所述第二状态对应的第一存储空间中存储的数据进行清除;
[0083]
控制模块1005,用于在所述垃圾回收程序对全部第一存储空间进行巡检时,控制全部第一存储空间的数据存储状态不变。
[0084]
在一个可能的实施方式中,所述存储模块1003,具体用于基于第一存储空间中存储数据对应的数据结构,确定所述缓存盘的全部第一存储空间的数据存储状态。
[0085]
在一个可能的实施方式中,所述存储模块1003,还用于获取所述数据结构中标识的数据存储位置;若当前第一存储空间中存储的数据未存在于所述主存盘中,则确定当前第一存储空间的数据存储状态为第一状态;若当前第一存储空间中存储的数据存在于所述主存盘中,则确定当前第一存储空间的数据存储状态为第二状态。
[0086]
在一个可能的实施方式中,所述控制模块1005,具体用于将数据清除后的第一存储空间释放,以用于重新缓存数据。
[0087]
本实施例提供的数据处理装置可以是如图10中所示的数据处理装置,可执行如图2-3中数据处理方法的所有步骤,进而实现图2-3所示数据处理方法的技术效果,具体请参照图2-3相关描述,为简洁描述,在此不作赘述。
[0088]
图11为本发明实施例提供的一种计算机设备的结构示意图,图11所示的计算机设备500包括:至少一个处理器501、存储器502、至少一个网络接口504和其他用户接口503。计算机设备500中的各个组件通过总线系统505耦合在一起。可理解,总线系统505用于实现这些组件之间的连接通信。总线系统505除包括数据总线之外,还包括电源总线、控制总线和状态信号总线。但是为了清楚说明起见,在图11中将各种总线都标为总线系统505。
[0089]
其中,用户接口503可以包括显示器、键盘或者点击设备(例如,鼠标,轨迹球(trackball)、触感板或者触摸屏等。
[0090]
可以理解,本发明实施例中的存储器502可以是易失性存储器或非易失性存储器,或可包括易失性和非易失性存储器两者。其中,非易失性存储器可以是只读存储器(read-only memory,rom)、可编程只读存储器(programmable rom,prom)、可擦除可编程只读存储器(erasable prom,eprom)、电可擦除可编程只读存储器(electrically eprom,eeprom)或闪存。易失性存储器可以是随机存取存储器(random access memory,ram),其用作外部高速缓存。通过示例性但不是限制性说明,许多形式的ram可用,例如静态随机存取存储器(static ram,sram)、动态随机存取存储器(dynamic ram,dram)、同步动态随机存取存储器(synchronous dram,sdram)、双倍数据速率同步动态随机存取存储器(double data rate sdram,ddrsdram)、增强型同步动态随机存取存储器(enhanced sdram,esdram)、同步连接动态随机存取存储器(synch link dram,sldram)和直接内存总线随机存取存储器(direct rambus ram,drram)。本文描述的存储器502旨在包括但不限于这些和任意其它适合类型的存储器。
[0091]
在一些实施方式中,存储器502存储了如下的元素,可执行单元或者数据结构,或者他们的子集,或者他们的扩展集:操作系统5021和应用程序5022。
[0092]
其中,操作系统5021,包含各种系统程序,例如框架层、核心库层、驱动层等,用于实现各种基础业务以及处理基于硬件的任务。应用程序5022,包含各种应用程序,例如媒体播放器(media player)、浏览器(browser)等,用于实现各种应用业务。实现本发明实施例方法的程序可以包含在应用程序5022中。
[0093]
在本发明实施例中,通过调用存储器502存储的程序或指令,具体的,可以是应用程序5022中存储的程序或指令,处理器501用于执行各方法实施例所提供的方法步骤,例如包括:
[0094]
获取待存储的应用数据,以及将所述应用数据按照预设数据结构缓存在缓存盘对应的第一存储空间中;实时检测所述缓存盘的全部第一存储空间的数据存储状态;在所述数据存储状态为第一状态时,将第一状态对应的第一存储空间中存储的数据转存到主存盘对应的第二存储空间中;在所述数据存储状态为第二状态时,控制垃圾回收程序对所述第二状态对应的第一存储空间中存储的数据进行清除。
[0095]
在一个可能的实施方式中,在所述垃圾回收程序对全部第一存储空间进行巡检时,控制全部第一存储空间的数据存储状态不变。
[0096]
在一个可能的实施方式中,基于第一存储空间中存储数据对应的数据结构,确定所述缓存盘的全部第一存储空间的数据存储状态。
[0097]
在一个可能的实施方式中,获取所述数据结构中标识的数据存储位置;若当前第一存储空间中存储的数据未存在于所述主存盘中,则确定当前第一存储空间的数据存储状态为第一状态;若当前第一存储空间中存储的数据存在于所述主存盘中,则确定当前第一存储空间的数据存储状态为第二状态。
[0098]
在一个可能的实施方式中,将数据清除后的第一存储空间释放,以用于重新缓存数据。
[0099]
在一个可能的实施方式中,所述缓存盘为一个,所述主存盘为多个;所述缓存盘与多个主存盘之间数据全映射。
[0100]
上述本发明实施例揭示的方法可以应用于处理器501中,或者由处理器501实现。
处理器501可能是一种集成电路芯片,具有信号的处理能力。在实现过程中,上述方法的各步骤可以通过处理器501中的硬件的集成逻辑电路或者软件形式的指令完成。上述的处理器501可以是通用处理器、数字信号处理器(digital signal processor,dsp)、专用集成电路(application specific integrated circuit,asic)、现成可编程门阵列(field programmable gate array,fpga)或者其他可编程逻辑器件、分立门或者晶体管逻辑器件、分立硬件组件。可以实现或者执行本发明实施例中的公开的各方法、步骤及逻辑框图。通用处理器可以是微处理器或者该处理器也可以是任何常规的处理器等。结合本发明实施例所公开的方法的步骤可以直接体现为硬件译码处理器执行完成,或者用译码处理器中的硬件及软件单元组合执行完成。软件单元可以位于随机存储器,闪存、只读存储器,可编程只读存储器或者电可擦写可编程存储器、寄存器等本领域成熟的存储介质中。该存储介质位于存储器502,处理器501读取存储器502中的信息,结合其硬件完成上述方法的步骤。
[0101]
可以理解的是,本文描述的这些实施例可以用硬件、软件、固件、中间件、微码或其组合来实现。对于硬件实现,处理单元可以实现在一个或多个专用集成电路(application specific integrated circuits,asic)、数字信号处理器(digital signal processing,dsp)、数字信号处理设备(dspdevice,dspd)、可编程逻辑设备(programmable logic device,pld)、现场可编程门阵列(field-programmable gate array,fpga)、通用处理器、控制器、微控制器、微处理器、用于执行本技术所述功能的其它电子单元或其组合中。
[0102]
对于软件实现,可通过执行本文所述功能的单元来实现本文所述的技术。软件代码可存储在存储器中并通过处理器执行。存储器可以在处理器中或在处理器外部实现。
[0103]
本实施例提供的计算机设备可以是如图11中所示的计算机设备,可执行如图2-3中数据处理方法的所有步骤,进而实现图2-3所示数据处理方法的技术效果,具体请参照图2-3相关描述,为简洁描述,在此不作赘述。
[0104]
本发明实施例还提供了一种存储介质(计算机可读存储介质)。这里的存储介质存储有一个或者多个程序。其中,存储介质可以包括易失性存储器,例如随机存取存储器;存储器也可以包括非易失性存储器,例如只读存储器、快闪存储器、硬盘或固态硬盘;存储器还可以包括上述种类的存储器的组合。
[0105]
当存储介质中一个或者多个程序可被一个或者多个处理器执行,以实现上述在计算机设备侧执行的数据处理方法。
[0106]
所述处理器用于执行存储器中存储的数据处理程序,以实现以下在计算机设备侧执行的数据处理方法的步骤:
[0107]
获取待存储的应用数据,以及将所述应用数据按照预设数据结构缓存在缓存盘对应的第一存储空间中;实时检测所述缓存盘的全部第一存储空间的数据存储状态;在所述数据存储状态为第一状态时,将第一状态对应的第一存储空间中存储的数据转存到主存盘对应的第二存储空间中;在所述数据存储状态为第二状态时,控制垃圾回收程序对所述第二状态对应的第一存储空间中存储的数据进行清除。
[0108]
在一个可能的实施方式中,在所述垃圾回收程序对全部第一存储空间进行巡检时,控制全部第一存储空间的数据存储状态不变。
[0109]
在一个可能的实施方式中,基于第一存储空间中存储数据对应的数据结构,确定所述缓存盘的全部第一存储空间的数据存储状态。
[0110]
在一个可能的实施方式中,获取所述数据结构中标识的数据存储位置;若当前第一存储空间中存储的数据未存在于所述主存盘中,则确定当前第一存储空间的数据存储状态为第一状态;若当前第一存储空间中存储的数据存在于所述主存盘中,则确定当前第一存储空间的数据存储状态为第二状态。
[0111]
在一个可能的实施方式中,将数据清除后的第一存储空间释放,以用于重新缓存数据。
[0112]
在一个可能的实施方式中,所述缓存盘为一个,所述主存盘为多个;所述缓存盘与多个主存盘之间数据全映射。
[0113]
专业人员应该还可以进一步意识到,结合本文中所公开的实施例描述的各示例的单元及算法步骤,能够以电子硬件、计算机软件或者二者的结合来实现,为了清楚地说明硬件和软件的可互换性,在上述说明中已经按照功能一般性地描述了各示例的组成及步骤。这些功能究竟以硬件还是软件方式来执行,取决于技术方案的特定应用和设计约束条件。专业技术人员可以对每个特定的应用来使用不同方法来实现所描述的功能,但是这种实现不应认为超出本发明的范围。
[0114]
结合本文中所公开的实施例描述的方法或算法的步骤可以用硬件、处理器执行的软件模块,或者二者的结合来实施。软件模块可以置于随机存储器(ram)、内存、只读存储器(rom)、电可编程rom、电可擦除可编程rom、寄存器、硬盘、可移动磁盘、cd-rom、或技术领域内所公知的任意其它形式的存储介质中。
[0115]
以上所述的具体实施方式,对本发明的目的、技术方案和有益效果进行了进一步详细说明,所应理解的是,以上所述仅为本发明的具体实施方式而已,并不用于限定本发明的保护范围,凡在本发明的精神和原则之内,所做的任何修改、等同替换、改进等,均应包含在本发明的保护范围之内。
再多了解一些

本文用于创业者技术爱好者查询,仅供学习研究,如用于商业用途,请联系技术所有人。

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

相关文献