CN114138566A - 虚拟机的数据存储方法、装置、虚拟机及存储介质 - Google Patents
虚拟机的数据存储方法、装置、虚拟机及存储介质 Download PDFInfo
- Publication number
- CN114138566A CN114138566A CN202210115376.1A CN202210115376A CN114138566A CN 114138566 A CN114138566 A CN 114138566A CN 202210115376 A CN202210115376 A CN 202210115376A CN 114138566 A CN114138566 A CN 114138566A
- Authority
- CN
- China
- Prior art keywords
- data
- files
- storage
- data storage
- virtual machine
- 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.)
- Granted
Links
- 238000013500 data storage Methods 0.000 title claims abstract description 140
- 238000000034 method Methods 0.000 title claims abstract description 62
- 238000012795 verification Methods 0.000 claims abstract description 37
- 230000002159 abnormal effect Effects 0.000 claims description 106
- 230000015654 memory Effects 0.000 claims description 31
- 238000012545 processing Methods 0.000 claims description 24
- 230000008569 process Effects 0.000 claims description 11
- 238000011084 recovery Methods 0.000 abstract description 9
- 238000010586 diagram Methods 0.000 description 8
- 230000008859 change Effects 0.000 description 6
- 230000001360 synchronised effect Effects 0.000 description 6
- 230000006870 function Effects 0.000 description 4
- 230000000694 effects Effects 0.000 description 2
- 238000007726 management method Methods 0.000 description 2
- 230000003068 static effect Effects 0.000 description 2
- 238000003491 array Methods 0.000 description 1
- 238000004891 communication Methods 0.000 description 1
- 238000013461 design Methods 0.000 description 1
- 238000005516 engineering process Methods 0.000 description 1
- 238000012986 modification Methods 0.000 description 1
- 230000004048 modification Effects 0.000 description 1
- 239000007787 solid Substances 0.000 description 1
- 238000006467 substitution reaction Methods 0.000 description 1
Images
Classifications
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F11/00—Error detection; Error correction; Monitoring
- G06F11/07—Responding to the occurrence of a fault, e.g. fault tolerance
- G06F11/14—Error detection or correction of the data by redundancy in operation
- G06F11/1402—Saving, restoring, recovering or retrying
- G06F11/1446—Point-in-time backing up or restoration of persistent data
- G06F11/1458—Management of the backup or restore process
- G06F11/1469—Backup restoration techniques
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F9/00—Arrangements for program control, e.g. control units
- G06F9/06—Arrangements for program control, e.g. control units using stored programs, i.e. using an internal store of processing equipment to receive or retain programs
- G06F9/44—Arrangements for executing specific programs
- G06F9/455—Emulation; Interpretation; Software simulation, e.g. virtualisation or emulation of application or operating system execution engines
- G06F9/45533—Hypervisors; Virtual machine monitors
- G06F9/45558—Hypervisor-specific management and integration aspects
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F9/00—Arrangements for program control, e.g. control units
- G06F9/06—Arrangements for program control, e.g. control units using stored programs, i.e. using an internal store of processing equipment to receive or retain programs
- G06F9/44—Arrangements for executing specific programs
- G06F9/455—Emulation; Interpretation; Software simulation, e.g. virtualisation or emulation of application or operating system execution engines
- G06F9/45533—Hypervisors; Virtual machine monitors
- G06F9/45558—Hypervisor-specific management and integration aspects
- G06F2009/45575—Starting, stopping, suspending or resuming virtual machine instances
Landscapes
- Engineering & Computer Science (AREA)
- Theoretical Computer Science (AREA)
- Software Systems (AREA)
- Physics & Mathematics (AREA)
- General Engineering & Computer Science (AREA)
- General Physics & Mathematics (AREA)
- Quality & Reliability (AREA)
- Information Retrieval, Db Structures And Fs Structures Therefor (AREA)
Abstract
本发明实施例涉及一种虚拟机的数据存储方法、装置、虚拟机及存储介质,包括:获取虚拟机的启动指令,基于所述启动指令加载存储设备;访问所述存储设备中对应的至少两个文件的第一存储区域记录的元数据信息,对所述元数据信息进行校验,得到校验结果;在所述校验结果正常时,访问所述至少两个文件的第二存储区域记录的数据区域位图信息;基于所述数据区域位图信息确定所述至少两个文件的数据存储状态;在所述至少两个文件的数据存储状态均正常时,向所述至少两个文件发送目标数据进行数据存储,由本方法,通过至少两个文件互为备份的数据存储方式,可以提高虚拟化平台上的容灾恢复效率,保证虚拟机的高可用。
Description
技术领域
本发明实施例涉及数据存储领域,尤其涉及一种虚拟机的数据存储方法、装置、虚拟机及存储介质。
背景技术
在虚拟化领域中,虚拟机或云平台的虚拟机高可用方案一般是由存储设备提供,使用存储设备提供的双活、远程复制等技术通过触发存储的容灾功能来达到虚拟机应用的双活功能。而在虚拟化平台上,一般使用存储设备提供的逻辑单元,在逻辑单元的存储空间上创建文件系统为虚拟机提供存储空间。而虚拟化平台上的容灾恢复需要先使用存储设备恢复逻辑单元上的数据,然后恢复文件系统,最后再恢复文件系统中的文件,最后再恢复虚拟机系统。整个数据恢复的IO栈很长,任何一个层次的数据恢复出现问题会导致虚拟机中的数据丢失。因此,如何提高虚拟化平台上的容灾恢复效率,保证虚拟机的高可用成为亟待解决的问题。
发明内容
鉴于此,为解决上述技术问题或部分技术问题,本发明实施例提供一种虚拟机的数据存储方法、装置、虚拟机及存储介质。
第一方面,本发明实施例提供一种虚拟机的数据存储方法,包括:
获取虚拟机的启动指令,基于所述启动指令加载存储设备;
访问所述存储设备中对应的至少两个文件的第一存储区域记录的元数据信息,对所述元数据信息进行校验,得到校验结果;
在所述校验结果正常时,访问所述至少两个文件的第二存储区域记录的数据区域位图信息;
基于所述数据区域位图信息确定所述至少两个文件的数据存储状态;
在所述至少两个文件的数据存储状态均正常时,向所述至少两个文件发送目标数据进行数据存储。
在一个可能的实施方式中,所述方法还包括:
访问所述至少两个文件的第三存储区域的第一标识信息;
若所述第一标识信息一致,则确定所述至少两个文件中存储的数据一致;
若所述第一标识信息不一致,则确定所述至少两个文件中存储的数据不一致,对所述至少两个文件中存储的数据进行数据同步处理。
在一个可能的实施方式中,所述方法还包括:
在所述虚拟机运行异常时,控制所述至少两个文件的第二存储区域的数据一致以及控制所述至少两个文件的第三存储区域的数据一致;
若所述至少两个文件中存在一个文件异常,则在正常文件的第一存储区域记录异常文件信息。
在一个可能的实施方式中,所述方法还包括:
对比所述至少两个文件的第一存储区域记录的元数据信息;
若所述元数据信息一致,则确定所述校验结果正常;
若所述元数据信息不一致,则确定所述校验结果异常。
在一个可能的实施方式中,所述方法还包括:
基于所述至少两个文件的第二存储区域记录的数据区域位图信息,生成对应的至少两个第二标识信息;
对比所述至少两个第二标识信息;
若所述至少两个第二标识信息一致,则所述至少两个文件的数据存储状态正常;
若所述至少两个第二标识信息不一致,则所述至少两个文件的数据存储状态异常。
在一个可能的实施方式中,所述方法还包括:
在向所述至少两个文件发送目标数据进行数据存储过程中,若存在任一个异常文件,则继续向所述异常文件发送所述目标数据;
若向所述异常文件发送目标数据的次数大于或等于次数阈值,且所述异常文件未成功进行数据存储,则确定所述异常文件的数据存储路径异常。
在一个可能的实施方式中,所述方法还包括:
在确定所述异常文件的数据存储路径异常时,向正常文件发送所述目标数据,以使所述正常文件继续对所述目标数据进行数据存储;
实时检测所述异常文件的数据存储状态,若检测到所述异常文件的数据存储状态正常,则基于所述正常文件中存储的数据对所述异常文件进行数据同步处理;
在所述数据同步处理完成时,执行向所述至少两个文件发送目标数据进行数据存储的步骤。
第二方面,本发明实施例提供一种虚拟机的数据存储装置,包括:
获取模块,用于获取虚拟机的启动指令,基于所述启动指令加载存储设备;
访问模块,用于访问所述存储设备中对应的至少两个文件的第一存储区域记录的元数据信息,对所述元数据信息进行校验,得到校验结果;
所述访问模块,还用于在所述校验结果正常时,访问所述至少两个文件的第二存储区域记录的数据区域位图信息;
确定模块,用于基于所述数据区域位图信息确定所述至少两个文件的数据存储状态;
发送模块,用于在所述至少两个文件的数据存储状态均正常时,向所述至少两个文件发送目标数据进行数据存储。
第三方面,本发明实施例提供一种虚拟机,包括:处理器和存储器,所述处理器用于执行所述存储器中存储的虚拟机的数据存储程序,以实现上述第一方面中所述的虚拟机的数据存储方法。
第四方面,本发明实施例提供一种存储介质,包括:所述存储介质存储有一个或者多个程序,所述一个或者多个程序可被一个或者多个处理器执行,以实现上述第一方面中所述的虚拟机的数据存储方法。
本发明实施例提供的虚拟机的数据存储方案,通过获取虚拟机的启动指令,基于所述启动指令加载存储设备;访问所述存储设备中对应的至少两个文件的第一存储区域记录的元数据信息,对所述元数据信息进行校验,得到校验结果;在所述校验结果正常时,访问所述至少两个文件的第二存储区域记录的数据区域位图信息;基于所述数据区域位图信息确定所述至少两个文件的数据存储状态;在所述至少两个文件的数据存储状态均正常时,向所述至少两个文件发送目标数据进行数据存储,相比于现有技术中使用存储设备提供的逻辑单元,在逻辑单元的存储空间上创建文件系统为虚拟机提供存储空间,而虚拟化平台上的容灾恢复需要先使用存储设备恢复逻辑单元上的数据,然后恢复文件系统,最后再恢复文件系统中的文件,最后再恢复虚拟机系统,整个数据恢复的IO栈很长,任何一个层次的数据恢复出现问题会导致虚拟机中的数据丢失的问题,由本方案,通过至少两个文件互为备份的数据存储方式,可以提高虚拟化平台上的容灾恢复效率,保证虚拟机的高可用。
附图说明
图1为本发明实施例提供的一种虚拟磁盘的布局结构图;
图2为本发明实施例提供的一种第三存储区域的数据存储结构图;
图3为本发明实施例提供的一种虚拟机的数据存储方法的流程示意图;
图4为本发明实施例提供的另一种虚拟机的数据存储方法的流程示意图;
图5为本发明实施例提供的一种虚拟机的数据存储装置的结构示意图;
图6为本发明实施例提供的一种虚拟机的结构示意图。
具体实施方式
为使本发明实施例的目的、技术方案和优点更加清楚,下面将结合本发明实施例中的附图,对本发明实施例中的技术方案进行清楚、完整地描述,显然,所描述的实施例是本发明一部分实施例,而不是全部的实施例。基于本发明中的实施例,本领域普通技术人员在没有做出创造性劳动前提下所获得的所有其他实施例,都属于本发明保护的范围。
为便于对本发明实施例的理解,下面将结合附图以具体实施例做进一步的解释说明,实施例并不构成对本发明实施例的限定。
图1为本发明实施例提供的一种虚拟磁盘的布局结构图,如图1所示,包括虚拟机、虚拟磁盘管理模块、虚拟磁盘,虚拟磁盘管理模块用于对虚拟机的数据存储方法进行执行,本发明实施例以两个文件为例,首先需要对虚拟磁盘的布局结构进行设计,在存储设备提供的两个逻辑单元上的存储空间中分别创建文件系统,再在两个文件系统中分别创建文件为虚拟机提供存储空间,将两个文件均格式化为多个区域,本发明实施例以四个区域为例,包括第一存储区域、第二存储区域、第三存储区域、第四存储区域,其中,第一存储区域可以是superblock区域,主要记录虚拟磁盘的大小,主备两个文件名称等元数据信息;第二存储区域可以为bitmap区域,bitmap区域记录的是数据区域位图信息,每一位表示一段数据区域,本发明可以默认数据区域是4KB,默认预留8K的数据空间,保存两个bitmap数据区域;第三存储区域可以为journal区域记录每一次更新数据的记录;第四存储区域可以为data区域,存储虚拟机的真实数据。
图2为本发明实施例提供的一种第三存储区域的数据存储结构图,如图2所示,第三存储区域为journal区域,数据存储模式可以分为四个区域,用以记录元数据变动的历史信息,分别为:New uuid、Bitmap uuid、Last uuid、History uuid。其中,New uuid是当前最新的元数据变更时生成的uuid信息;Bitmap uuid记录是当前数据区域的bitmap生成的uuid;Last uuid是上次的元数据变化生成的uuid信息;History uuid是上上次的元数据变化生成的uuid信息;uuid信息为数据发生变化产生的标识信息,还可以包含有数据发生变化的时间等信息。
图3为本发明实施例提供的一种虚拟机的数据存储方法的流程示意图,如图3所示,该方法具体包括:
S31、获取虚拟机的启动指令,基于所述启动指令加载存储设备。
本发明实施例中,首先获取虚拟机的启动指令,虚拟机在接收到启动指令后,加载存储设备,本发明实施例中的存储设备可以是磁盘。
S32、访问所述存储设备中对应的至少两个文件的第一存储区域记录的元数据信息,对所述元数据信息进行校验,得到校验结果。
访问存储设备中对应的两个文件系统中分别创建的至少两个文件,本发明实施例以两个文件进行说明,该两个文件可以互为主备文件,访问两个文件对应的第一存储区域,该第一存储区域可以为superblock区域,由于superblock区域中主要记录虚拟磁盘的大小,主备两个文件名称等元数据信息,上述元数据信息可以表示为一个uuid标识,若两个文件中记录的uuid标识相同,则可以确定校验结果正常,表征两个文件为同一组主备文件;相应的,若两个文件中记录的uuid标识不同,则可以确定校验结果异常,表征两个文件不为同一组主备文件。
S33、在所述校验结果正常时,访问所述至少两个文件的第二存储区域记录的数据区域位图信息。
S34、基于所述数据区域位图信息确定所述至少两个文件的数据存储状态。
以下对S33-S34进行统一说明:
在确定两个文件为同一组主备文件时,分别读取两个文件中的第二存储区,该第二存储区域可以是bitmap区域,同时根据bitmap区域记录的数据区域位图信息也可以生成相应的uuid标识,进而读取两个文件分别在第三存储区域(journal区域)的bitmap uuid标识,比较两个文件的bitmap uuid标识是否一致,若一致,则认定两个文件的数据存储状态正常,可正常进行数据存储;若不一致,则认定两个文件的数据存储状态异常,不可进行数据存储。
S35、在所述至少两个文件的数据存储状态均正常时,向所述至少两个文件发送目标数据进行数据存储。
本发明实施例中,在确定两个文件的数据存储状态均正常时,可以向两个文件分别发送目标数据进行数据存储。
本发明实施例提供的虚拟机的数据存储方法,通过获取虚拟机的启动指令,基于所述启动指令加载存储设备;访问所述存储设备中对应的至少两个文件的第一存储区域记录的元数据信息,对所述元数据信息进行校验,得到校验结果;在所述校验结果正常时,访问所述至少两个文件的第二存储区域记录的数据区域位图信息;基于所述数据区域位图信息确定所述至少两个文件的数据存储状态;在所述至少两个文件的数据存储状态均正常时,向所述至少两个文件发送目标数据进行数据存储,相比于现有技术中使用存储设备提供的逻辑单元,在逻辑单元的存储空间上创建文件系统为虚拟机提供存储空间,而虚拟化平台上的容灾恢复需要先使用存储设备恢复逻辑单元上的数据,然后恢复文件系统,最后再恢复文件系统中的文件,最后再恢复虚拟机系统,整个数据恢复的IO栈很长,任何一个层次的数据恢复出现问题会导致虚拟机中的数据丢失的问题,由本方法,通过至少两个文件互为备份的数据存储方式,可以提高虚拟化平台上的容灾恢复效率,保证虚拟机的高可用。
图4为本发明实施例提供的另一种虚拟机的数据存储方法的流程示意图,如图4所示,该方法具体包括:
S41、访问所述至少两个文件的第三存储区域的第一标识信息。
本发明实施例中,可以在数据存储之前,对两个文件进行数据同步处理,访问两个文件的第三存储区域的第一标识信息,该第一标识信息可以为New uuid、Bitmap uuid、Last uuid、History uuid标识。
S42、若所述第一标识信息一致,则确定所述至少两个文件中存储的数据一致。
若两个文件中分别对应的第一标识信息均一致,即主文件的New uuid与备文件New uuid一致、主文件的Bitmap uuid与备文件Bitmap uuid一致、主文件的Last uuid与备文件Last uuid一致、主文件的History uuid与备文件History uuid一致,则确定两个文件中存储的数据一致,无需进行数据同步处理。
S43、若所述第一标识信息不一致,则确定所述至少两个文件中存储的数据不一致,对所述至少两个文件中存储的数据进行数据同步处理。
若两个文件的New uuid均为空,则说明两个文件是新建文件,没有数据变更,正常加载至虚拟机进程即可;若两个文件的New uuid一致,则确认两个文件的数据是一致的,无需进行数据同步。
可选的,若其中一个文件的New uuid与另一文件中Last uuid或History uuid一致,则说明该文件的数据为老旧数据,需要将另一个文件的数据全量同步至该文件中。
可选的,若其中一个文件的New uuid与另一文件中的Last uuid或History uuid都不一致,则确定两个文件中的数据不一致,则存储设备加载失败,需要等待手动校验并同步相关数据。此问题发生的情况可能是在数据存储过程中,其中一个文件出现异常,不再接收数据,而另一个正常的文件继续进行数据存储,经过一定的时间,导致两个文件的数据存在较大差异,此时导致其中一个文件的New uuid与另一文件中的Last uuid或Historyuuid都不一致,需要等待手动校验并同步相关数据。
S44、在所述虚拟机运行异常时,控制所述至少两个文件的第二存储区域的数据一致以及控制所述至少两个文件的第三存储区域的数据一致。
本发明实施例中,在数据存储过程中还可能出现虚拟机以外关机或宕机的情况,在虚拟机运行异常时,访问两个文件的第二存储区域,基于第二存储区域的标识信息,确定数据最新的文件,将数据最新的文件中的数据同步到另一文件中;相应的,访问两个文件的第三存储区域,由于第三存储区域记录每一次更新数据的记录,因此,保证两个文件的第三存储区域的数据记录一致,可以表征两个文件在虚拟机运行异常时数据一致。
S45、若所述至少两个文件中存在一个文件异常,则在正常文件的第一存储区域记录异常文件信息。
若在虚拟机运行异常时,两个文件中存在一个文件异常,则在正常文件的第一存储区域记录该异常文件的文件信息,并标记该异常文件不可用。
S46、在向所述至少两个文件发送目标数据进行数据存储过程中,若存在任一个异常文件,则继续向所述异常文件发送所述目标数据。
本发明实施例中,在数据存储过程中还可能由于网络等原因出现其中一个文件异常,无法向该异常文件正常发送目标数据,不能进行数据存储,此时,继续向该异常文件发送目标数据。
S47、若向所述异常文件发送目标数据的次数大于或等于次数阈值,且所述异常文件未成功进行数据存储,则确定所述异常文件的数据存储路径异常。
若向异常文件发送目标数据的次数大于或等于次数阈值(例如,5次),此时异常文件仍然无法成功进行数据存储,则判定该异常文件的数据存储路径异常。
S48、在确定所述异常文件的数据存储路径异常时,向正常文件发送所述目标数据,以使所述正常文件继续对所述目标数据进行数据存储。
在确定异常文件的数据存储路径异常时,虚拟机继续承接服务,继续向正常文件发送目标数据,以使该正常文件继续对目标数据进行数据存储,保证虚拟机的正常服务。
S49、实时检测所述异常文件的数据存储状态,若检测到所述异常文件的数据存储状态正常,则基于所述正常文件中存储的数据对所述异常文件进行数据同步处理。
实时检测异常文件的数据存储状态,待异常文件恢复后,可以检测到异常文件的数据存储状态正常,基于正常文件中存储的数据,将数据同步到该异常文件中。其中,可以根据第三存储区域中的uuid,判断数据同步方向。
S410、在所述数据同步处理完成时,执行向所述至少两个文件发送目标数据进行数据存储的步骤。
本发明实施例中,数据同步过程中,正常文件仍然在接收目标数据进行数据存储,保证虚拟机的服务,此时可以控制数据同步量大于正常文件的数据存储量,经过一定的时间可以完成两个文件的数据同步,数据同步完成时,可以继续同时向两个文件发送目标数据,以使两个文件对目标数据进行数据存储。
本发明实施例提供的虚拟机的数据存储方法,通过获取虚拟机的启动指令,基于所述启动指令加载存储设备;访问所述存储设备中对应的至少两个文件的第一存储区域记录的元数据信息,对所述元数据信息进行校验,得到校验结果;在所述校验结果正常时,访问所述至少两个文件的第二存储区域记录的数据区域位图信息;基于所述数据区域位图信息确定所述至少两个文件的数据存储状态;在所述至少两个文件的数据存储状态均正常时,向所述至少两个文件发送目标数据进行数据存储,由本方法,通过至少两个文件互为备份的数据存储方式,可以提高虚拟化平台上的容灾恢复效率,保证虚拟机的高可用。
图5为本发明实施例提供的一种虚拟机的数据存储装置,具体包括:
获取模块501,用于获取虚拟机的启动指令,基于所述启动指令加载存储设备;
访问模块502,用于访问所述存储设备中对应的至少两个文件的第一存储区域记录的元数据信息,对所述元数据信息进行校验,得到校验结果;
所述访问模块502,还用于在所述校验结果正常时,访问所述至少两个文件的第二存储区域记录的数据区域位图信息;
确定模块503,用于基于所述数据区域位图信息确定所述至少两个文件的数据存储状态;
发送模块504,用于在所述至少两个文件的数据存储状态均正常时,向所述至少两个文件发送目标数据进行数据存储。
在一个可能的实施方式中,所述访问模块502,具体用于访问所述至少两个文件的第三存储区域的第一标识信息。
在一个可能的实施方式中,所述确定模块503,具体用于若所述第一标识信息一致,则确定所述至少两个文件中存储的数据一致;若所述第一标识信息不一致,则确定所述至少两个文件中存储的数据不一致,对所述至少两个文件中存储的数据进行数据同步处理。
在一个可能的实施方式中,所述确定模块503,还用于对比所述至少两个文件的第一存储区域记录的元数据信息;若所述元数据信息一致,则确定所述校验结果正常;若所述元数据信息不一致,则确定所述校验结果异常。
在一个可能的实施方式中,所述确定模块503,还用于基于所述至少两个文件的第二存储区域记录的数据区域位图信息,生成对应的至少两个第二标识信息;对比所述至少两个第二标识信息;若所述至少两个第二标识信息一致,则所述至少两个文件的数据存储状态正常;若所述至少两个第二标识信息不一致,则所述至少两个文件的数据存储状态异常。
在一个可能的实施方式中,所述发送模块504,具体用于在向所述至少两个文件发送目标数据进行数据存储过程中,若存在任一个异常文件,则继续向所述异常文件发送所述目标数据;若向所述异常文件发送目标数据的次数大于或等于次数阈值,且所述异常文件未成功进行数据存储,则确定所述异常文件的数据存储路径异常。
在一个可能的实施方式中,所述发送模块504,还用于在确定所述异常文件的数据存储路径异常时,向正常文件发送所述目标数据,以使所述正常文件继续对所述目标数据进行数据存储;实时检测所述异常文件的数据存储状态,若检测到所述异常文件的数据存储状态正常,则基于所述正常文件中存储的数据对所述异常文件进行数据同步处理;在所述数据同步处理完成时,执行向所述至少两个文件发送目标数据进行数据存储的步骤。
在一个可能的实施方式中,所述发送模块504,还用于在所述虚拟机运行异常时,控制所述至少两个文件的第二存储区域的数据一致以及控制所述至少两个文件的第三存储区域的数据一致;若所述至少两个文件中存在一个文件异常,则在正常文件的第一存储区域记录异常文件信息。
本实施例提供的虚拟机的数据存储装置可以是如图5中所示的虚拟机的数据存储装置,可执行如图3-4中虚拟机的数据存储方法的所有步骤,进而实现图3-4所示虚拟机的数据存储方法的技术效果,具体请参照图3-4相关描述,为简洁描述,在此不作赘述。
图6为本发明实施例提供的一种虚拟机的结构示意图,图6所示的虚拟机600包括:至少一个处理器601、存储器602、至少一个网络接口604和其他用户接口603。虚拟机600中的各个组件通过总线系统605耦合在一起。可理解,总线系统605用于实现这些组件之间的连接通信。总线系统605除包括数据总线之外,还包括电源总线、控制总线和状态信号总线。但是为了清楚说明起见,在图6中将各种总线都标为总线系统605。
其中,用户接口603可以包括显示器、键盘或者点击设备(例如,鼠标,轨迹球(trackball)、触感板或者触摸屏等。
可以理解,本发明实施例中的存储器602可以是易失性存储器或非易失性存储器,或可包括易失性和非易失性存储器两者。其中,非易失性存储器可以是只读存储器(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)。本文描述的存储器602旨在包括但不限于这些和任意其它适合类型的存储器。
在一些实施方式中,存储器602存储了如下的元素,可执行单元或者数据结构,或者他们的子集,或者他们的扩展集:操作系统6021和应用程序6022。
其中,操作系统6021,包含各种系统程序,例如框架层、核心库层、驱动层等,用于实现各种基础业务以及处理基于硬件的任务。应用程序6022,包含各种应用程序,例如媒体播放器(Media Player)、浏览器(Browser)等,用于实现各种应用业务。实现本发明实施例方法的程序可以包含在应用程序6022中。
在本发明实施例中,通过调用存储器602存储的程序或指令,具体的,可以是应用程序6022中存储的程序或指令,处理器601用于执行各方法实施例所提供的方法步骤,例如包括:
获取虚拟机的启动指令,基于所述启动指令加载存储设备;访问所述存储设备中对应的至少两个文件的第一存储区域记录的元数据信息,对所述元数据信息进行校验,得到校验结果;在所述校验结果正常时,访问所述至少两个文件的第二存储区域记录的数据区域位图信息;基于所述数据区域位图信息确定所述至少两个文件的数据存储状态;在所述至少两个文件的数据存储状态均正常时,向所述至少两个文件发送目标数据进行数据存储。
在一个可能的实施方式中,访问所述至少两个文件的第三存储区域的第一标识信息;若所述第一标识信息一致,则确定所述至少两个文件中存储的数据一致;若所述第一标识信息不一致,则确定所述至少两个文件中存储的数据不一致,对所述至少两个文件中存储的数据进行数据同步处理。
在一个可能的实施方式中,在所述虚拟机运行异常时,控制所述至少两个文件的第二存储区域的数据一致以及控制所述至少两个文件的第三存储区域的数据一致;若所述至少两个文件中存在一个文件异常,则在正常文件的第一存储区域记录异常文件信息。
在一个可能的实施方式中,对比所述至少两个文件的第一存储区域记录的元数据信息;若所述元数据信息一致,则确定所述校验结果正常;若所述元数据信息不一致,则确定所述校验结果异常。
在一个可能的实施方式中,基于所述至少两个文件的第二存储区域记录的数据区域位图信息,生成对应的至少两个第二标识信息;对比所述至少两个第二标识信息;若所述至少两个第二标识信息一致,则所述至少两个文件的数据存储状态正常;若所述至少两个第二标识信息不一致,则所述至少两个文件的数据存储状态异常。
在一个可能的实施方式中,在向所述至少两个文件发送目标数据进行数据存储过程中,若存在任一个异常文件,则继续向所述异常文件发送所述目标数据;若向所述异常文件发送目标数据的次数大于或等于次数阈值,且所述异常文件未成功进行数据存储,则确定所述异常文件的数据存储路径异常。
在一个可能的实施方式中,在确定所述异常文件的数据存储路径异常时,向正常文件发送所述目标数据,以使所述正常文件继续对所述目标数据进行数据存储;实时检测所述异常文件的数据存储状态,若检测到所述异常文件的数据存储状态正常,则基于所述正常文件中存储的数据对所述异常文件进行数据同步处理;在所述数据同步处理完成时,执行向所述至少两个文件发送目标数据进行数据存储的步骤。
上述本发明实施例揭示的方法可以应用于处理器601中,或者由处理器601实现。处理器601可能是一种集成电路芯片,具有信号的处理能力。在实现过程中,上述方法的各步骤可以通过处理器601中的硬件的集成逻辑电路或者软件形式的指令完成。上述的处理器601可以是通用处理器、数字信号处理器(Digital Signal Processor,DSP)、专用集成电路(Application Specific Integrated Circuit,ASIC)、现成可编程门阵列(FieldProgrammable Gate Array, FPGA)或者其他可编程逻辑器件、分立门或者晶体管逻辑器件、分立硬件组件。可以实现或者执行本发明实施例中的公开的各方法、步骤及逻辑框图。通用处理器可以是微处理器或者该处理器也可以是任何常规的处理器等。结合本发明实施例所公开的方法的步骤可以直接体现为硬件译码处理器执行完成,或者用译码处理器中的硬件及软件单元组合执行完成。软件单元可以位于随机存储器,闪存、只读存储器,可编程只读存储器或者电可擦写可编程存储器、寄存器等本领域成熟的存储介质中。该存储介质位于存储器602,处理器601读取存储器602中的信息,结合其硬件完成上述方法的步骤。
可以理解的是,本文描述的这些实施例可以用硬件、软件、固件、中间件、微码或其组合来实现。对于硬件实现,处理单元可以实现在一个或多个专用集成电路(ApplicationSpecific Integrated Circuits,ASIC)、数字信号处理器(Digital Signal Processing,DSP)、数字信号处理设备(DSPDevice,DSPD)、可编程逻辑设备(Programmable LogicDevice,PLD)、现场可编程门阵列(Field-Programmable Gate Array,FPGA)、通用处理器、控制器、微控制器、微处理器、用于执行本申请所述功能的其它电子单元或其组合中。
对于软件实现,可通过执行本文所述功能的单元来实现本文所述的技术。软件代码可存储在存储器中并通过处理器执行。存储器可以在处理器中或在处理器外部实现。
本实施例提供的虚拟机可以是如图6中所示的虚拟机,可执行如图3-4中虚拟机的数据存储方法的所有步骤,进而实现图3-4所示虚拟机的数据存储方法的技术效果,具体请参照图3-4相关描述,为简洁描述,在此不作赘述。
本发明实施例还提供了一种存储介质(计算机可读存储介质)。这里的存储介质存储有一个或者多个程序。其中,存储介质可以包括易失性存储器,例如随机存取存储器;存储器也可以包括非易失性存储器,例如只读存储器、快闪存储器、硬盘或固态硬盘;存储器还可以包括上述种类的存储器的组合。
当存储介质中一个或者多个程序可被一个或者多个处理器执行,以实现上述在虚拟机侧执行的虚拟机的数据存储方法。
所述处理器用于执行存储器中存储的虚拟机的数据存储程序,以实现以下在虚拟机侧执行的虚拟机的数据存储方法的步骤:
获取虚拟机的启动指令,基于所述启动指令加载存储设备;访问所述存储设备中对应的至少两个文件的第一存储区域记录的元数据信息,对所述元数据信息进行校验,得到校验结果;在所述校验结果正常时,访问所述至少两个文件的第二存储区域记录的数据区域位图信息;基于所述数据区域位图信息确定所述至少两个文件的数据存储状态;在所述至少两个文件的数据存储状态均正常时,向所述至少两个文件发送目标数据进行数据存储。
在一个可能的实施方式中,访问所述至少两个文件的第三存储区域的第一标识信息;若所述第一标识信息一致,则确定所述至少两个文件中存储的数据一致;若所述第一标识信息不一致,则确定所述至少两个文件中存储的数据不一致,对所述至少两个文件中存储的数据进行数据同步处理。
在一个可能的实施方式中,在所述虚拟机运行异常时,控制所述至少两个文件的第二存储区域的数据一致以及控制所述至少两个文件的第三存储区域的数据一致;若所述至少两个文件中存在一个文件异常,则在正常文件的第一存储区域记录异常文件信息。
在一个可能的实施方式中,对比所述至少两个文件的第一存储区域记录的元数据信息;若所述元数据信息一致,则确定所述校验结果正常;若所述元数据信息不一致,则确定所述校验结果异常。
在一个可能的实施方式中,基于所述至少两个文件的第二存储区域记录的数据区域位图信息,生成对应的至少两个第二标识信息;对比所述至少两个第二标识信息;若所述至少两个第二标识信息一致,则所述至少两个文件的数据存储状态正常;若所述至少两个第二标识信息不一致,则所述至少两个文件的数据存储状态异常。
在一个可能的实施方式中,在向所述至少两个文件发送目标数据进行数据存储过程中,若存在任一个异常文件,则继续向所述异常文件发送所述目标数据;若向所述异常文件发送目标数据的次数大于或等于次数阈值,且所述异常文件未成功进行数据存储,则确定所述异常文件的数据存储路径异常。
在一个可能的实施方式中,在确定所述异常文件的数据存储路径异常时,向正常文件发送所述目标数据,以使所述正常文件继续对所述目标数据进行数据存储;实时检测所述异常文件的数据存储状态,若检测到所述异常文件的数据存储状态正常,则基于所述正常文件中存储的数据对所述异常文件进行数据同步处理;在所述数据同步处理完成时,执行向所述至少两个文件发送目标数据进行数据存储的步骤。
专业人员应该还可以进一步意识到,结合本文中所公开的实施例描述的各示例的单元及算法步骤,能够以电子硬件、计算机软件或者二者的结合来实现,为了清楚地说明硬件和软件的可互换性,在上述说明中已经按照功能一般性地描述了各示例的组成及步骤。这些功能究竟以硬件还是软件方式来执行,取决于技术方案的特定应用和设计约束条件。专业技术人员可以对每个特定的应用来使用不同方法来实现所描述的功能,但是这种实现不应认为超出本发明的范围。
结合本文中所公开的实施例描述的方法或算法的步骤可以用硬件、处理器执行的软件模块,或者二者的结合来实施。软件模块可以置于随机存储器(RAM)、内存、只读存储器(ROM)、电可编程ROM、电可擦除可编程ROM、寄存器、硬盘、可移动磁盘、CD-ROM、或技术领域内所公知的任意其它形式的存储介质中。
以上所述的具体实施方式,对本发明的目的、技术方案和有益效果进行了进一步详细说明,所应理解的是,以上所述仅为本发明的具体实施方式而已,并不用于限定本发明的保护范围,凡在本发明的精神和原则之内,所做的任何修改、等同替换、改进等,均应包含在本发明的保护范围之内。
Claims (10)
1.一种虚拟机的数据存储方法,其特征在于,包括:
获取虚拟机的启动指令,基于所述启动指令加载存储设备;
访问所述存储设备中对应的至少两个文件的第一存储区域记录的元数据信息,对所述元数据信息进行校验,得到校验结果;
在所述校验结果正常时,访问所述至少两个文件的第二存储区域记录的数据区域位图信息;
基于所述数据区域位图信息确定所述至少两个文件的数据存储状态;
在所述至少两个文件的数据存储状态均正常时,向所述至少两个文件发送目标数据进行数据存储。
2.根据权利要求1所述的方法,其特征在于,所述方法还包括:
访问所述至少两个文件的第三存储区域的第一标识信息;
若所述第一标识信息一致,则确定所述至少两个文件中存储的数据一致;
若所述第一标识信息不一致,则确定所述至少两个文件中存储的数据不一致,对所述至少两个文件中存储的数据进行数据同步处理。
3.根据权利要求1所述的方法,其特征在于,所述方法还包括:
在所述虚拟机运行异常时,控制所述至少两个文件的第二存储区域的数据一致以及控制所述至少两个文件的第三存储区域的数据一致;
若所述至少两个文件中存在一个文件异常,则在正常文件的第一存储区域记录异常文件信息。
4.根据权利要求1所述的方法,其特征在于,所述访问所述存储设备中对应的至少两个文件的第一存储区域记录的元数据信息,对所述元数据信息进行校验,得到校验结果,包括:
对比所述至少两个文件的第一存储区域记录的元数据信息;
若所述元数据信息一致,则确定所述校验结果正常;
若所述元数据信息不一致,则确定所述校验结果异常。
5.根据权利要求4所述的方法,其特征在于,所述基于所述数据区域位图信息确定所述至少两个文件的数据存储状态,包括:
基于所述至少两个文件的第二存储区域记录的数据区域位图信息,生成对应的至少两个第二标识信息;
对比所述至少两个第二标识信息;
若所述至少两个第二标识信息一致,则所述至少两个文件的数据存储状态正常;
若所述至少两个第二标识信息不一致,则所述至少两个文件的数据存储状态异常。
6.根据权利要求5所述的方法,其特征在于,所述方法还包括:
在向所述至少两个文件发送目标数据进行数据存储过程中,若存在任一个异常文件,则继续向所述异常文件发送所述目标数据;
若向所述异常文件发送目标数据的次数大于或等于次数阈值,且所述异常文件未成功进行数据存储,则确定所述异常文件的数据存储路径异常。
7.根据权利要求6所述的方法,其特征在于,所述方法还包括:
在确定所述异常文件的数据存储路径异常时,向正常文件发送所述目标数据,以使所述正常文件继续对所述目标数据进行数据存储;
实时检测所述异常文件的数据存储状态,若检测到所述异常文件的数据存储状态正常,则基于所述正常文件中存储的数据对所述异常文件进行数据同步处理;
在所述数据同步处理完成时,执行向所述至少两个文件发送目标数据进行数据存储的步骤。
8.一种虚拟机的数据存储装置,其特征在于,包括:
获取模块,用于获取虚拟机的启动指令,基于所述启动指令加载存储设备;
访问模块,用于访问所述存储设备中对应的至少两个文件的第一存储区域记录的元数据信息,对所述元数据信息进行校验,得到校验结果;
所述访问模块,还用于在所述校验结果正常时,访问所述至少两个文件的第二存储区域记录的数据区域位图信息;
确定模块,用于基于所述数据区域位图信息确定所述至少两个文件的数据存储状态;
发送模块,用于在所述至少两个文件的数据存储状态均正常时,向所述至少两个文件发送目标数据进行数据存储。
9.一种虚拟机,其特征在于,包括:处理器和存储器,所述处理器用于执行所述存储器中存储的虚拟机的数据存储程序,以实现权利要求1~7中任一项所述的虚拟机的数据存储方法。
10.一种存储介质,其特征在于,所述存储介质存储有一个或者多个程序,所述一个或者多个程序可被一个或者多个处理器执行,以实现权利要求1~7中任一项所述的虚拟机的数据存储方法。
Priority Applications (2)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN202210115376.1A CN114138566B (zh) | 2022-02-07 | 2022-02-07 | 虚拟机的数据存储方法、装置、虚拟机及存储介质 |
PCT/CN2022/135166 WO2023147738A1 (zh) | 2022-02-07 | 2022-11-29 | 虚拟机的数据存储方法、装置、虚拟机及存储介质 |
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN202210115376.1A CN114138566B (zh) | 2022-02-07 | 2022-02-07 | 虚拟机的数据存储方法、装置、虚拟机及存储介质 |
Publications (2)
Publication Number | Publication Date |
---|---|
CN114138566A true CN114138566A (zh) | 2022-03-04 |
CN114138566B CN114138566B (zh) | 2022-04-29 |
Family
ID=80381852
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
CN202210115376.1A Active CN114138566B (zh) | 2022-02-07 | 2022-02-07 | 虚拟机的数据存储方法、装置、虚拟机及存储介质 |
Country Status (2)
Country | Link |
---|---|
CN (1) | CN114138566B (zh) |
WO (1) | WO2023147738A1 (zh) |
Cited By (1)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
WO2023147738A1 (zh) * | 2022-02-07 | 2023-08-10 | 苏州浪潮智能科技有限公司 | 虚拟机的数据存储方法、装置、虚拟机及存储介质 |
Citations (6)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN102693230A (zh) * | 2011-03-23 | 2012-09-26 | 伊姆西公司 | 用于存储区域网络的文件系统 |
CN103748545A (zh) * | 2011-08-26 | 2014-04-23 | 威睿公司 | 数据存储系统和数据存储控制方法 |
CN104794028A (zh) * | 2014-01-16 | 2015-07-22 | 中国移动通信集团浙江有限公司 | 一种容灾处理方法、装置、主用数据中心和备用数据中心 |
WO2016191964A1 (zh) * | 2015-05-29 | 2016-12-08 | 华为技术有限公司 | 一种文件系统的管理方法及装置 |
CN109815207A (zh) * | 2018-12-28 | 2019-05-28 | 深圳市安云信息科技有限公司 | 数据存储方法和客户端代理 |
CN111625401A (zh) * | 2020-05-29 | 2020-09-04 | 浪潮电子信息产业股份有限公司 | 基于集群文件系统的数据备份方法、装置及可读存储介质 |
Family Cites Families (6)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN102609365B (zh) * | 2012-02-15 | 2015-09-23 | 合一网络技术(北京)有限公司 | 一种虚拟磁盘系统和基于虚拟磁盘系统的文件存储方法 |
US11144412B2 (en) * | 2017-06-05 | 2021-10-12 | Vmware, Inc. | Virtual machine image file synchronization using delta bitmaps and delta files |
CN111708603A (zh) * | 2020-05-24 | 2020-09-25 | 苏州浪潮智能科技有限公司 | 一种实时保护Openstack云主机数据的方法和设备 |
CN112711498A (zh) * | 2020-12-29 | 2021-04-27 | 北京浪潮数据技术有限公司 | 一种虚拟机容灾备份方法、装置、设备及可读存储介质 |
CN113190177B (zh) * | 2021-05-12 | 2023-07-14 | 西安雷风电子科技有限公司 | 数据存储方法、终端设备、服务器及系统 |
CN114138566B (zh) * | 2022-02-07 | 2022-04-29 | 苏州浪潮智能科技有限公司 | 虚拟机的数据存储方法、装置、虚拟机及存储介质 |
-
2022
- 2022-02-07 CN CN202210115376.1A patent/CN114138566B/zh active Active
- 2022-11-29 WO PCT/CN2022/135166 patent/WO2023147738A1/zh unknown
Patent Citations (6)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN102693230A (zh) * | 2011-03-23 | 2012-09-26 | 伊姆西公司 | 用于存储区域网络的文件系统 |
CN103748545A (zh) * | 2011-08-26 | 2014-04-23 | 威睿公司 | 数据存储系统和数据存储控制方法 |
CN104794028A (zh) * | 2014-01-16 | 2015-07-22 | 中国移动通信集团浙江有限公司 | 一种容灾处理方法、装置、主用数据中心和备用数据中心 |
WO2016191964A1 (zh) * | 2015-05-29 | 2016-12-08 | 华为技术有限公司 | 一种文件系统的管理方法及装置 |
CN109815207A (zh) * | 2018-12-28 | 2019-05-28 | 深圳市安云信息科技有限公司 | 数据存储方法和客户端代理 |
CN111625401A (zh) * | 2020-05-29 | 2020-09-04 | 浪潮电子信息产业股份有限公司 | 基于集群文件系统的数据备份方法、装置及可读存储介质 |
Non-Patent Citations (1)
Title |
---|
XUN ZHAO等: "Liquid: A Scalable Deduplication File System for Virtual Machine Images", 《IEEE TRANSACTIONS ON PARALLEL AND DISTRIBUTED SYSTEMS》 * |
Cited By (1)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
WO2023147738A1 (zh) * | 2022-02-07 | 2023-08-10 | 苏州浪潮智能科技有限公司 | 虚拟机的数据存储方法、装置、虚拟机及存储介质 |
Also Published As
Publication number | Publication date |
---|---|
CN114138566B (zh) | 2022-04-29 |
WO2023147738A1 (zh) | 2023-08-10 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
CN106776130B (zh) | 一种日志恢复方法、存储装置和存储节点 | |
EP3474143B1 (en) | Method and apparatus for incremental recovery of data | |
CN111538719A (zh) | 数据迁移方法、装置、设备及计算机存储介质 | |
JP5534043B2 (ja) | ストレージシステム | |
CN110162429A (zh) | 系统修复方法、服务器及存储介质 | |
CN111046024A (zh) | 一种共享存储数据库的数据处理方法、装置、设备及介质 | |
US8290992B2 (en) | File management method, file management device, and program | |
JPWO2009004674A1 (ja) | 記憶装置、ディスク装置、書込み判定方法、制御装置 | |
CN114138566B (zh) | 虚拟机的数据存储方法、装置、虚拟机及存储介质 | |
CN108572888B (zh) | 磁盘快照创建方法和磁盘快照创建装置 | |
CN114138192A (zh) | 存储节点在线升级方法、装置、系统及存储介质 | |
CN113312205B (zh) | 数据校验方法、装置、存储介质和计算机设备 | |
CN110879764B (zh) | 一种位图设置方法、装置、设备及可读存储介质 | |
CN113703673B (zh) | 一种单机数据存储方法及相关装置 | |
US7529973B2 (en) | Method of and apparatus for taking back-up and checking alteration of data, and computer product | |
US11429537B2 (en) | Method, device, and computer program product for managing storage system | |
CN113886352A (zh) | 分布式文件系统的元数据恢复方法、装置、设备及介质 | |
CN113467805A (zh) | 一种网络设备的固件回滚方法及相关装置 | |
CN111104256A (zh) | 一种数据读取方法、装置、设备及存储介质 | |
CN113821378B (zh) | 一种云硬盘备份方法、系统、存储介质及设备 | |
CN107656747B (zh) | 一种数据升级方法及移动终端 | |
CN113608922A (zh) | 一种备份系统切换方法和装置 | |
CN115952031A (zh) | 脑裂文件的恢复方法、装置、计算机设备及可读存储介质 | |
CN115268786A (zh) | 数据写入方法、分布式存储系统、设备和存储介质 | |
CN115309587A (zh) | 一种efs分区数据备份的方法、装置及终端 |
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 |