CN107844273B - 一种数据写入方法及装置、验证方法及装置 - Google Patents

一种数据写入方法及装置、验证方法及装置 Download PDF

Info

Publication number
CN107844273B
CN107844273B CN201711059999.7A CN201711059999A CN107844273B CN 107844273 B CN107844273 B CN 107844273B CN 201711059999 A CN201711059999 A CN 201711059999A CN 107844273 B CN107844273 B CN 107844273B
Authority
CN
China
Prior art keywords
data
checksum
preset
sampling
magic number
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
CN201711059999.7A
Other languages
English (en)
Other versions
CN107844273A (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.)
Sangfor Technologies Co Ltd
Original Assignee
Sangfor Technologies 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 Sangfor Technologies Co Ltd filed Critical Sangfor Technologies Co Ltd
Priority to CN201711059999.7A priority Critical patent/CN107844273B/zh
Publication of CN107844273A publication Critical patent/CN107844273A/zh
Application granted granted Critical
Publication of CN107844273B publication Critical patent/CN107844273B/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/0619Improving the reliability of storage systems in relation to data integrity, e.g. data losses, bit errors
    • 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/0638Organizing or formatting or addressing of data
    • 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/0674Disk device
    • G06F3/0676Magnetic disk device

Abstract

本发明实施例公开了一种数据写入方法及装置、验证方法及装置、计算机装置、可读存储介质,用于避免校验和误判,提高使用校验和检测数据错误的精度,减少对系统的负面影响。本发明实施例中,数据写入方法包括:接收针对第一数据的写入请求;根据写入请求在第一数据的预设位置获取采样数据,并利用第一数据生成校验和;将采样数据和校验和按照预设格式进行处理,得到第二数据,第二数据包括至少两个采样数据或至少一个预设魔数;在第一存储区域写入第一数据,并按照预设规则在第二存储区域写入第二数据。

Description

一种数据写入方法及装置、验证方法及装置
技术领域
本发明涉及数据处理领域,尤其涉及一种数据写入方法及装置、验证方法及装置、计算机装置、可读存储介质。
背景技术
保持数据完整性是现代存储系统的重中之重。目前,有各种各样的技术被开发和应用来改进数据完整性的保护,其中最常用、最受欢迎的就是校验和方法。
传统的针对存储系统的校验和方法一般分为两类:一类是端到端校验,另一类是磁盘校验和。一般来说,使用校验和对数据进行保护的时候,一旦数据出现非正常更改,那么在读取时重新计算的校验和并不会等于存储时计算的校验和。然而,校验和本身也会出现错误,例如,在写校验和时出现校验和部分写入却返回正确的情况,那么若使用错误的校验和去验证数据,则会造成数据完整性的误判。
发明内容
本发明实施例提供了一种数据写入方法及装置、验证方法及装置、计算机装置、可读存储介质,用于避免校验和误判,提高使用校验和检测数据错误的精度,减少对系统的负面影响。
有鉴于此,本发明第一方面提供一种数据写入方法,可包括:
接收针对第一数据的写入请求;
根据写入请求在第一数据的预设位置获取采样数据,并利用第一数据生成校验和;
将采样数据和校验和按照预设格式进行处理,得到第二数据,第二数据包括至少两个采样数据或至少一个预设魔数;
在第一存储区域写入第一数据,并按照预设规则在第二存储区域写入第二数据。
进一步的,将采样数据和校验和按照预设格式进行处理,得到第二数据包括:
当第二数据包括至少两个采样数据时,在校验和的首尾两端分别设置至少一个采样数据,得到第二数据;或,
当第二数据包括至少一个预设魔数时,在校验和的首尾两端分别设置采样数据、预设魔数中的至少一种,得到第二数据。
进一步的,第一数据的大小为采样数据的大小的200倍至1000倍。
进一步的,第一存储区域为第一磁盘中的第一区域,第二存储区域为第二磁盘中的第二区域。
本发明第二方面提供一种验证方法,可包括:
接收针对第一数据的读取请求;
根据读取请求从第一存储区域读取第一数据对应的第二数据,第二数据为将第一校验和与第一采样数据按照预设格式进行处理得到,且包括至少两个第一采样数据或至少一个预设魔数;
将至少两个第一采样数据进行对比,或检测至少一个预设魔数是否发生变化;
若至少两个第一采样数据均相同,或至少一个预设魔数均未发生变化,则确定第一校验和正确。
进一步的,在将至少两个第一采样数据进行对比,或检测至少一个预设魔数是否发生变化之前,方法还包括:
根据读取请求从第二存储区域读取第一数据;
利用第一数据生成第二校验和,并将第二校验和与第一校验和进行对比;
若第二校验和与第一校验和不相同,则触发将至少两个第一采样数据进行对比,或检测至少一个预设魔数是否发生变化的步骤。
进一步的,方法还包括:
根据读取请求从第二存储区域读取第一数据;
在确定第一校验和正确之后,方法还包括:
利用第一数据生成第二校验和,并将第二校验和与第一校验和进行对比;
若第二校验和与第一校验和不相同,则确定第一数据错误。
进一步的,方法还包括:
若第二校验和与第一校验和相同,则将第一采样数据与第一数据的预设位置的第二采样数据进行对比;
若第一采样数据与第二采样数据相同,则确定第一数据正确。
进一步的,预设格式包括:
当第二数据包括至少两个第一采样数据时,在第一校验和的首尾两端分别设置至少一个第一采样数据;或,
当第二数据包括至少一个预设魔数时,在第一校验和的首尾两端分别设置第一采样数据、预设魔数中的至少一种。
进一步的,第一数据的大小为第二采样数据的大小的200倍至1000倍。
进一步的,第一存储区域为第一磁盘中的第一区域,第二存储区域为第二磁盘中的第二区域。
本发明第三方面提供一种数据写入装置,可包括:
接收单元,用于接收针对第一数据的写入请求;
获取单元,用于根据写入请求在第一数据的预设位置获取采样数据;
生成单元,用于利用第一数据生成校验和;
处理单元,用于将采样数据和校验和按照预设格式进行处理,得到第二数据,第二数据包括至少两个采样数据或至少一个预设魔数;
写入单元,用于在第一存储区域写入第一数据,并按照预设规则在第二存储区域写入第二数据。
进一步的,处理单元,具体用于:
当第二数据包括至少两个采样数据时,在校验和的首尾两端分别设置至少一个采样数据,得到第二数据;或,
当第二数据包括至少一个预设魔数时,在校验和的首尾两端分别设置采样数据、预设魔数中的至少一种,得到第二数据。
进一步的,第一数据的大小为采样数据的大小的200倍至1000倍。
进一步的,第一存储区域为第一磁盘中的第一区域,第二存储区域为第二磁盘中的第二区域。
本发明第四方面提供一种验证装置,可包括:
接收单元,用于接收针对第一数据的读取请求;
第一读取单元,用于根据读取请求从第一存储区域读取第一数据对应的第二数据,第二数据为将第一校验和与第一采样数据按照预设格式进行处理得到,且包括至少两个第一采样数据或至少一个预设魔数;
处理单元,用于将至少两个第一采样数据进行对比,或检测至少一个预设魔数是否发生变化;
第一确定单元,用于当至少两个第一采样数据均相同,或至少一个预设魔数均未发生变化时,则确定第一校验和正确。
进一步的,装置还包括:
第二读取单元,还用于根据读取请求从第二存储区域读取第一数据;
生成单元,用于利用第一数据生成第二校验和;
第一对比单元,用于将第二校验和与第一校验和进行对比;
触发单元,用于当第二校验和与第一校验和不相同时,则触发处理单元将至少两个第一采样数据进行对比,或检测至少一个预设魔数是否发生变化。
进一步的,装置还包括:
第二读取单元,用于根据读取请求从第二存储区域读取第一数据;
生成单元,用于利用第一数据生成第二校验和;
第一对比单元,用于将第二校验和与第一校验和进行对比;
第二确定单元,用于当第二校验和与第一校验和不相同时,则确定第一数据错误。
进一步的,装置还包括:
第二对比单元,用于当第二校验和与第一校验和相同时,则将第一采样数据与第一数据的预设位置的第二采样数据进行对比;
第三确定单元,还用于当第一采样数据与第二采样数据相同时,则确定第一数据正确。
进一步的,预设格式包括:
当第二数据包括至少两个第一采样数据时,在第一校验和的首尾两端分别设置至少一个第一采样数据;或,
当第二数据包括至少一个预设魔数时,在第一校验和的首尾两端分别设置第一采样数据、预设魔数中的至少一种。
进一步的,第一数据的大小为第二采样数据的大小的200倍至1000倍。
进一步的,第一存储区域为第一磁盘中的第一区域,第二存储区域为第二磁盘中的第二区域。
本发明第五方面提供一种计算机装置,计算机装置包括处理器,处理器用于执行存储器中存储的计算机程序时,实现如下步骤:
接收针对第一数据的写入请求;
根据写入请求在第一数据的预设位置获取采样数据,并利用第一数据生成校验和;
将采样数据和校验和按照预设格式进行处理,得到第二数据,第二数据包括至少两个采样数据或至少一个预设魔数;
在第一存储区域写入第一数据,并按照预设规则在第二存储区域写入第二数据。
本发明第六方面提供一种计算机可读存储介质,其上存储有计算机程序,计算机程序被处理器执行时,实现如下步骤:
接收针对第一数据的写入请求;
根据写入请求在第一数据的预设位置获取采样数据,并利用第一数据生成校验和;
将采样数据和校验和按照预设格式进行处理,得到第二数据,第二数据包括至少两个采样数据或至少一个预设魔数;
在第一存储区域写入第一数据,并按照预设规则在第二存储区域写入第二数据。
本发明第七方面提供一种计算机装置,计算机装置包括处理器,处理器用于执行存储器中存储的计算机程序时,实现如下步骤:
接收针对第一数据的读取请求;
根据读取请求从第一存储区域读取第一数据对应的第二数据,第二数据为将第一校验和与第一采样数据按照预设格式进行处理得到,且包括至少两个第一采样数据或至少一个预设魔数;
将至少两个第一采样数据进行对比,或检测至少一个预设魔数是否发生变化;
若至少两个第一采样数据均相同,或至少一个预设魔数均未发生变化,则确定第一校验和正确。
本发明第八方面提供一种计算机可读存储介质,其上存储有计算机程序,计算机程序被处理器执行时,实现如下步骤:
接收针对第一数据的读取请求;
根据读取请求从第一存储区域读取第一数据对应的第二数据,第二数据为将第一校验和与第一采样数据按照预设格式进行处理得到,且包括至少两个第一采样数据或至少一个预设魔数;
将至少两个第一采样数据进行对比,或检测至少一个预设魔数是否发生变化;
若至少两个第一采样数据均相同,或至少一个预设魔数均未发生变化,则确定第一校验和正确。
从以上技术方案可以看出,本发明实施例具有以下优点:
本发明实施例提供了一种数据写入方法,在接收到针对第一数据的写入请求后,可以根据写入请求在第一数据的预设位置获取采样数据,并可以将第一数据写入第一存储区域,将采样与由第一数据生成的校验和处理后得到的第二数据写入第二存储区域,其中,第二数据包括至少两个采样数据或至少一个预设魔数。由此,在对第一数据进行读取时,可以利用至少两个采样数据或至少一个预设魔数对校验和进行检验,而由于第二数据为将采样数据和校验和按照预设格式进行处理得到,则在至少两个采样数据或至少一个预设魔数未发生篡改时,可以确认第一数据对应的校验和未发生篡改,从而可以避免校验和出错但第一数据正确的误判场景,进而可以有效地减少误判率,提高系统可靠性。
附图说明
图1为本发明实施例中数据写入方法一个实施例示意图;
图2为本发明实施例中验证方法一个实施例示意图;
图3为本发明实施例中验证方法另一实施例示意图;
图4为本发明实施例中验证方法另一实施例示意图;
图5为本发明实施例中数据写入装置一个实施例示意图;
图6为本发明实施例中验证装置一个实施例示意图;
图7为本发明实施例中验证装置另一实施例示意图;
图8为本发明实施例中验证装置另一实施例示意图;
图9为本发明实施例中验证装置另一实施例示意图。
具体实施方式
本发明实施例提供了一种数据写入方法及装置、验证方法及装置、计算机装置。可读存储介质,用于避免校验和误判,提高使用校验和检测数据错误的精度,减少对系统的负面影响。
为了使本技术领域的人员更好地理解本发明方案,下面将结合本发明实施例中的附图,对本发明实施例中的技术方案进行清楚、完整地描述,显然,所描述的实施例仅仅是本发明一部分的实施例,而不是全部的实施例。基于本发明中的实施例,本领域普通技术人员在没有做出创造性劳动前提下所获得的所有其他实施例,都应当属于本发明保护的范围。
本发明的说明书和权利要求书及上述附图中的术语“第一”、“第二”、“第三”、“第四”等(如果存在)是用于区别类似的对象,而不必用于描述特定的顺序或先后次序。应该理解这样使用的数据在适当情况下可以互换,以便这里描述的实施例能够以除了在这里图示或描述的内容以外的顺序实施。此外,术语“包括”和“具有”以及他们的任何变形,意图在于覆盖不排他的包含,例如,包含了一系列步骤或单元的过程、方法、系统、产品或设备不必限于清楚地列出的那些步骤或单元,而是可包括没有清楚地列出的或对于这些过程、方法、产品或设备固有的其它步骤或单元。
为便于理解,下面对本发明实施例中的具体流程进行描述,请参阅图1,本发明实施例中数据写入方法一个实施例包括:
101、接收针对第一数据的写入请求;
本实施例中,需要对第一数据进行存储时,可以接收针对第一数据的写入请求。
102、根据写入请求在第一数据的预设位置获取采样数据,并利用第一数据生成校验和;
本实施例中,接收针对第一数据的写入请求后,可以根据写入请求在第一数据的预设位置获取采样数据,并利用第一数据生成校验和。
具体的,接收针对第一数据的写入请求后,可以获取第一数据,并可以按照预设定义在第一数据的预设位置进行采样,以得到采样数据。其中,该预设位置可以为第一数据的头部,可以为第一数据的尾部,也可以为第一数据的中部,还可以将第一数据作为采样数据,此处不做具体限定。
需要说明的是,本实施例中采样数据的大小可以根据实际需要进行设置,可选的,为了避免采样数据过大而造成的存储空间的占用,可以将采样数据的大小设置得稍小些。可选的,第一数据的大小为采样数据的大小的200倍至1000倍。
本实施例中,利用第一数据生成校验和的方法可以参照现有技术,此处不再赘述。
103、将采样数据和校验和按照预设格式进行处理,得到第二数据;
本实施例中,根据写入请求在第一数据的预设位置获取采样数据,并利用第一数据生成校验和后,可以将采样数据和校验和按照预设格式进行处理,得到第二数据。其中,第二数据可以包括至少两个采样数据或至少一个预设魔数。
具体的,为了利于对第二数据中的校验和进行验证,第二数据的数据格式可以如下方式:
第一种:
当第二数据可以包括至少两个采样数据时,可以利用这至少两个采样数据的比较来验证校验和是否发生篡改,假设包括两个采样数据,采样数据为A,校验和为B,那么在实际应用中,可以将采样数据与校验和按照预设格式进行组合,得到第二数据,例如AAB、ABA、BAA等数据形式。
优选的,由于数据被篡改时,从数据的首尾两端篡改的可能性较大,则为了提高发现校验和的篡改可能性,可以在校验和的首尾两端分别设置至少一个采样数据,得到第二数据,即诸如ABA的形式。
第二种:
当第二数据可以包括至少一个预设魔数时,在将采样数据与校验和按照预设格式进行处理时,可以将采用数据、校验和、至少一个预设魔数进行组合,得到第二数据。例如,沿用上述的说明,假设预设魔数为C,则第二数据的形式可以为CBA、CAB、ABC等。
优选的,为了提高发现校验和的篡改可能性,可以在校验和的首尾两端分别设置采样数据、预设魔数中的至少一种,得到第二数据,即诸如CAB、ABC。
其中,当预设魔数为一个以上时,可以将这一个以上的预设魔数设于校验和与采用数据的首尾段,如CABC、CBAC,以进一步提高发现采样数据的篡改可能性。
可以理解的是,本实施例中,当预设魔数为一个以上时,这一个以上的预设魔数彼此间可以相同,也可以不相同,此处不做具体限定。
需要说明的是,本实施例中,当第二数据可以包括至少一个预设魔数时,采样数据也可以为两个以上,以能够通过对至少一个预设魔数、至少一个采样数据进行验证来判断校验和是否发生篡改,此处不做具体限定。
104、在第一存储区域写入第一数据,并按照预设规则在第二存储区域写入第二数据。
本实施例中,将采样数据和校验和按照预设格式进行处理,得到第二数据,可以在第一存储区域写入第一数据,并可以按照预设规则在第二存储区域写入第二数据。
具体的,第二数据的存储是为了在第一数据读取时,能够验证第一数据的正确性,由此,在第一数据与第二数据进行存储时,需要建立第一数据与第二数据的映射关系,以在读取第一数据时,能够根据该映射关系读取第二数据,例如,可以建立第一存储区域与第二存储区域的映射关系,从而可以确定第一存储区域存储的数据与第二存储区域存储的数据具有关联性。
可以理解的是,基于第一数据、第二数据的使用可能性,第一存储区域、第二存储区域可以有不同的属性,例如磁盘、缓存等,此处不做具体限定。
本实施例中,为了加强第一数据、第二数据的长久性,第一存储区域可以为第一磁盘中的第一区域,第二存储区域可以为第二磁盘中的第二区域。其中,第一磁盘与第二磁盘可以为同一磁盘,也可以不为同一磁盘,当第一磁盘与第二磁盘为同一磁盘时,第一区域与第二区域可以为同一区域,也可以不为同一区域,此处不做具体限定。
本实施例中,在接收到针对第一数据的写入请求后,可以根据写入请求在第一数据的预设位置获取采样数据,并可以将第一数据写入第一存储区域,将采样与由第一数据生成的校验和处理后得到的第二数据写入第二存储区域,其中,第二数据包括至少两个采样数据或至少一个预设魔数。由此,在对第一数据进行读取时,可以利用至少两个采样数据或至少一个预设魔数对校验和进行检验,而由于第二数据为将采样数据和校验和按照预设格式进行处理得到,则在至少两个采样数据或至少一个预设魔数未发生篡改时,可以确认第一数据对应的校验和未发生篡改,从而可以避免校验和出错但第一数据正确的误判场景,进而可以有效地减少误判率,提高系统可靠性。
上面对数据写入方法进行了描述,在数据写入后,可以读取写入的数据进行使用,在读取数据后,可以对写入的数据进行相关的校验,以保证正确数据的正确使用,下面进行具体说明:
请参阅图2,本发明实施例中验证方法一个实施例包括:
201、接收针对第一数据的读取请求;
本实施例中,需要对第一数据进行使用时,可以接收针对第一数据的读取请求。
202、根据读取请求从第一存储区域读取第一数据对应的第二数据;
本实施例中,接收针对第一数据的读取请求后,可以根据读取请求从第一存储区域读取第一数据对应的第二数据。其中,第二数据为将第一校验和与第一采样数据按照预设格式进行处理得到,且可以包括至少两个第一采样数据或至少一个预设魔数。
具体的,第二数据可以用于第一数据的校验,第一数据与第二数据在写入时可以建立映射关系,由此,在需要读取第一数据时,可以根据该映射关系在第一存储区域读取第一数据对应的第二数据。
其中,由于第二数据可以用于第一数据的校验,则第二数据为将第一校验和与第一采样数据按照预设格式进行处理得到,可以包括至少两个第一采样数据或至少一个预设魔数。
基于此,第二数据在写入第一存储区域时,其预设格式可以如下:
当第二数据包括至少两个第一采样数据时,在第一校验和的首尾两端分别设置至少一个第一采样数据;或,
当第二数据包括至少一个预设魔数时,在第一校验和的首尾两端分别设置第一采样数据、预设魔数中的至少一种。
上述第二数据的数据格式的相应内容可以参照图1所示实施例中步骤103中的内容,此处不再赘述。
203、将第二数据中的至少两个第一采样数据进行对比,或检测至少一个预设魔数是否发生变化;
本实施例中,根据读取请求从第一存储区域读取第一数据对应的第二数据后,可以将第二数据中的至少两个第一采样数据进行对比,并可以检测至少一个预设魔数是否发生变化。
具体的,由于第二数据的数据格式有多种形式,则在验证第一校验和是否被篡改时,可以主要通过如下方式:
第一种:
当第二数据包括至少两个第一采样数据时,可以将至少两个第一采样数据进行对比。在至少两个第一采样数据写入时,至少两个第一采样数据是完全相同的,则在将至少两个第一采样数据进行对比时,只要其中一个第一采样数据与其它第一采样数据不一样,则可以默认第二数据发生了篡改,第一校验和可能出错,反之,当所有第一采样数据均相同时,则可以默认为第二数据未发生篡改,第一校验和未出错。
第二种:
当第二数据包括至少一个预设魔数时,可以检测至少一个预设魔数是否发生变化。由于魔数是固定的,则在本实施例中,一旦其中一个预设魔数发生变化,则可以默认第二数据发生了篡改,第一校验和可能出错,反之,当所有第一采样数据均相同时,则可以默认为第二数据未发生篡改,第一校验和未出错。
可以理解的是,在第二种方式中,第二数据还可以包括至少两个第一采样数据,则可以同时对至少两个第一采样数据、至少一个预设魔数进行检测,以加强验证的精度,则只有至少一个预设魔数均未发生变化,且至少两个第一采样数据均相同,才可以默认为第二数据未发生篡改,此处不做具体限定。
204、若至少两个第一采样数据均相同,或至少一个预设魔数均未发生变化,则确定第一校验和正确;
本实施例中,当第二数据包括至少一个预设魔数时,若确定至少两个第一采样数据均相同,则可以确定第一校验和正确,或者,当第二数据包括至少一个预设魔数时,若确定至少一个预设魔数未发生变化,则也可以确定第一校验和正确。
205、若至少两个第一采样数据不完全相同,或至少一个预设魔数中的一个或多个发生变化,则确定第一校验和出错。
本实施例中,当第二数据包括至少一个预设魔数时,若确定至少两个第一采样数据不完全相同,则可以确定第一校验和出错,或者,当第二数据包括至少一个预设魔数时,若确定至少一个预设魔数中的一个或多个发生变化,则也可以确定第一校验和出错。在确定第一校验和出错后,可以进行第一校验和的报错,以使得工作人员可以分析第一校验和的出错原因。
本实施例中,相对于现有技术而言,在接收到针对第一数据的读取请求后,可以先行对第一数据对应的第二数据中的第一校验和进行验证,以能够在利用第一校验和对第一数据进行验证前,可以预先判断第一校验和的正确性,从而有利于避免第一校验和出错但第一数据正确的误判场景,进而可以有效地减少误判率,提高系统可靠性。
可以理解的是,本实施例中,还可以对第一校验和与第一数据生成的第二校验和进行对比,以提高第一校验和的验证效率,且可以对第一数据进行验证,下面分别进行具体说明:
请参阅图3,本发明实施例中验证方法另一实施例包括:
301、接收针对第一数据的读取请求;
302、根据读取请求从第一存储区域读取第一数据对应的第二数据;
本实施例中的步骤301至步骤302与图2所示实施例中的步骤201至步骤202相同,此处不再赘述。
303、根据读取请求从第二存储区域读取第一数据;
本实施例中,接收到针对第一数据的读取请求后,还可以根据读取请求从第二存储区域读取第一数据。
可以理解的是,基于第一数据、第二数据的使用可能性,第一存储区域、第二存储区域可以有不同的属性,例如磁盘、缓存等,此处不做具体限定。
其中,第一存储区域可以为第一磁盘中的第一区域,第二存储区域可以为第二磁盘中的第二区域。其中,第一磁盘与第二磁盘可以为同一磁盘,也可以不为同一磁盘,当第一磁盘与第二磁盘为同一磁盘时,第一区域与第二区域可以为同一区域,也可以不为同一区域,此处不做具体限定。
可以理解的是,本实施例中的步骤303在步骤302之前执行,也可以与步骤302同时执行,此处不做具体限定。
304、利用第一数据生成第二校验和,并将第二校验和与第一校验和进行对比;
本实施例中,根据读取请求从第二存储区域读取第一数据后,可以利用第一数据生成第二校验和,并可以将第二校验和与第一校验和进行对比,以判断第二校验和是否与第一校验和相同。
本实施例中,利用第一数据生成第二校验和的方法可以参照现有技术,此处不再赘述。
305、若第二校验和与第一校验和不相同,则将至少两个第一采样数据进行对比,或检测至少一个预设魔数是否发生变化;
306、若至少两个第一采样数据均相同,或至少一个预设魔数均未发生变化,则确定第一校验和正确;
本实施例中的步骤305至步骤306与图2所示实施例中的步骤203至步骤204相同,此处不再赘述。
可以理解的是,本实施例中,在第二校验和与第一校验和不相同的情况下,要么第一校验和出错,要么第一数据出错,要么第一校验和与第一数据均出错,那么当至少两个第一采样数据均相同时,可以说明第一校验和正确,则第一数据出错。在确定第一数据出错后,可以进行第一数据的报错,以使得工作人员可以分析第一数据的出错原因。
307、若第二校验和与第一校验和相同,则将第一采样数据与第一数据的预设位置的第二采样数据进行对比;
本实施例中,若第二校验和于第一校验和相同,则可以默认为第一校验和正确,那么为了进一步校验第一数据的正确性,可以将第一采样数据与第一数据的预设位置的第二采样数据进行对比。
具体的,第一采样数据为写入第一数据时,在第一数据的预设位置进行采样得到,则为了防止篡改后的第一数据与篡改前的第一数据生成的校验和相同而误认为第一数据未发生篡改造成的漏判,在读取第一数据后,可以在第一数据对应于第一采样数据的预设位置获取第二采样数据,并可以将第一采样数据与第二采样进行对比。
其中,为了避免第一采样数据过大而造成第二数据对存储空间的占用,由于第一采样数据与第二采样数据的大小应该相同,则第一数据的大小为可以第二采样数据的大小的200倍至1000倍。
308、若第一采样数据与第二采样数据相同,则确定第一数据正确;
本实施例中,若第一采样数据与第二采样数据相同,则可以确定第一数据正确。
可以理解的是,本实施例中,若第一采样数据与第二采样数据不相同,则可以认为第一数据出错,即可能篡改后的第一数据与篡改前的第一数据生成的校验和相同。在确定第一数据出错后,可以进行第一数据的报错,以使得工作人员可以分析第一数据的出错原因。
309、若第一采样数据与第二采样数据不相同,则确定第一数据错误;
本实施例中,若第一采样数据与第二采样数据不相同,则可以确定第一数据错误。
进一步的,在确定第一数据出错后,可以进行第一数据的报错,以使得工作人员可以分析第一数据的出错原因。
310、若至少两个第一采样数据不完全相同,或至少一个预设魔数中的一个或多个发生变化,则确定第一校验和出错。
本实施例中的步骤308与图2所示实施例中的步骤205相同,此处不再赘述。
请参阅图4,本发明实施例中验证方法另一实施例包括:
401、接收针对第一数据的读取请求;
402、根据读取请求从第一存储区域读取第一数据对应的第二数据;
403、将至少两个第一采样数据进行对比,或检测至少一个预设魔数是否发生变化;
404、若至少两个第一采样数据均相同,或至少一个预设魔数均未发生变化,则确定第一校验和正确;
本实施例中的步骤401至步骤404与图2所示实施例中的步骤201至步骤204相同,此处不再赘述。
405、根据读取请求从第二存储区域读取第一数据;
本实施例中,接收到针对第一数据的读取请求后,还可以根据读取请求从第二存储区域读取第一数据。
可以理解的是,本实施例中的步骤405可以在步骤404之前执行,也可以与步骤404同时执行,此处不做具体限定。
406、利用第一数据生成第二校验和,并将第二校验和与第一校验和进行对比;
本实施例中的步骤406与图3所示实施例中的步骤304相同,此处不再赘述。
407、若第二校验和与第一校验和相同,则将第一采样数据与第一数据的预设位置的第二采样数据进行对比;
408、若第一采样数据与第二采样数据相同,则确定第一数据正确;
本实施例中的步骤407至步骤408与图3所示实施例中的步骤307至步骤308相同,此处不再赘述。
409、若第一采样数据与第二采样数据不相同,则确定第一数据错误;
本实施例中,若第一采样数据与第二采样数据不相同,则可以确定第一数据错误。
进一步的,在确定第一数据出错后,可以进行第一数据的报错,以使得工作人员可以分析第一数据的出错原因。
410、若第二校验和与第一校验和不相同,则确定第一数据错误;
本实施例中,在第一校验和正确的情况下,若第二校验和与第一校验和不相同,则可以确定第一数据错误。
进一步的,在确定第一数据出错后,可以进行第一数据的报错,以使得工作人员可以分析第一数据的出错原因。
411、若至少两个第一采样数据不完全相同,或至少一个预设魔数中的一个或多个发生变化,则确定第一校验和出错。
本实施例中的步骤411与图2所示实施例中的步骤205相同,此处不再赘述。
上面对本发明实施例中的数据写入方法、验证方法分别进行了说明,下面对本发明实施例中的数据写入装置、验证装置分别进行说明:
请参阅图5,本发明实施例中数据写入装置一个实施例包括:
接收单元501,用于接收针对第一数据的写入请求;
获取单元502,用于根据写入请求在第一数据的预设位置获取采样数据;
生成单元503,用于利用第一数据生成校验和;
处理单元504,用于将采样数据和校验和按照预设格式进行处理,得到第二数据,第二数据包括至少两个采样数据或至少一个预设魔数;
写入单元505,用于在第一存储区域写入第一数据,并按照预设规则在第二存储区域写入第二数据。
可选的,在本发明的一些实施例中,处理单元504,可以进一步具体用于:
当第二数据包括至少两个采样数据时,在校验和的首尾两端分别设置至少一个采样数据,得到第二数据;或,
当第二数据包括至少一个预设魔数时,在校验和的首尾两端分别设置采样数据、预设魔数中的至少一种,得到第二数据。
请参阅图6,本发明实施例中验证装置一个实施例包括:
接收单元601,用于接收针对第一数据的读取请求;
第一读取单元602,用于根据读取请求从第一存储区域读取第一数据对应的第二数据,第二数据为将第一校验和与第一采样数据按照预设格式进行处理得到,且包括至少两个第一采样数据或至少一个预设魔数;
处理单元603,用于将至少两个第一采样数据进行对比,或检测至少一个预设魔数是否发生变化;
第一确定单元604,用于当至少两个第一采样数据均相同,或至少一个预设魔数均未发生变化时,则确定第一校验和正确。
可选的,在本发明的一些实施例中,基于图6,如图7所示,装置可以还包括:
第二读取单元605,用于根据读取请求从第二存储区域读取第一数据;
生成单元606,用于利用第一数据生成第二校验和;
第一对比单元607,用于将第二校验和与第一校验和进行对比;
触发单元608,用于当第二校验和与第一校验和不相同时,则触发处理单元将至少两个第一采样数据进行对比,或检测至少一个预设魔数是否发生变化。
可选的,在本发明的一些实施例中,基于图6,如图8所示,装置还可以进一步包括:
第二读取单元605,还用于根据读取请求从第二存储区域读取第一数据;
生成单元606,用于利用第一数据生成第二校验和;
第一对比单元607,用于将第二校验和与第一校验和进行对比;
第二确定单元609,用于当第二校验和与第一校验和不相同时,则确定第一数据错误。
可选的,在本发明的一些实施例中,基于图8为例进行说明,如图9,装置还可以进一步包括:
第二对比单元610,用于当第二校验和与第一校验和相同时,则将第一采样数据与第一数据的预设位置的第二采样数据进行对比;
第三确定单元611,还用于当第一采样数据与第二采样数据相同时,则确定第一数据正确。
上面从模块化功能实体的角度对本发明实施例中的数据写入装置、验证装置进行了描述,下面从硬件处理的角度对本发明实施例中的计算机装置进行描述:
基于数据写入方法,本发明实施例中计算机装置一个实施例包括:
处理器以及存储器;
存储器用于存储计算机程序,处理器用于执行存储器中存储的计算机程序时,可以实现如下步骤:
接收针对第一数据的写入请求;
根据写入请求在第一数据的预设位置获取采样数据,并利用第一数据生成校验和;
将采样数据和校验和按照预设格式进行处理,得到第二数据,第二数据包括至少两个采样数据或至少一个预设魔数;
在第一存储区域写入第一数据,并按照预设规则在第二存储区域写入第二数据。
在本发明的一些实施例中,处理器用于执行存储器中存储的计算机程序时,还可以实现如下步骤:
当第二数据包括至少两个采样数据时,在校验和的首尾两端分别设置至少一个采样数据,得到第二数据;或,
当第二数据包括至少一个预设魔数时,在校验和的首尾两端分别设置采样数据、预设魔数中的至少一种,得到第二数据。
基于验证方法,本发明实施例中计算机装置另一实施例包括:
处理器以及存储器;
存储器用于存储计算机程序,处理器用于执行存储器中存储的计算机程序时,可以实现如下步骤:
接收针对第一数据的读取请求;
根据读取请求从第一存储区域读取第一数据对应的第二数据,第二数据为将第一校验和与第一采样数据按照预设格式进行处理得到,且包括至少两个第一采样数据或至少一个预设魔数;
将至少两个第一采样数据进行对比,或检测至少一个预设魔数是否发生变化;
若至少两个第一采样数据均相同,或至少一个预设魔数均未发生变化,则确定第一校验和正确。
在本发明的一些实施例中,处理器用于执行存储器中存储的计算机程序时,还可以实现如下步骤:
根据读取请求从第二存储区域读取第一数据;
利用第一数据生成第二校验和,并将第二校验和与第一校验和进行对比;
若第二校验和与第一校验和不相同,则触发将至少两个第一采样数据进行对比,或检测至少一个预设魔数是否发生变化的步骤。
在本发明的一些实施例中,处理器用于执行存储器中存储的计算机程序时,还可以实现如下步骤:
根据读取请求从第二存储区域读取第一数据;
在确定第一校验和正确之后,方法还包括:
利用第一数据生成第二校验和,并将第二校验和与第一校验和进行对比;
若第二校验和与第一校验和不相同,则确定第一数据错误。
在本发明的一些实施例中,处理器用于执行存储器中存储的计算机程序时,还可以实现如下步骤:
若第二校验和与第一校验和相同,则将第一采样数据与第一数据的预设位置的第二采样数据进行对比;
若第一采样数据与第二采样数据相同,则确定第一数据正确。
可以理解的是,上述说明的计算机装置中的处理器执行所述计算机程序时,也可以实现上述对应的各装置实施例中各单元的功能,此处不再赘述。示例性的,所述计算机程序可以被分割成一个或多个模块/单元,所述一个或者多个模块/单元被存储在所述存储器中,并由所述处理器执行,以完成本发明。所述一个或多个模块/单元可以是能够完成特定功能的一系列计算机程序指令段,该指令段用于描述所述计算机程序在诸如所述数据写入装置中的执行过程。例如,所述计算机程序可以被分割成上述数据写入装置中的各单元,各单元可以实现如上述相应数据写入装置说明的具体功能。
所述计算机装置可以是桌上型计算机、笔记本、掌上电脑及云端服务器等计算设备。所述计算机装置可包括但不仅限于处理器、存储器。本领域技术人员可以理解,处理器、存储器仅仅是计算机装置的示例,并不构成对计算机装置的限定,可以包括更多或更少的部件,或者组合某些部件,或者不同的部件,例如所述计算机装置还可以包括输入输出设备、网络接入设备、总线等。
所述处理器可以是中央处理单元(Central Processing Unit,CPU),还可以是其他通用处理器、数字信号处理器(Digital Signal Processor,DSP)、专用集成电路(Application Specific Integrated Circuit,ASIC)、现成可编程门阵列(Field-Programmable GateArray,FPGA)或者其他可编程逻辑器件、分立门或者晶体管逻辑器件、分立硬件组件等。通用处理器可以是微处理器或者该处理器也可以是任何常规的处理器等,所述处理器是所述计算机装置的控制中心,利用各种接口和线路连接整个计算机装置的各个部分。
所述存储器可用于存储所述计算机程序和/或模块,所述处理器通过运行或执行存储在所述存储器内的计算机程序和/或模块,以及调用存储在存储器内的数据,实现所述计算机装置的各种功能。所述存储器可主要包括存储程序区和存储数据区,其中,存储程序区可存储操作系统、至少一个功能所需的应用程序等;存储数据区可存储根据终端的使用所创建的数据等。此外,存储器可以包括高速随机存取存储器,还可以包括非易失性存储器,例如硬盘、内存、插接式硬盘,智能存储卡(Smart Media Card,SMC),安全数字(SecureDigital,SD)卡,闪存卡(Flash Card)、至少一个磁盘存储器件、闪存器件、或其他易失性固态存储器件。
基于数据写入方法,本发明还提供了一种计算机可读存储介质,该计算机可读存储介质上存储有计算机程序,计算机程序被处理器执行时,可以实现如下步骤:
接收针对第一数据的写入请求;
根据写入请求在第一数据的预设位置获取采样数据,并利用第一数据生成校验和;
将采样数据和校验和按照预设格式进行处理,得到第二数据,第二数据包括至少两个采样数据或至少一个预设魔数;
在第一存储区域写入第一数据,并按照预设规则在第二存储区域写入第二数据。
在本发明的一些实施例中,计算机可读存储介质存储的计算机程序被处理器执行时,还可以实现如下步骤:
当第二数据包括至少两个采样数据时,在校验和的首尾两端分别设置至少一个采样数据,得到第二数据;或,
当第二数据包括至少一个预设魔数时,在校验和的首尾两端分别设置采样数据、预设魔数中的至少一种,得到第二数据。
基于验证方法,本发明还提供了一种计算机可读存储介质,该计算机可读存储介质上存储有计算机程序,计算机程序被处理器执行时,可以实现如下步骤:
接收针对第一数据的读取请求;
根据读取请求从第一存储区域读取第一数据对应的第二数据,第二数据为将第一校验和与第一采样数据按照预设格式进行处理得到,且包括至少两个第一采样数据或至少一个预设魔数;
将至少两个第一采样数据进行对比,或检测至少一个预设魔数是否发生变化;
若至少两个第一采样数据均相同,或至少一个预设魔数均未发生变化,则确定第一校验和正确。
在本发明的一些实施例中,计算机可读存储介质存储的计算机程序被处理器执行时,还可以实现如下步骤:
根据读取请求从第二存储区域读取第一数据;
利用第一数据生成第二校验和,并将第二校验和与第一校验和进行对比;
若第二校验和与第一校验和不相同,则触发将至少两个第一采样数据进行对比,或检测至少一个预设魔数是否发生变化的步骤。
在本发明的一些实施例中,计算机可读存储介质存储的计算机程序被处理器执行时,还可以实现如下步骤:
根据读取请求从第二存储区域读取第一数据;
在确定第一校验和正确之后,方法还包括:
利用第一数据生成第二校验和,并将第二校验和与第一校验和进行对比;
若第二校验和与第一校验和不相同,则确定第一数据错误。
在本发明的一些实施例中,计算机可读存储介质存储的计算机程序被处理器执行时,还可以实现如下步骤:
若第二校验和与第一校验和相同,则将第一采样数据与第一数据的预设位置的第二采样数据进行对比;
若第一采样数据与第二采样数据相同,则确定第一数据正确。
可以理解的是,所述集成的单元如果以软件功能单元的形式实现并作为独立的产品销售或使用时,可以存储在相应的一个计算机可读取存储介质中。基于这样的理解,本发明实现上述相应的实施例方法中的全部或部分流程,也可以通过计算机程序来指令相关的硬件来完成,所述的计算机程序可存储于一计算机可读存储介质中,该计算机程序在被处理器执行时,可实现上述各个方法实施例的步骤。其中,所述计算机程序包括计算机程序代码,所述计算机程序代码可以为源代码形式、对象代码形式、可执行文件或某些中间形式等。所述计算机可读介质可以包括:能够携带所述计算机程序代码的任何实体或装置、记录介质、U盘、移动硬盘、磁碟、光盘、计算机存储器、只读存储器(ROM,Read-Only Memory)、随机存取存储器(RAM,Random Access Memory)、电载波信号、电信信号以及软件分发介质等。需要说明的是,所述计算机可读介质包含的内容可以根据司法管辖区内立法和专利实践的要求进行适当的增减,例如在某些司法管辖区,根据立法和专利实践,计算机可读介质不包括电载波信号和电信信号。
所属领域的技术人员可以清楚地了解到,为描述的方便和简洁,上述描述的系统,装置和单元的具体工作过程,可以参考前述方法实施例中的对应过程,在此不再赘述。
在本申请所提供的几个实施例中,应该理解到,所揭露的系统,装置和方法,可以通过其它的方式实现。例如,以上所描述的装置实施例仅仅是示意性的,例如,所述单元的划分,仅仅为一种逻辑功能划分,实际实现时可以有另外的划分方式,例如多个单元或组件可以结合或者可以集成到另一个系统,或一些特征可以忽略,或不执行。另一点,所显示或讨论的相互之间的耦合或直接耦合或通信连接可以是通过一些接口,装置或单元的间接耦合或通信连接,可以是电性,机械或其它的形式。
所述作为分离部件说明的单元可以是或者也可以不是物理上分开的,作为单元显示的部件可以是或者也可以不是物理单元,即可以位于一个地方,或者也可以分布到多个网络单元上。可以根据实际的需要选择其中的部分或者全部单元来实现本实施例方案的目的。
另外,在本发明各个实施例中的各功能单元可以集成在一个处理单元中,也可以是各个单元单独物理存在,也可以两个或两个以上单元集成在一个单元中。
以上所述,以上实施例仅用以说明本发明的技术方案,而非对其限制;尽管参照前述实施例对本发明进行了详细的说明,本领域的普通技术人员应当理解:其依然可以对前述各实施例所记载的技术方案进行修改,或者对其中部分技术特征进行等同替换;而这些修改或者替换,并不使相应技术方案的本质脱离本发明各实施例技术方案的精神和范围。

Claims (15)

1.一种数据写入方法,其特征在于,包括:
接收针对第一数据的写入请求;
根据所述写入请求在所述第一数据的预设位置获取采样数据,并利用所述第一数据生成第一校验和,其中,每一个校验和是采用预设的校验和算法对输入数据进行运算生成的数据,用于校验写入数据与读出数据的一致性;
将所述采样数据和所述第一校验和按照预设格式进行处理,得到第二数据,所述第二数据包括至少两个所述采样数据或至少一个预设魔数,其中魔数是指预设的数字常量或字符串;
在第一存储区域写入所述第一数据,并按照预设规则在第二存储区域写入所述第二数据;
所述将所述采样数据和所述第一校验和按照预设格式进行处理,得到第二数据包括:
当所述第二数据包括至少两个所述采样数据时,在所述第一校验和的首尾两端分别设置至少一个所述采样数据,得到第二数据;或,
当所述第二数据包括至少一个预设魔数时,在所述第一校验和的首尾两端分别设置所述采样数据、所述预设魔数中的至少一种,得到第二数据。
2.根据权利要求1所述的方法,其特征在于,所述第一数据的大小为所述采样数据的大小的200倍至1000倍。
3.根据权利要求1至2中任一项所述的方法,其特征在于,所述第一存储区域为第一磁盘中的第一区域,所述第二存储区域为第二磁盘中的第二区域。
4.一种验证方法,其特征在于,包括:
接收针对第一数据的读取请求;
根据所述读取请求从第一存储区域读取所述第一数据对应的第二数据,其中,当所述第二数据包括至少两个第一采样数据时,在第一校验和的首尾两端分别设置至少一个所述第一采样数据,得到第二数据;所述第一校验和是在写入所述第一数据时,采用预设的校验和算法对所述第一数据进行运算生成的数据;或,当所述第二数据包括至少一个预设魔数时,在所述第一校验和的首尾两端分别设置所述第一采样数据、所述预设魔数中的至少一种,得到第二数据,其中,魔数是指预设的数字常量或字符串;
将至少两个所述第一采样数据进行对比,或检测至少一个所述预设魔数是否发生变化;
若至少两个所述第一采样数据均相同,或至少一个所述预设魔数均未发生变化,则确定所述第一校验和正确。
5.根据权利要求4所述的方法,其特征在于,在所述将至少两个所述第一采样数据进行对比,或检测至少一个所述预设魔数是否发生变化之前,所述方法还包括:
根据所述读取请求从第二存储区域读取所述第一数据;
利用所述第一数据生成第二校验和,并将所述第二校验和与所述第一校验和进行对比;
若所述第二校验和与所述第一校验和不相同,则触发所述将至少两个所述第一采样数据进行对比,或检测至少一个所述预设魔数是否发生变化的步骤。
6.根据权利要求4所述的方法,其特征在于,所述方法还包括:
根据所述读取请求从第二存储区域读取所述第一数据;
在所述确定所述第一校验和正确之后,所述方法还包括:
利用所述第一数据生成第二校验和,并将所述第二校验和与所述第一校验和进行对比;
若所述第二校验和与所述第一校验和不相同,则确定所述第一数据错误。
7.根据权利要求6或5所述的方法,其特征在于,所述方法还包括:
若所述第二校验和与所述第一校验和相同,则将所述第一采样数据与所述第一数据的预设位置的第二采样数据进行对比;
若所述第一采样数据与所述第二采样数据相同,则确定所述第一数据正确。
8.根据权利要求7所述的方法,其特征在于,所述第一数据的大小为所述第二采样数据的大小的200倍至1000倍。
9.根据权利要求4至6中任一项所述的方法,其特征在于,所述第一存储区域为第一磁盘中的第一区域,所述第二存储区域为第二磁盘中的第二区域。
10.一种数据写入装置,其特征在于,包括:
接收单元,用于接收针对第一数据的写入请求;
获取单元,用于根据所述写入请求在所述第一数据的预设位置获取采样数据;
生成单元,用于利用所述第一数据生成第一校验和,其中,每一个校验和是采用预设的校验和算法对输入数据进行运算生成的数据,用于校验写入数据与读出数据的一致性;
处理单元,用于将所述采样数据和所述第一校验和按照预设格式进行处理,得到第二数据,所述第二数据包括至少两个所述采样数据或至少一个预设魔数,所述将所述采样数据和所述第一校验和按照预设格式进行处理,得到第二数据包括:当所述第二数据包括至少两个所述采样数据时,在所述第一校验和的首尾两端分别设置至少一个所述采样数据,得到第二数据;或,当所述第二数据包括至少一个预设魔数时,在所述第一校验和的首尾两端分别设置所述采样数据、所述预设魔数中的至少一种,得到第二数据,其中,魔数是指预设的数字常量或字符串;
写入单元,用于在第一存储区域写入所述第一数据,并按照预设规则在第二存储区域写入所述第二数据。
11.一种验证装置,其特征在于,包括:
接收单元,用于接收针对第一数据的读取请求;
第一读取单元,用于根据所述读取请求从第一存储区域读取所述第一数据对应的第二数据,所述第二数据为将第一校验和与第一采样数据按照预设格式进行处理得到,且包括至少两个所述第一采样数据或至少一个预设魔数,其中,当所述第二数据包括至少两个所述采样数据时,在所述第一校验和的首尾两端分别设置至少一个所述采样数据,得到第二数据;所述第一校验和是在写入所述第一数据时,采用预设的校验和算法对所述第一数据进行运算生成的数据;或,当所述第二数据包括至少一个预设魔数时,在所述第一校验和的首尾两端分别设置所述采样数据、所述预设魔数中的至少一种,得到第二数据,其中,魔数是指预设的数字常量或字符串;
处理单元,用于将至少两个所述第一采样数据进行对比,或检测至少一个所述预设魔数是否发生变化;
第一确定单元,用于当至少两个所述第一采样数据均相同,或至少一个所述预设魔数均未发生变化时,则确定所述第一校验和正确。
12.一种计算机装置,其特征在于:所述计算机装置包括处理器,所述处理器用于执行存储器中存储的计算机程序时实现如权利要求1至3中任意一项所述数据写入方法的步骤。
13.一种计算机可读存储介质,其上存储有计算机程序,其特征在于:所述计算机程序被处理器执行时实现如权利要求1至3中任意一项所述数据写入方法的步骤。
14.一种计算机装置,其特征在于:所述计算机装置包括处理器,所述处理器用于执行存储器中存储的计算机程序时实现如权利要求4至9中任意一项所述验证方法的步骤。
15.一种计算机可读存储介质,其上存储有计算机程序,其特征在于:所述计算机程序被处理器执行时实现如权利要求4至9中任意一项所述验证方法的步骤。
CN201711059999.7A 2017-11-01 2017-11-01 一种数据写入方法及装置、验证方法及装置 Active CN107844273B (zh)

Priority Applications (1)

Application Number Priority Date Filing Date Title
CN201711059999.7A CN107844273B (zh) 2017-11-01 2017-11-01 一种数据写入方法及装置、验证方法及装置

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
CN201711059999.7A CN107844273B (zh) 2017-11-01 2017-11-01 一种数据写入方法及装置、验证方法及装置

Publications (2)

Publication Number Publication Date
CN107844273A CN107844273A (zh) 2018-03-27
CN107844273B true CN107844273B (zh) 2021-05-04

Family

ID=61682177

Family Applications (1)

Application Number Title Priority Date Filing Date
CN201711059999.7A Active CN107844273B (zh) 2017-11-01 2017-11-01 一种数据写入方法及装置、验证方法及装置

Country Status (1)

Country Link
CN (1) CN107844273B (zh)

Families Citing this family (2)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN110955916B (zh) * 2018-09-26 2023-09-05 深信服科技股份有限公司 一种数据完整性保护方法、系统及相关设备
CN113391767B (zh) * 2021-06-30 2022-10-28 北京百度网讯科技有限公司 数据一致性的校验方法、装置、电子设备及可读存储介质

Citations (8)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US5881176A (en) * 1994-09-21 1999-03-09 Ricoh Corporation Compression and decompression with wavelet style and binary style including quantization by device-dependent parser
US7114119B1 (en) * 2002-04-19 2006-09-26 Ncr Corp. Detecting and correcting errors in data
CN103019880A (zh) * 2012-12-14 2013-04-03 华为技术有限公司 一种数据校验方法及存储设备、存储系统
CN104598161A (zh) * 2013-10-31 2015-05-06 腾讯科技(深圳)有限公司 数据读取、写入方法和装置及数据存储结构
CN105183382A (zh) * 2015-09-09 2015-12-23 浪潮(北京)电子信息产业有限公司 一种数据块保护方法及装置
CN105579980A (zh) * 2013-09-27 2016-05-11 仁荷大学校产学协力团 基于ssd的raid系统中的校验数据的去重
CN106537402A (zh) * 2014-08-01 2017-03-22 索尼公司 内容格式转换验证
CN106933499A (zh) * 2015-12-31 2017-07-07 北京京存技术有限公司 一种提高mlc闪存系统性能的方法和装置

Family Cites Families (3)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US7917647B2 (en) * 2000-06-16 2011-03-29 Mcafee, Inc. Method and apparatus for rate limiting
AUPR966201A0 (en) * 2001-12-20 2002-01-24 Canon Information Systems Research Australia Pty Ltd A configurable input buffer
US8412682B2 (en) * 2006-06-29 2013-04-02 Netapp, Inc. System and method for retrieving and using block fingerprints for data deduplication

Patent Citations (8)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US5881176A (en) * 1994-09-21 1999-03-09 Ricoh Corporation Compression and decompression with wavelet style and binary style including quantization by device-dependent parser
US7114119B1 (en) * 2002-04-19 2006-09-26 Ncr Corp. Detecting and correcting errors in data
CN103019880A (zh) * 2012-12-14 2013-04-03 华为技术有限公司 一种数据校验方法及存储设备、存储系统
CN105579980A (zh) * 2013-09-27 2016-05-11 仁荷大学校产学协力团 基于ssd的raid系统中的校验数据的去重
CN104598161A (zh) * 2013-10-31 2015-05-06 腾讯科技(深圳)有限公司 数据读取、写入方法和装置及数据存储结构
CN106537402A (zh) * 2014-08-01 2017-03-22 索尼公司 内容格式转换验证
CN105183382A (zh) * 2015-09-09 2015-12-23 浪潮(北京)电子信息产业有限公司 一种数据块保护方法及装置
CN106933499A (zh) * 2015-12-31 2017-07-07 北京京存技术有限公司 一种提高mlc闪存系统性能的方法和装置

Also Published As

Publication number Publication date
CN107844273A (zh) 2018-03-27

Similar Documents

Publication Publication Date Title
CN107844714B (zh) 一种验证方法及装置、计算机装置、可读存储介质
CN111104246B (zh) 提升dram的错误检测与纠错的验证效率的方法、装置、计算机设备及存储介质
CN108363640B (zh) 数据校验方法及装置、计算机可读存储介质
CN106294040B (zh) 光模块状态信息的获取方法和装置
CN111045881A (zh) 一种慢盘检测方法及系统
CN110727597B (zh) 一种基于日志排查无效代码补全用例的方法
CN107844273B (zh) 一种数据写入方法及装置、验证方法及装置
CN100445963C (zh) 一种实现高可靠性空闲链表的方法及装置
CN112463036B (zh) 一种磁盘计算分块条带的方法、系统、终端及存储介质
CN109918221B (zh) 一种硬盘报错解析方法、系统、终端及存储介质
US11392539B2 (en) Conversion method, conversion apparatus, and recording medium
CN110727691A (zh) 一种数据解析校验方法及装置
CN110580220A (zh) 测量代码段执行时间的方法及终端设备
CN106648969B (zh) 一种磁盘中损坏数据巡检方法及系统
CN105843740B (zh) 代码编译结果的检测方法和装置
CN110955916B (zh) 一种数据完整性保护方法、系统及相关设备
US9299456B2 (en) Matrix and compression-based error detection
US9288161B2 (en) Verifying the functionality of an integrated circuit
CN111143347A (zh) 一种对象存储数据一致性测试方法、系统、终端及存储介质
CN112242177A (zh) 存储器测试方法、装置、计算机可读存储介质及电子设备
CN112416891B (zh) 数据检测方法、装置、电子设备及可读存储介质
US9697073B1 (en) Systems and methods for handling parity and forwarded error in bus width conversion
US8151176B2 (en) CPU instruction RAM parity error procedure
CN109472148B (zh) 加载热补丁的方法、装置和存储介质
US11397662B2 (en) Method for debugging computer program, device employing method, and storage medium

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