CN113791741B - 固态硬盘的数据巡检方法、装置、计算机设备及存储介质 - Google Patents

固态硬盘的数据巡检方法、装置、计算机设备及存储介质 Download PDF

Info

Publication number
CN113791741B
CN113791741B CN202111358272.5A CN202111358272A CN113791741B CN 113791741 B CN113791741 B CN 113791741B CN 202111358272 A CN202111358272 A CN 202111358272A CN 113791741 B CN113791741 B CN 113791741B
Authority
CN
China
Prior art keywords
data
block
target block
logic unit
data inspection
Prior art date
Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
Active
Application number
CN202111358272.5A
Other languages
English (en)
Other versions
CN113791741A (zh
Inventor
钱翔
Current Assignee (The listed assignees may be inaccurate. Google has not performed a legal analysis and makes no representation or warranty as to the accuracy of the list.)
Suzhou Inspur Intelligent Technology Co Ltd
Original Assignee
Suzhou Inspur Intelligent Technology Co Ltd
Priority date (The priority date is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the date listed.)
Filing date
Publication date
Application filed by Suzhou Inspur Intelligent Technology Co Ltd filed Critical Suzhou Inspur Intelligent Technology Co Ltd
Priority to CN202111358272.5A priority Critical patent/CN113791741B/zh
Publication of CN113791741A publication Critical patent/CN113791741A/zh
Application granted granted Critical
Publication of CN113791741B publication Critical patent/CN113791741B/zh
Priority to PCT/CN2022/089835 priority patent/WO2023087624A1/zh
Active legal-status Critical Current
Anticipated expiration legal-status Critical

Links

Images

Classifications

    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F3/00Input arrangements for transferring data to be processed into a form capable of being handled by the computer; Output arrangements for transferring data from processing unit to output unit, e.g. interface arrangements
    • G06F3/06Digital input from, or digital output to, record carriers, e.g. RAID, emulated record carriers or networked record carriers
    • G06F3/0601Interfaces specially adapted for storage systems
    • G06F3/0602Interfaces specially adapted for storage systems specifically adapted to achieve a particular effect
    • G06F3/0614Improving the reliability of storage systems
    • G06F3/0616Improving the reliability of storage systems in relation to life time, e.g. increasing Mean Time Between Failures [MTBF]
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F3/00Input arrangements for transferring data to be processed into a form capable of being handled by the computer; Output arrangements for transferring data from processing unit to output unit, e.g. interface arrangements
    • G06F3/06Digital input from, or digital output to, record carriers, e.g. RAID, emulated record carriers or networked record carriers
    • G06F3/0601Interfaces specially adapted for storage systems
    • G06F3/0628Interfaces specially adapted for storage systems making use of a particular technique
    • G06F3/0662Virtualisation aspects
    • G06F3/0665Virtualisation aspects at area level, e.g. provisioning of virtual or logical volumes
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F3/00Input arrangements for transferring data to be processed into a form capable of being handled by the computer; Output arrangements for transferring data from processing unit to output unit, e.g. interface arrangements
    • G06F3/06Digital input from, or digital output to, record carriers, e.g. RAID, emulated record carriers or networked record carriers
    • G06F3/0601Interfaces specially adapted for storage systems
    • G06F3/0668Interfaces specially adapted for storage systems adopting a particular infrastructure
    • G06F3/0671In-line storage system
    • G06F3/0673Single storage device
    • G06F3/0679Non-volatile semiconductor memory device, e.g. flash memory, one time programmable memory [OTP]

Landscapes

  • Engineering & Computer Science (AREA)
  • Theoretical Computer Science (AREA)
  • Human Computer Interaction (AREA)
  • Physics & Mathematics (AREA)
  • General Engineering & Computer Science (AREA)
  • General Physics & Mathematics (AREA)
  • Debugging And Monitoring (AREA)

Abstract

本发明实施例涉及一种固态硬盘的数据巡检方法、装置、计算机设备及存储介质,所述方法包括:获取数据巡检任务;基于所述数据巡检任务从起始block条带开始对固态硬盘进行数据巡检;检测巡检到的block条带的block数据状态;基于所述block数据状态确定数据巡检策略;基于所述数据巡检策略对从所述起始block条带开始进行数据巡检,得到满足预设巡检条件的目标block条带,并对所述目标block条带中的目标block进行处理,由此方法,可以实现对固态硬盘中的多个plane同时进行数据巡检,提高数据巡检效率,节约巨大的时间成本。

Description

固态硬盘的数据巡检方法、装置、计算机设备及存储介质
技术领域
本发明实施例涉及固态硬盘数据巡检领域,尤其涉及一种固态硬盘的数据巡检方法、装置、计算机设备及存储介质。
背景技术
随着固态硬盘的高速发展和广泛应用,固态硬盘的数据巡检有效地保证了数据的可靠性,因此,如何提高数据巡检的效率成为重要的研究方向。
目前,对于单plane和多plane的固态硬盘,采用的巡检方式均为:先判断获取一个block,对这一个block的physicalpage的errorbit数与阈值作比较,得到比较结果后再做下一个valid physical block的巡检。
上述数据巡检方式对多plane的固态硬盘而言,数据巡检效率低,耗费巨大的时间成本。
发明内容
鉴于此,为解决上述多plane的固态硬盘的数据巡检效率低的技术问题,本发明实施例提供一种固态硬盘的数据巡检方法、装置、计算机设备及存储介质。
第一方面,本发明实施例提供一种固态硬盘的数据巡检方法,包括:
获取数据巡检任务;
基于所述数据巡检任务从起始block条带开始对固态硬盘进行数据巡检;
检测巡检到的block条带的block数据状态;
基于所述block数据状态确定数据巡检策略;
基于所述数据巡检策略对从所述起始block条带开始进行数据巡检,得到满足预设巡检条件的目标block条带,并对所述目标block条带中的目标block进行处理。
在一个可能的实施方式中,所述方法还包括:
若所述起始block条带的block数据状态为已写入数据,则确定所述数据巡检策略为从所述起始block条带开始进行数据巡检;
若所述起始block条带的block数据状态为未写入数据,则确定所述数据巡检策略为从下一个block条带开始进行数据巡检。
在一个可能的实施方式中,所述方法还包括:
基于所述数据巡检策略开始进行数据巡检,获取已写入数据的目标block条带;
获取所述目标block条带对应的bitmap;
基于所述bitmap,确定所述目标block条带中bitmap最低位的目标block。
在一个可能的实施方式中,所述方法还包括:
确定bitmap最低位的目标block所在逻辑单元;
获取所述逻辑单元对应的plane bitmap,并将所述逻辑单元对应的所有planebitmap进行标记;
基于plane bitmap对逻辑单元上多个目标block中的physical page的error bit数与阈值进行比较。
在一个可能的实施方式中,所述方法还包括:
若所述逻辑单元上目标block中的physical page的error bit数大于或等于阈值,则将目标block中的physical page中的数据进行搬移。
在一个可能的实施方式中,所述方法还包括:
判断目标block是否为逻辑单元的最后一个block;
若不是,则巡检下一个block,执行所述获取已写入数据的目标block条带的步骤;
若是,则将目标block设置为起始block。
在一个可能的实施方式中,所述方法还包括:
若所述逻辑单元上目标block中的physical page的error bit数小于阈值,则判断目标block所在的逻辑单元是否为固态硬盘中的最后一个逻辑单元;
若是,则执行获取数据巡检任务的步骤;
若不是,则执行判断目标block是否为逻辑单元的最后一个block的步骤。
第二方面,本发明实施例提供一种固态硬盘的数据巡检装置,包括:
获取模块,用于获取数据巡检任务;
巡检模块,用于基于所述数据巡检任务从起始block条带开始对固态硬盘进行数据巡检;
所述巡检模块,还检测巡检到的block条带的block数据状态;
确定模块,用于基于所述block数据状态确定数据巡检策略;
处理模块,用于基于所述数据巡检策略对从所述起始block条带开始进行数据巡检,得到满足预设巡检条件的目标block条带,并对所述目标block条带中的目标block进行处理。
第三方面,本发明实施例提供一种计算机设备,包括:处理器和存储器,所述处理器用于执行所述存储器中存储的固态硬盘的数据巡检程序,以实现上述第一方面中所述的固态硬盘的数据巡检方法。
第四方面,本发明实施例提供一种存储介质,包括:所述存储介质存储有一个或者多个程序,所述一个或者多个程序可被一个或者多个处理器执行,以实现上述第一方面中所述的固态硬盘的数据巡检方法。
本发明实施例提供的固态硬盘的数据巡检方案,通过获取数据巡检任务;基于所述数据巡检任务从起始block条带开始对固态硬盘进行数据巡检;检测巡检到的block条带的block数据状态;基于所述block数据状态确定数据巡检策略;基于所述数据巡检策略对从所述起始block条带开始进行数据巡检,得到满足预设巡检条件的目标block条带,并对所述目标block条带中的目标block进行处理,相比于现有技术中多plane的固态硬盘进行数据巡检,先判断获取一个block,对这一个block的physicalpage的errorbit数与阈值作比较,得到比较结果后再做下一个block的巡检的方式,由本方案,可以实现对固态硬盘中的多个plane同时进行数据巡检,提高数据巡检效率,节约巨大的时间成本。
附图说明
图1为本发明实施例提供的一种固态硬盘的数据巡检方法的流程示意图;
图2为本发明实施例提供的另一种固态硬盘的数据巡检方法的流程示意图;
图3为本发明实施例提供的一种固态硬盘的数据巡检装置的结构示意图;
图4为本发明实施例提供的一种计算机设备的结构示意图;
图5为本发明实施例提供的一种固态硬盘的结构示意图;
图6为本发明实施例提供的一种固态硬盘的数据巡检结构示意图。
具体实施方式
为使本发明实施例的目的、技术方案和优点更加清楚,下面将结合本发明实施例中的附图,对本发明实施例中的技术方案进行清楚、完整地描述,显然,所描述的实施例是本发明一部分实施例,而不是全部的实施例。基于本发明中的实施例,本领域普通技术人员在没有做出创造性劳动前提下所获得的所有其他实施例,都属于本发明保护的范围。
为便于对本发明实施例的理解,下面将结合附图以具体实施例做进一步的解释说明,实施例并不构成对本发明实施例的限定。
图1为本发明实施例提供的一种固态硬盘的数据巡检方法的流程示意图,如图1所示,该方法具体包括:
S11、获取数据巡检任务。
本发明实施例应用于多plane的固态硬盘的数据巡检场景,如图5所示的固态硬盘的结构示意图,每个固态硬盘中包括多个Lun,每个Lun中包括多个plane,每个plane中包含多个block,每个block中包含多个physical page,如图6所示的固态硬盘的数据巡检结构进行数据巡检。获取数据巡检任务,该数据巡检任务可以由定时器周期性触发生成,获取定时器触发的数据巡检任务。
S12、基于所述数据巡检任务从起始block条带开始对固态硬盘进行数据巡检。
获取到数据巡检任务后,确定每个plane的起始block条带(例如,block0),该起始block条带可能为plane中的第一个block条带,也可能是任意一个被上次数据巡检设置的起始block条带。
S13、检测巡检到的block条带的block数据状态。
确定起始block条带后,检测起始block条带的block数据状态,即是否被写入数据。
S14、基于所述block数据状态确定数据巡检策略。
基于起始block条带的block数据状态确定数据巡检策略,该数据巡检策略为数据巡检的路径,即从起始block条带开始进行数据巡检或者从起始block条带的下一个block条带开始进行数据巡检。
S15、基于所述数据巡检策略对从所述起始block条带开始进行数据巡检,得到满足预设巡检条件的目标block条带,并对所述目标block条带中的目标block进行处理。
基于S14确定的数据巡检策略从起始block条带开始进行数据巡检,得到满足预设巡检条件的每个plane中的目标block条带,对巡检到的目标block条带中的目标block进行处理,其中,预设巡检条件为筛选目标block条带的条件,即是否被写入数据;筛选目标block的条件可以以bitmap为筛选条件,具体筛选方式由下方实施例说明,在此先不详述。
本发明实施例提供的固态硬盘的数据巡检方法,通过获取数据巡检任务;基于所述数据巡检任务从起始block条带开始对固态硬盘进行数据巡检;检测巡检到的block条带的block数据状态;基于所述block数据状态确定数据巡检策略;基于所述数据巡检策略对从所述起始block条带开始进行数据巡检,得到满足预设巡检条件的目标block条带,并对所述目标block条带中的目标block进行处理,相比于现有技术中多plane的固态硬盘进行数据巡检,先判断获取一个block,对这一个block的physicalpage的errorbit数与阈值作比较,得到比较结果后再做下一个block的巡检的方式,由本方法,可以实现对固态硬盘中的多个plane同时进行数据巡检,提高数据巡检效率,节约巨大的时间成本。
图2为本发明实施例提供的另一种固态硬盘的数据巡检方法的流程示意图,如图2所示,该方法具体包括:
S21、基于所述数据巡检策略开始进行数据巡检,获取已写入数据的目标block条带。
本发明实施例中,数据巡检策略可以由起始block条带的block数据状态确定,若起始block条带的block数据状态为已写入数据,则确定数据巡检策略为从该起始block条带开始进行数据巡检;若起始block条带的block数据状态为未写入数据,则确定数据巡检策略为从下一个block条带开始进行数据巡检。
获取已写入数据的目标block条带。
S22、获取所述目标block条带对应的bitmap。
S23、基于所述bitmap,确定所述目标block条带中bitmap最低位的目标block。
获取已写入数据的目标block条带对应的bitmap,该bitmap用来记录目标block条带所在的plane是好块还是坏块。
本发明实施例中,可以根据bitmap将全部被写入数据的block进行排序,确定bitmap最低位的目标block。
S24、确定bitmap最低位的目标block所在逻辑单元。
基于S23确定的bitmap最低位的目标block,可以确定该目标block所在的固态硬盘中的逻辑单元。
S25、获取所述逻辑单元对应的plane bitmap,并将所述逻辑单元对应的所有plane bitmap进行标记。
获取S24中确定的目标block所在的逻辑单元对应的plane bitmap,将该逻辑单元中的plane bitmap进行标记,标记该逻辑单元中的plane已经被巡检,以及目标block条带上的某个Lun的好坏块情况,在下次数据巡检过程可以不再巡检该逻辑单元的plane。
S26、基于plane bitmap对逻辑单元上多个目标block中的physical page的errorbit数与阈值进行比较。
本发明实施例中,将S25确定的逻辑单元中被写入数据的目标block中的physicalpage的error bit数与预先设定的阈值进行比较,得到比较结果。
其中,若physical page的error bit数大于或等于阈值,则可以确定physicalpage所在的block为坏块;若physical page的error bit数小于阈值,则可以确定physicalpage所在的block为好块。
S27、若所述逻辑单元上目标block中的physical page的error bit数大于或等于阈值,则将目标block中的physical page中的数据进行搬移。
若S26中的physical page的error bit数大于或等于阈值,则将大于或等于阈值的physical page中的数据进行搬移,可以搬移到其他好块中error bit数小于阈值的physical page中。
S28、判断目标block是否为逻辑单元的最后一个block。
在S27对数据进行搬移之后,需要判断当前逻辑单元中的目标block是否为该逻辑单元的最后一个block,若目标block不是该逻辑单元的最后一个block,则巡检下一个block,确定下一个block是否被写入数据,以及获取被写入数据的block对应的bitmap;若目标block是该逻辑单元的最后一个block,则将目标block设置为起始block,下一轮数据巡检时,从该目标block开始进行。
S29、若所述逻辑单元上目标block中的physical page的error bit数小于阈值,则判断目标block所在的逻辑单元是否为固态硬盘中的最后一个逻辑单元。
本发明实施例中,若逻辑单元上写入数据的block中的physical page的errorbit数小于阈值,则判断目标block所在的逻辑单元是否为固态硬盘中的最后一个逻辑单元,判断方法可以根据逻辑单元的编号确定,本发明不做具体限制。
若目标block所在的逻辑单元为固态硬盘中的最后一个逻辑单元,则本次数据巡检任务完成,可以根据获取的定时器触发的数据巡检任务再次进行数据巡检;若目标block所在的逻辑单元不是固态硬盘中的最后一个逻辑单元,则判断目标block是否为逻辑单元的最后一个block,若目标block不是逻辑单元的最后一个block,则巡检下一个block;若目标block是逻辑单元的最后一个block,则将目标block设置为起始block,下一轮数据巡检时,从该目标block开始进行。
可选的,不同的逻辑单元可以使用不同的定时器,每个定时器的时间间隔可以根据当前逻辑单元的有效block数量进行确定。
本发明实施例提供的固态硬盘的数据巡检方法,通过获取数据巡检任务;基于所述数据巡检任务从起始block条带开始对固态硬盘进行数据巡检;检测巡检到的block条带的block数据状态;基于所述block数据状态确定数据巡检策略;基于所述数据巡检策略对从所述起始block条带开始进行数据巡检,得到满足预设巡检条件的目标block条带,并对所述目标block条带中的目标block进行处理,相比于现有技术中多plane的固态硬盘进行数据巡检,先判断获取一个block,对这一个block的physicalpage的errorbit数与阈值作比较,得到比较结果后再做下一个block的巡检的方式,由本方法,可以实现对固态硬盘中的多个plane同时进行数据巡检,提高数据巡检效率,节约巨大的时间成本。
图3为本发明实施例提供的一种固态硬盘的数据巡检装置的结构示意图,如图3所示,具体包括:
获取模块301,用于获取数据巡检任务;
巡检模块302,用于基于所述数据巡检任务从起始block条带开始对固态硬盘进行数据巡检;
所述巡检模块302,还检测巡检到的block条带的block数据状态;
确定模块303,用于基于所述block数据状态确定数据巡检策略;
处理模块304,用于基于所述数据巡检策略对从所述起始block条带开始进行数据巡检,得到满足预设巡检条件的目标block条带,并对所述目标block条带中的目标block进行处理。
在一个可能的实施方式中,所述确定模块303,具体用于若所述起始block条带的block数据状态为已写入数据,则确定所述数据巡检策略为从所述起始block条带开始进行数据巡检;若所述起始block条带的block数据状态为未写入数据,则确定所述数据巡检策略为从下一个block条带开始进行数据巡检。
在一个可能的实施方式中,所述处理模块304,具体用于基于所述数据巡检策略开始进行数据巡检,获取已写入数据的目标block条带;获取所述目标block条带对应的bitmap;基于所述bitmap,确定所述目标block条带中bitmap最低位的目标block。
在一个可能的实施方式中,所述处理模块304,还用于确定bitmap最低位的目标block所在逻辑单元;获取所述逻辑单元对应的plane bitmap,并将所述逻辑单元对应的所有plane bitmap进行标记;基于plane bitmap对逻辑单元上多个目标block中的physicalpage的error bit数与阈值进行比较。
在一个可能的实施方式中,所述处理模块304,还用于若所述逻辑单元上目标block中的physical page的error bit数大于或等于阈值,则将目标block中的physicalpage中的数据进行搬移。
在一个可能的实施方式中,所述处理模块304,还用于判断目标block是否为逻辑单元的最后一个block;若不是,则巡检下一个block,执行所述获取已写入数据的目标block条带的步骤;若是,则将目标block设置为起始block。
在一个可能的实施方式中,所述处理模块304,还用于若所述逻辑单元上目标block中的physical page的error bit数小于阈值,则判断目标block所在的逻辑单元是否为固态硬盘中的最后一个逻辑单元;若是,则执行获取数据巡检任务的步骤;若不是,则执行判断目标block是否为逻辑单元的最后一个block的步骤。
本实施例提供的固态硬盘的数据巡检装置可以是如图3中所示的固态硬盘的数据巡检装置,可执行如图1-2中固态硬盘的数据巡检方法的所有步骤,进而实现图1-2所示固态硬盘的数据巡检方法的技术效果,具体请参照图1-2相关描述,为简洁描述,在此不作赘述。
图4为本发明实施例提供的一种计算机设备的结构示意图,图4所示的计算机设备400包括:至少一个处理器401、存储器402、至少一个网络接口404和其他用户接口403。计算机设备400中的各个组件通过总线系统405耦合在一起。可理解,总线系统405用于实现这些组件之间的连接通信。总线系统405除包括数据总线之外,还包括电源总线、控制总线和状态信号总线。但是为了清楚说明起见,在图4中将各种总线都标为总线系统405。
其中,用户接口403可以包括显示器、键盘或者点击设备(例如,鼠标,轨迹球(trackball)、触感板或者触摸屏等。
可以理解,本发明实施例中的存储器402可以是易失性存储器或非易失性存储器,或可包括易失性和非易失性存储器两者。其中,非易失性存储器可以是只读存储器(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 DataRate SDRAM,DDRSDRAM)、增强型同步动态随机存取存储器(Enhanced SDRAM,ESDRAM)、同步连接动态随机存取存储器(Synch link DRAM,SLDRAM)和直接内存总线随机存取存储器(Direct Rambus RAM,DRRAM)。本文描述的存储器402旨在包括但不限于这些和任意其它适合类型的存储器。
在一些实施方式中,存储器402存储了如下的元素,可执行单元或者数据结构,或者他们的子集,或者他们的扩展集:操作系统4021和应用程序 4022。
其中,操作系统4021,包含各种系统程序,例如框架层、核心库层、驱动层等,用于实现各种基础业务以及处理基于硬件的任务。应用程序4022,包含各种应用程序,例如媒体播放器(Media Player)、浏览器(Browser)等,用于实现各种应用业务。实现本发明实施例方法的程序可以包含在应用程序4022中。
在本发明实施例中,通过调用存储器402存储的程序或指令,具体的,可以是应用程序4022中存储的程序或指令,处理器401用于执行各方法实施例所提供的方法步骤,例如包括:
获取数据巡检任务;基于所述数据巡检任务从起始block条带开始对固态硬盘进行数据巡检;检测巡检到的block条带的block数据状态;基于所述block数据状态确定数据巡检策略;基于所述数据巡检策略对从所述起始block条带开始进行数据巡检,得到满足预设巡检条件的目标block条带,并对所述目标block条带中的目标block进行处理。
在一个可能的实施方式中,若所述起始block条带的block数据状态为已写入数据,则确定所述数据巡检策略为从所述起始block条带开始进行数据巡检;若所述起始block条带的block数据状态为未写入数据,则确定所述数据巡检策略为从下一个block条带开始进行数据巡检。
在一个可能的实施方式中,基于所述数据巡检策略开始进行数据巡检,获取已写入数据的目标block条带;获取所述目标block条带对应的bitmap;基于所述bitmap,确定所述目标block条带中bitmap最低位的目标block。
在一个可能的实施方式中,确定bitmap最低位的目标block所在逻辑单元;获取所述逻辑单元对应的plane bitmap,并将所述逻辑单元对应的所有plane bitmap进行标记;基于plane bitmap对逻辑单元上多个目标block中的physical page的error bit数与阈值进行比较。
在一个可能的实施方式中,若所述逻辑单元上目标block中的physical page的error bit数大于或等于阈值,则将目标block中的physical page中的数据进行搬移。
在一个可能的实施方式中,判断目标block是否为逻辑单元的最后一个block;若不是,则巡检下一个block,执行所述获取已写入数据的目标block条带的步骤;若是,则将目标block设置为起始block。
在一个可能的实施方式中,若所述逻辑单元上目标block中的physical page的error bit数小于阈值,则判断目标block所在的逻辑单元是否为固态硬盘中的最后一个逻辑单元;若是,则执行获取数据巡检任务的步骤;若不是,则执行判断目标block是否为逻辑单元的最后一个block的步骤。
上述本发明实施例揭示的方法可以应用于处理器401中,或者由处理器401实现。处理器401可能是一种集成电路芯片,具有信号的处理能力。在实现过程中,上述方法的各步骤可以通过处理器401中的硬件的集成逻辑电路或者软件形式的指令完成。上述的处理器401可以是通用处理器、数字信号处理器(Digital Signal Processor,DSP)、专用集成电路(Application Specific Integrated Circuit,ASIC)、现成可编程门阵列(FieldProgrammable Gate Array, FPGA)或者其他可编程逻辑器件、分立门或者晶体管逻辑器件、分立硬件组件。可以实现或者执行本发明实施例中的公开的各方法、步骤及逻辑框图。通用处理器可以是微处理器或者该处理器也可以是任何常规的处理器等。结合本发明实施例所公开的方法的步骤可以直接体现为硬件译码处理器执行完成,或者用译码处理器中的硬件及软件单元组合执行完成。软件单元可以位于随机存储器,闪存、只读存储器,可编程只读存储器或者电可擦写可编程存储器、寄存器等本领域成熟的存储介质中。该存储介质位于存储器402,处理器401读取存储器402中的信息,结合其硬件完成上述方法的步骤。
可以理解的是,本文描述的这些实施例可以用硬件、软件、固件、中间件、微码或其组合来实现。对于硬件实现,处理单元可以实现在一个或多个专用集成电路(ApplicationSpecific Integrated Circuits,ASIC)、数字信号处理器(Digital Signal Processing,DSP)、数字信号处理设备(DSPDevice,DSPD)、可编程逻辑设备(Programmable LogicDevice,PLD)、现场可编程门阵列(Field-Programmable Gate Array,FPGA)、通用处理器、控制器、微控制器、微处理器、用于执行本申请所述功能的其它电子单元或其组合中。
对于软件实现,可通过执行本文所述功能的单元来实现本文所述的技术。软件代码可存储在存储器中并通过处理器执行。存储器可以在处理器中或在处理器外部实现。
本实施例提供的计算机设备可以是如图4中所示的计算机设备,可执行如图1-2中固态硬盘的数据巡检方法的所有步骤,进而实现图1-2所示固态硬盘的数据巡检方法的技术效果,具体请参照图1-2相关描述,为简洁描述,在此不作赘述。
本发明实施例还提供了一种存储介质(计算机可读存储介质)。这里的存储介质存储有一个或者多个程序。其中,存储介质可以包括易失性存储器,例如随机存取存储器;存储器也可以包括非易失性存储器,例如只读存储器、快闪存储器、硬盘或固态硬盘;存储器还可以包括上述种类的存储器的组合。
当存储介质中一个或者多个程序可被一个或者多个处理器执行,以实现上述在计算机设备侧执行的固态硬盘的数据巡检方法。
所述处理器用于执行存储器中存储的固态硬盘的数据巡检程序,以实现以下在计算机设备侧执行的固态硬盘的数据巡检方法的步骤:
获取数据巡检任务;基于所述数据巡检任务从起始block条带开始对固态硬盘进行数据巡检;检测巡检到的block条带的block数据状态;基于所述block数据状态确定数据巡检策略;基于所述数据巡检策略对从所述起始block条带开始进行数据巡检,得到满足预设巡检条件的目标block条带,并对所述目标block条带中的目标block进行处理。
在一个可能的实施方式中,若所述起始block条带的block数据状态为已写入数据,则确定所述数据巡检策略为从所述起始block条带开始进行数据巡检;若所述起始block条带的block数据状态为未写入数据,则确定所述数据巡检策略为从下一个block条带开始进行数据巡检。
在一个可能的实施方式中,基于所述数据巡检策略开始进行数据巡检,获取已写入数据的目标block条带;获取所述目标block条带对应的bitmap;基于所述bitmap,确定所述目标block条带中bitmap最低位的目标block。
在一个可能的实施方式中,确定bitmap最低位的目标block所在逻辑单元;获取所述逻辑单元对应的plane bitmap,并将所述逻辑单元对应的所有plane bitmap进行标记;基于plane bitmap对逻辑单元上多个目标block中的physical page的error bit数与阈值进行比较。
在一个可能的实施方式中,若所述逻辑单元上目标block中的physical page的error bit数大于或等于阈值,则将目标block中的physical page中的数据进行搬移。
在一个可能的实施方式中,判断目标block是否为逻辑单元的最后一个block;若不是,则巡检下一个block,执行所述获取已写入数据的目标block条带的步骤;若是,则将目标block设置为起始block。
在一个可能的实施方式中,若所述逻辑单元上目标block中的physical page的error bit数小于阈值,则判断目标block所在的逻辑单元是否为固态硬盘中的最后一个逻辑单元;若是,则执行获取数据巡检任务的步骤;若不是,则执行判断目标block是否为逻辑单元的最后一个block的步骤。
专业人员应该还可以进一步意识到,结合本文中所公开的实施例描述的各示例的单元及算法步骤,能够以电子硬件、计算机软件或者二者的结合来实现,为了清楚地说明硬件和软件的可互换性,在上述说明中已经按照功能一般性地描述了各示例的组成及步骤。这些功能究竟以硬件还是软件方式来执行,取决于技术方案的特定应用和设计约束条件。专业技术人员可以对每个特定的应用来使用不同方法来实现所描述的功能,但是这种实现不应认为超出本发明的范围。
结合本文中所公开的实施例描述的方法或算法的步骤可以用硬件、处理器执行的软件模块,或者二者的结合来实施。软件模块可以置于随机存储器(RAM)、内存、只读存储器(ROM)、电可编程ROM、电可擦除可编程ROM、寄存器、硬盘、可移动磁盘、CD-ROM、或技术领域内所公知的任意其它形式的存储介质中。
以上所述的具体实施方式,对本发明的目的、技术方案和有益效果进行了进一步详细说明,所应理解的是,以上所述仅为本发明的具体实施方式而已,并不用于限定本发明的保护范围,凡在本发明的精神和原则之内,所做的任何修改、等同替换、改进等,均应包含在本发明的保护范围之内。

Claims (6)

1.一种固态硬盘的数据巡检方法,其特征在于,包括:
获取数据巡检任务;
基于所述数据巡检任务从起始block条带开始对固态硬盘进行数据巡检;
检测巡检到的block条带的block数据状态;
基于所述block数据状态确定数据巡检策略;
基于所述数据巡检策略开始进行数据巡检,获取已写入数据的目标block条带;
获取所述目标block条带对应的bitmap;
基于所述bitmap,确定所述目标block条带中bitmap最低位的目标block;
确定bitmap最低位的目标block所在逻辑单元;
获取所述逻辑单元对应的plane bitmap,并将所述逻辑单元对应的所有plane bitmap进行标记;
基于plane bitmap对逻辑单元上多个目标block中的physical page的error bit数与阈值进行比较;
若所述逻辑单元上目标block中的physical page的error bit数大于或等于阈值,则将目标block中的physical page中的数据进行搬移;
若所述逻辑单元上目标block中的physical page的error bit数小于阈值,则判断目标block所在的逻辑单元是否为固态硬盘中的最后一个逻辑单元;
若是,则执行获取数据巡检任务的步骤;
若不是,则执行判断目标block是否为逻辑单元的最后一个block的步骤。
2.根据权利要求1所述的方法,其特征在于,所述基于所述block数据状态确定数据巡检策略,包括:
若所述起始block条带的block数据状态为已写入数据,则确定所述数据巡检策略为从所述起始block条带开始进行数据巡检;
若所述起始block条带的block数据状态为未写入数据,则确定所述数据巡检策略为从下一个block条带开始进行数据巡检。
3.根据权利要求2所述的方法,其特征在于,所述将目标block中的physical page中的数据进行搬移之后,包括:
判断目标block是否为逻辑单元的最后一个block;
若不是,则巡检下一个block,执行所述获取已写入数据的目标block条带的步骤;
若是,则将目标block设置为起始block。
4.一种固态硬盘的数据巡检装置,其特征在于,包括:
获取模块,用于获取数据巡检任务;
巡检模块,用于基于所述数据巡检任务从起始block条带开始对固态硬盘进行数据巡检;
所述巡检模块,还检测巡检到的block条带的block数据状态;
确定模块,用于基于所述block数据状态确定数据巡检策略;
处理模块,用于基于所述数据巡检策略对从所述起始block条带开始进行数据巡检,得到满足预设巡检条件的目标block条带,并对所述目标block条带中的目标block进行处理;
所述获取模块,还用于基于所述数据巡检策略开始进行数据巡检,获取已写入数据的目标block条带;
所述获取模块,还用于获取所述目标block条带对应的bitmap;
所述确定模块,还用于基于所述bitmap,确定所述目标block条带中bitmap最低位的目标block;
所述确定模块,还用于确定bitmap最低位的目标block所在逻辑单元;
所述获取模块,还用于获取所述逻辑单元对应的plane bitmap,并将所述逻辑单元对应的所有plane bitmap进行标记;
所述处理模块,还用于基于plane bitmap对逻辑单元上多个目标block中的physicalpage的error bit数与阈值进行比较;
所述处理模块,还用于若所述逻辑单元上目标block中的physical page的error bit数大于或等于阈值,则将目标block中的physical page中的数据进行搬移;
所述处理模块,还用于若所述逻辑单元上目标block中的physical page的error bit数小于阈值,则判断目标block所在的逻辑单元是否为固态硬盘中的最后一个逻辑单元;
所述处理模块,还用于若是,则执行获取数据巡检任务的步骤;
所述处理模块,还用于若不是,则执行判断目标block是否为逻辑单元的最后一个block的步骤。
5.一种计算机设备,其特征在于,包括:处理器和存储器,所述处理器用于执行所述存储器中存储的固态硬盘的数据巡检程序,以实现权利要求1~3中任一项所述的固态硬盘的数据巡检方法。
6.一种存储介质,其特征在于,所述存储介质存储有一个或者多个程序,所述一个或者多个程序可被一个或者多个处理器执行,以实现权利要求1~3中任一项所述的固态硬盘的数据巡检方法。
CN202111358272.5A 2021-11-17 2021-11-17 固态硬盘的数据巡检方法、装置、计算机设备及存储介质 Active CN113791741B (zh)

Priority Applications (2)

Application Number Priority Date Filing Date Title
CN202111358272.5A CN113791741B (zh) 2021-11-17 2021-11-17 固态硬盘的数据巡检方法、装置、计算机设备及存储介质
PCT/CN2022/089835 WO2023087624A1 (zh) 2021-11-17 2022-04-28 固态硬盘的数据巡检方法、装置、计算机设备及存储介质

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
CN202111358272.5A CN113791741B (zh) 2021-11-17 2021-11-17 固态硬盘的数据巡检方法、装置、计算机设备及存储介质

Publications (2)

Publication Number Publication Date
CN113791741A CN113791741A (zh) 2021-12-14
CN113791741B true CN113791741B (zh) 2022-02-22

Family

ID=78955409

Family Applications (1)

Application Number Title Priority Date Filing Date
CN202111358272.5A Active CN113791741B (zh) 2021-11-17 2021-11-17 固态硬盘的数据巡检方法、装置、计算机设备及存储介质

Country Status (2)

Country Link
CN (1) CN113791741B (zh)
WO (1) WO2023087624A1 (zh)

Families Citing this family (3)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN112445429B (zh) * 2020-10-30 2022-08-05 至誉科技(武汉)有限公司 固态硬盘物理块的管理方法及系统
CN113791741B (zh) * 2021-11-17 2022-02-22 苏州浪潮智能科技有限公司 固态硬盘的数据巡检方法、装置、计算机设备及存储介质
CN117115586A (zh) * 2023-08-24 2023-11-24 长江三峡集团实业发展(北京)有限公司 一种光伏组件巡检决策方法、装置、介质及巡检飞行器

Citations (4)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN109558269A (zh) * 2018-12-05 2019-04-02 郑州云海信息技术有限公司 一种固态硬盘状态的检测方法、装置和介质
CN109614052A (zh) * 2018-12-13 2019-04-12 郑州云海信息技术有限公司 一种数据巡检方法、装置和计算机可读存储介质
CN110825556A (zh) * 2019-10-30 2020-02-21 苏州浪潮智能科技有限公司 一种判断固态硬盘中存储数据状态的方法和装置
CN111078498A (zh) * 2019-12-03 2020-04-28 山东华芯半导体有限公司 一种ssd中数据巡检的方法

Family Cites Families (9)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
KR20110025524A (ko) * 2009-09-04 2011-03-10 삼성전자주식회사 반도체 메모리 장치 및 그것의 데이터 처리 방법
US10365859B2 (en) * 2014-10-21 2019-07-30 International Business Machines Corporation Storage array management employing a merged background management process
CN109817271A (zh) * 2018-11-21 2019-05-28 中国航空工业集团公司洛阳电光设备研究所 一种固态硬盘坏块的检测方法
CN109599145A (zh) * 2018-12-04 2019-04-09 郑州云海信息技术有限公司 一种固态硬盘的测试方法、装置及计算机存储介质
KR20200072139A (ko) * 2018-12-12 2020-06-22 에스케이하이닉스 주식회사 메모리 시스템 및 그것의 동작방법
KR20200079852A (ko) * 2018-12-26 2020-07-06 에스케이하이닉스 주식회사 메모리 시스템 및 그것의 동작방법
US10922022B2 (en) * 2019-03-13 2021-02-16 Samsung Electronics Co., Ltd. Method and system for managing LBA overlap checking in NVMe based SSDs
CN113791741B (zh) * 2021-11-17 2022-02-22 苏州浪潮智能科技有限公司 固态硬盘的数据巡检方法、装置、计算机设备及存储介质
CN114300032A (zh) * 2021-12-28 2022-04-08 深圳大普微电子科技有限公司 一种检查存储介质失效的方法、装置和固态硬盘

Patent Citations (4)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN109558269A (zh) * 2018-12-05 2019-04-02 郑州云海信息技术有限公司 一种固态硬盘状态的检测方法、装置和介质
CN109614052A (zh) * 2018-12-13 2019-04-12 郑州云海信息技术有限公司 一种数据巡检方法、装置和计算机可读存储介质
CN110825556A (zh) * 2019-10-30 2020-02-21 苏州浪潮智能科技有限公司 一种判断固态硬盘中存储数据状态的方法和装置
CN111078498A (zh) * 2019-12-03 2020-04-28 山东华芯半导体有限公司 一种ssd中数据巡检的方法

Also Published As

Publication number Publication date
WO2023087624A1 (zh) 2023-05-25
CN113791741A (zh) 2021-12-14

Similar Documents

Publication Publication Date Title
CN113791741B (zh) 固态硬盘的数据巡检方法、装置、计算机设备及存储介质
US7409623B2 (en) System and method of reading non-volatile computer memory
US10565128B2 (en) Workload detection and media cache management
US9898402B2 (en) Unaligned data coalescing
US8976478B1 (en) Band rewrites based on error scan counts
CN108089971B (zh) 基于嵌入式实时系统的日志服务方法和系统
US9269452B2 (en) Determining system lifetime characteristics
US11209986B2 (en) Memory operations on data
US10268540B2 (en) Data storage device and operating method thereof
US20170125127A1 (en) Memory system and operating method thereof
US20050157561A1 (en) Data recovery apparatus and method used for flash memory
US10545810B2 (en) Method and apparatus for monitoring non-volatile memory read errors using background media scan
CN109614052B (zh) 一种数据巡检方法、装置和计算机可读存储介质
US20180129575A1 (en) Memory management
CN104115231A (zh) 用于确定对存储器阵列的访问的方法、装置和系统
US8504897B2 (en) Memory controller
CN114090379A (zh) 服务器总线故障定位方法、装置、电子设备及存储介质
CN112732181B (zh) 一种ssd的数据迁移方法及相关装置
WO2019074500A1 (en) MEMORY DEVICES COMPRISING EXECUTION TRACING PADS
US11309055B2 (en) Power loss test engine device and method
CN115599589A (zh) 一种数据恢复方法及相关装置
US9417954B2 (en) Data storage device and method for operating the same
WO2013074420A1 (en) Apparatuses and methods for storing validity masks and operating apparatuses
CN109299018B (zh) 一种Flash存储器中历史数据的读取方法及装置
CN108509295B (zh) 存储器系统的操作方法

Legal Events

Date Code Title Description
PB01 Publication
PB01 Publication
SE01 Entry into force of request for substantive examination
SE01 Entry into force of request for substantive examination
GR01 Patent grant
GR01 Patent grant