CN117873955A - 文件***管理方法、装置和存储介质 - Google Patents

文件***管理方法、装置和存储介质 Download PDF

Info

Publication number
CN117873955A
CN117873955A CN202211241709.1A CN202211241709A CN117873955A CN 117873955 A CN117873955 A CN 117873955A CN 202211241709 A CN202211241709 A CN 202211241709A CN 117873955 A CN117873955 A CN 117873955A
Authority
CN
China
Prior art keywords
file system
data
target
source
target file
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.)
Pending
Application number
CN202211241709.1A
Other languages
English (en)
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.)
Chengdu Huawei Technology Co Ltd
Original Assignee
Chengdu Huawei 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 Chengdu Huawei Technology Co Ltd filed Critical Chengdu Huawei Technology Co Ltd
Priority to CN202211241709.1A priority Critical patent/CN117873955A/zh
Priority to PCT/CN2023/103850 priority patent/WO2024078029A1/zh
Publication of CN117873955A publication Critical patent/CN117873955A/zh
Pending legal-status Critical Current

Links

Classifications

    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F16/00Information retrieval; Database structures therefor; File system structures therefor
    • G06F16/10File systems; File servers
    • G06F16/11File system administration, e.g. details of archiving or snapshots
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F16/00Information retrieval; Database structures therefor; File system structures therefor
    • G06F16/20Information retrieval; Database structures therefor; File system structures therefor of structured data, e.g. relational data
    • G06F16/27Replication, distribution or synchronisation of data between databases or within a distributed database system; Distributed database system architectures therefor
    • 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

Landscapes

  • Engineering & Computer Science (AREA)
  • Theoretical Computer Science (AREA)
  • Databases & Information Systems (AREA)
  • Physics & Mathematics (AREA)
  • General Engineering & Computer Science (AREA)
  • General Physics & Mathematics (AREA)
  • Data Mining & Analysis (AREA)
  • Computing Systems (AREA)
  • Human Computer Interaction (AREA)
  • Information Retrieval, Db Structures And Fs Structures Therefor (AREA)

Abstract

本申请涉及一种文件***管理方法、装置和存储介质。该方法包括:响应于数据同步请求,获取目标文件***和源文件***的信息;根据目标文件***和源文件***的信息,将源文件***中的数据全量或增量同步至目标文件***;其中,目标文件***和源文件***通过树状结构进行连接,目标文件***或源文件***为通过克隆操作创建的文件***。根据本申请实施例,能够实现在基于树状结构创建的级联的克隆文件***中,不同版本的文件***之间的数据能够灵活、简便的同步,可以控制树状结构中级联的深度,且消除了新创建克隆文件***带来的代价,在节省了存储空间的同时,还可以提升整个文件***的管理效率。

Description

文件***管理方法、装置和存储介质
技术领域
本申请涉及文件***快照嫁接技术领域,尤其涉及一种文件***管理方法、装置和存储介质。
背景技术
随着当前数据增长,对数据进行挖掘以最大化发挥数据的价值成为趋势,例如在测试、人工智能(artificial intelligence,AI)模型训练、数据挖掘等场景中,通常需要数据能够在多个版本及版本间进行简便快速流动。文件***克隆特性可以满足数据快速复制、部署的要求,同时对数据进行保护。文件***克隆特性是基于快照对源文件***的复制与数据保护技术。该特性产生的克隆文件***类似于一个文件***快照,与源文件***共享源数据,可以瞬时生成某一时间点的多个可用副本。与只读快照不同,克隆文件***可以共享给应用服务器进行读写。通过***克隆文件***,可以实现数据全量拷贝,成为独立完整的物理数据副本。
然而,在当前的文件***应用中,通常是在每次在应用时重新拷贝一份数据,这种方式效率低、空间浪费大。或者是创建级联的克隆文件***,然而,级联的深度会影响文件***的性能,且新创建的克隆需要进行复杂的配置后才能进行业务,代价较大。因此,亟需新型的方法以提升文件***的管理效率,节省存储空间,使得数据在文件***中的流动更加灵活。
发明内容
有鉴于此,提出了一种文件***管理方法、装置和存储介质。
第一方面,本申请的实施例提供了一种文件***管理方法。该方法包括:
响应于数据同步请求,获取目标文件***和源文件***的信息;
根据目标文件***和源文件***的信息,将源文件***中的数据全量或增量同步至目标文件***;
其中,目标文件***和源文件***通过树状结构进行连接,目标文件***或源文件***为通过克隆操作创建的文件***。
根据本申请实施例,能够实现在基于树状结构创建的级联的克隆文件***中,响应于数据同步请求,实现各个节点之间数据的增量或全量同步,使得数据能够在各个节点之间灵活流动。从而,通过使得不同版本的文件***之间的数据能够简便的同步,可以控制树状结构中级联的深度,且消除了新创建克隆文件***带来的代价,在节省了存储空间的同时,还可以提升整个文件***的管理效率。
根据第一方面,在文件***管理方法的第一种可能的实现方式中,数据同步请求包括将源文件***中预定时刻的数据同步至目标文件***。
根据本申请实施例,通过将源文件***中预定时刻的数据同步至目标文件***,可以实现目标文件***的数据同步至某一时刻,从而实现与源文件***间数据的流动,满足相应的业务需求。
根据第一方面或第一方面的第一种可能的实现方式,在文件***管理方法的第二种可能的实现方式中,数据同步请求包括将源文件***中预定时刻后的数据修改同步至目标文件***。
根据本申请实施例,通过将源文件***中预定时刻后的数据修改同步至目标文件***,可以使得文件***间数据的流动更加灵活,在相应的业务场景之下,无需增加级联的深度,即可基于同步了数据修改后的目标文件***继续进行相应业务操作,简化了业务流程,提高了效率。
根据第一方面的第一种或第二种可能的实现方式,在文件***管理方法的第三种可能的实现方式中,预定时刻包括目标文件***中的数据和源文件***中的数据开始存在区别的时刻。
根据本申请实施例,可以使目标文件***中的数据和源文件***中的数据能够最大化的进行同步,以满足相应的业务需求。
根据第一方面的第一种或第二种可能的实现方式,在文件***管理方法的第四种可能的实现方式中,源文件***为目标文件***在树状结构中的上一级或多级文件***,预定时刻包括源文件***通过克隆操作创建下一级文件***的时刻。
根据本申请实施例,通过将源文件***中,通过克隆操作创建下一级文件***时的数据同步至目标文件***,可以使得目标文件***的数据能够回退至预定时刻,从而在数据灵活流动的同时,在相应的业务场景之下,无需增加级联的深度,即可基于回退后的目标文件***继续进行相应业务操作,简化了业务流程,提高了效率。
根据第一方面或第一方面的第一种或第二种或第三种或第四种可能的实现方式,在文件***管理方法的第五种可能的实现方式中,目标文件***和源文件***的信息,包括以下中的一项或多项:
引用的上一级文件***的信息、指示创建时刻的第一标识、指示当前时刻的第二标识。
根据本申请实施例,通过在文件***的信息中包括引用的上一级文件***的信息、指示创建时刻的第一标识、指示当前时刻的第二标识,可以响应于数据同步请求,实现文件***之间的数据灵活同步,从而可以减少管理代价,提升对文件***的管理效率。
根据第一方面的第五种可能的实现方式,在文件***管理方法的第六种可能的实现方式中,文件***对应的第一标识根据文件***的上一级文件***在通过克隆操作创建文件***时对应的第二标识确定。
根据本申请实施例,可以更加准确地记录文件***中的数据变化,以方便文件***之间的数据同步。
根据第一方面的第五种或第六种可能的实现方式,在文件***管理方法的第七种可能的实现方式中,根据目标文件***和源文件***的信息,将源文件***中的数据全量或增量同步至目标文件***,包括:
根据目标文件***和/或源文件***分别对应的引用的上一级文件***的信息,确定指示预定时刻的第三标识;
将源文件***中目标文件***在第三标识之后修改的数据写入目标文件***。
根据本申请实施例,通过确定指示预定时刻的第三标识,并将源文件***中目标文件***在第三标识之后修改的数据写入目标文件***,可以使目标文件***中的数据回退至与源文件***中的数据开始产生区别的时刻,从而可以更好的实现文件***之间数据的同步,满足不同版本间数据简便快速流动的需求。
根据第一方面的第七种可能的实现方式,在文件***管理方法的第八种可能的实现方式中,根据目标文件***和/或源文件***分别对应的引用的上一级文件***的信息,确定指示预定时刻的第三标识,包括以下中的至少一种:
在根据目标文件***对应的引用的上一级文件***的信息,确定源文件***为所述目标文件***的上一级文件***的情况下,以目标文件***对应的第一标识作为第三标识;
在根据目标文件***对应的引用的上一级文件***的信息,确定源文件***为目标文件***的上两级或两级以上文件***的情况下,以源文件***的下一级文件***对应的第一标识作为第三标识;
在根据源文件***对应的引用的上一级文件***的信息,确定目标文件***为源文件***的上一级文件***的情况下,以源文件***对应的第一标识作为第三标识;
在根据源文件***对应的引用的上一级文件***的信息,确定目标文件***为源文件***的上两级或两级以上文件***的情况下,以目标文件***的下一级文件***对应的第一标识作为第三标识;
在根据源文件***和目标文件***分别对应的引用的上一级文件***的信息,确定源文件***和目标文件***存在共同的根节点对应的文件***的情况下,根据根节点对应的文件***的下一级文件***对应的第一标识,确定第三标识。
根据本申请实施例,通过在不同的情况下,分别确定第三标识,可以使树状结构中任意两个文件***之间的数据能够灵活同步,以满足相应业务的需求。
根据第一方面的第七种或第八种可能的实现方式,在文件***管理方法的第九种可能的实现方式中,在数据同步请求为将源文件***中预定时刻后的数据修改同步至目标文件***的情况下,根据目标文件***和源文件***的信息,将源文件***中的数据全量或增量同步至目标文件***,还包括:
将源文件***中在第三标识后修改的数据写入目标文件***。
根据本申请实施例,通过将源文件***中在第三标识之后修改的数据写入目标文件***,可以在增量同步的情况下,完成文件***之间数据修改的同步,从而可以满足不同版本间数据简便快速流动的需求。
根据第一方面的第七种或第八种或第九种可能的实现方式,在文件***管理方法的第十种可能的实现方式中,根据目标文件***和源文件***的信息,将源文件***中的数据全量同步至目标文件***,还包括:
将源文件***中在第三标识及第三标识前的数据写入目标文件***;
该方法还包括:
断开目标文件***和目标文件***在树状结构中的上一级文件***之间的连接关系。
根据本申请实施例,通过将源文件***中在第三标识及第三标识前的数据写入目标文件***,可以完成文件***之间数据的全量同步,通过断开目标文件***与目标文件***在树状结构中的上一级文件***之间的连接关系,可以在全量同步后使得目标文件***成为独立的非克隆普通文件***,由此可以控制树状结构中级联的深度,消除了新创建克隆文件***带来的配置代价,可以提升文件***的管理效率。
根据第一方面的第十种可能的实现方式,在文件***管理方法的第十一种可能的实现方式中,断开目标文件***和目标文件***在树状结构中的上一级文件***之间的连接关系,包括:
将目标文件***对应的第一标识和引用的上一级文件***的信息置为空。
根据本申请实施例,通过将目标文件***对应的引用的上一级文件***的信息和第一标识置为空,可以实现在全量同步的场景中,断开目标文件***与目标文件***在树状结构中的上一级文件***之间的连接关系,使得目标文件***成为独立的非克隆普通文件***,由此可以控制树状结构中级联的深度,消除了新创建克隆文件***带来的配置代价。
第二方面,本申请的实施例提供了一种文件***管理装置。该装置包括:
获取模块,用于响应于数据同步请求,获取目标文件***和源文件***的信息;
数据同步模块,用于根据目标文件***和源文件***的信息,将源文件***中的数据全量或增量同步至目标文件***;
其中,目标文件***和源文件***通过树状结构进行连接,目标文件***或源文件***为通过克隆操作创建的文件***。
根据第二方面,在文件***管理装置的第一种可能的实现方式中,数据同步请求包括将源文件***中预定时刻的数据同步至目标文件***。
根据第二方面或第二方面的第一种可能的实现方式,在文件***管理装置的第二种可能的实现方式中,数据同步请求包括将源文件***中预定时刻后的数据修改同步至目标文件***。
根据第二方面的第一种或第二种可能的实现方式,在文件***管理装置的第三种可能的实现方式中,预定时刻包括目标文件***中的数据和源文件***中的数据开始存在区别的时刻。
根据第二方面的第一种或第二种可能的实现方式,在文件***管理装置的第四种可能的实现方式中,源文件***为目标文件***在树状结构中的上一级或多级文件***,预定时刻包括源文件***通过克隆操作创建下一级文件***的时刻。
根据第二方面或第二方面的第一种或第二种或第三种或第四种可能的实现方式,在文件***管理装置的第五种可能的实现方式中,目标文件***和源文件***的信息,包括以下中的一项或多项:
引用的上一级文件***的信息、指示创建时刻的第一标识、指示当前时刻的第二标识。
根据第二方面的第五种可能的实现方式,在文件***管理装置的第六种可能的实现方式中,文件***对应的第一标识根据文件***的上一级文件***在通过克隆操作创建文件***时对应的第二标识确定。
根据第二方面的第五种或第六种可能的实现方式,在文件***管理装置的第七种可能的实现方式中,该数据同步模块,用于:
根据目标文件***和/或源文件***分别对应的引用的上一级文件***的信息,确定指示预定时刻的第三标识;
将源文件***中目标文件***在第三标识之后修改的数据写入目标文件***。
根据第二方面的第七种可能的实现方式,在文件***管理装置的第八种可能的实现方式中,根据目标文件***和/或源文件***分别对应的引用的上一级文件***的信息,确定指示预定时刻的第三标识,包括以下中的至少一种:
在根据目标文件***对应的引用的上一级文件***的信息,确定源文件***为所述目标文件***的上一级文件***的情况下,以目标文件***对应的第一标识作为第三标识;
在根据目标文件***对应的引用的上一级文件***的信息,确定源文件***为目标文件***的上两级或两级以上文件***的情况下,以源文件***的下一级文件***对应的第一标识作为第三标识;
在根据源文件***对应的引用的上一级文件***的信息,确定目标文件***为源文件***的上一级文件***的情况下,以源文件***对应的第一标识作为第三标识;
在根据源文件***对应的引用的上一级文件***的信息,确定目标文件***为源文件***的上两级或两级以上文件***的情况下,以目标文件***的下一级文件***对应的第一标识作为第三标识;
在根据源文件***和目标文件***分别对应的引用的上一级文件***的信息,确定源文件***和目标文件***存在共同的根节点对应的文件***的情况下,根据根节点对应的文件***的下一级文件***对应的第一标识,确定第三标识。
根据第二方面的第七种或第八种可能的实现方式,在文件***管理装置的第九种可能的实现方式中,在数据同步请求为将源文件***中预定时刻后的数据修改同步至目标文件***的情况下,该数据同步模块,还用于:
将源文件***中在第三标识后修改的数据写入目标文件***。
根据第二方面的第七种或第八种或第九种可能的实现方式,在文件***管理装置的第十种可能的实现方式中,该数据同步模块,还用于:
将源文件***中在第三标识及第三标识前的数据写入目标文件***;
该装置还包括:
断开模块,用于断开目标文件***和目标文件***在树状结构中的上一级文件***之间的连接关系。
根据第二方面的第十种可能的实现方式,在文件***管理装置的第十一种可能的实现方式中,该断开模块,用于:
将目标文件***对应的第一标识和引用的上一级文件***的信息置为空。
第三方面,本申请的实施例提供了一种文件***管理装置,该装置包括:处理器;用于存储处理器可执行指令的存储器;其中,处理器被配置为执行指令时实现上述第一方面或者第一方面的多种可能的实现方式中的一种或几种的文件***管理方法。
第四方面,本申请的实施例提供了一种非易失性计算机可读存储介质,其上存储有计算机程序指令,计算机程序指令被处理器执行时实现上述第一方面或者第一方面的多种可能的实现方式中的一种或几种的文件***管理方法。
第五方面,本申请的实施例提供了一种终端设备,该终端设备可以执行上述第一方面或者第一方面的多种可能的实现方式中的一种或几种的文件***管理方法。
第六方面,本申请的实施例提供了一种计算机程序产品,包括计算机可读代码,或者承载有计算机可读代码的非易失性计算机可读存储介质,当所述计算机可读代码在电子设备中运行时,所述电子设备中的处理器执行上述第一方面或者第一方面的多种可能的实现方式中的一种或几种的文件***管理方法。
本申请的这些和其他方面在以下(多个)实施例的描述中会更加简明易懂。
附图说明
包含在说明书中并且构成说明书的一部分的附图与说明书一起示出了本申请的示例性实施例、特征和方面,并且用于解释本申请的原理。
图1示出根据本申请一实施例的应用场景的示意图。
图2示出根据本申请一实施例的文件***管理方法的流程图。
图3示出根据本申请一实施例的文件***的数据布局的示意图。
图4示出根据本申请一实施例的对文件***中的数据进行处理的示意图。
图5示出根据本申请一实施例的文件***的信息的示意图。
图6示出根据本申请一实施例的文件***管理方法的流程图。
图7示出根据本申请一实施例的文件***之间进行数据同步的示意图。
图8示出根据本申请一实施例的文件***之间进行数据同步的示意图。
图9示出根据本申请一实施例的文件***之间进行数据同步的示意图。
图10示出根据本申请一实施例的文件***之间进行数据同步的示意图。
图11示出根据本申请一实施例的文件***之间进行数据同步的示意图。
图12示出根据本申请一实施例的文件***管理装置的结构图。
图13示出根据本申请一实施例的电子设备1300的结构图。
具体实施方式
以下将参考附图详细说明本申请的各种示例性实施例、特征和方面。附图中相同的附图标记表示功能相同或相似的元件。尽管在附图中示出了实施例的各种方面,但是除非特别指出,不必按比例绘制附图。
在这里专用的词“示例性”意为“用作例子、实施例或说明性”。这里作为“示例性”所说明的任何实施例不必解释为优于或好于其它实施例。
另外,为了更好的说明本申请,在下文的具体实施方式中给出了众多的具体细节。本领域技术人员应当理解,没有某些具体细节,本申请同样可以实施。在一些实例中,对于本领域技术人员熟知的方法、手段、元件和电路未作详细描述,以便于凸显本申请的主旨。
随着当前数据增长,对数据进行挖掘以最大化发挥数据的价值成为趋势,例如在测试、AI模型训练、数据挖掘等场景中,通常需要数据能够在多个版本及版本间进行简便快速流动。文件***克隆特性可以满足数据快速复制、部署的要求,同时对数据进行保护。文件***克隆特性是基于快照对源文件***的复制与数据保护技术。该特性产生的克隆文件***类似于一个文件***快照,与源文件***共享源数据,可以瞬时生成某一时间点的多个可用副本。与只读快照不同,克隆文件***可以共享给应用服务器进行读写。通过***克隆文件***,可以实现数据全量拷贝,成为独立完整的物理数据副本。
然而,在当前的文件***应用中,通常是在每次在应用时重新拷贝一份数据,这种方式效率低、空间浪费大。或者是创建级联的克隆文件***,然而,级联的深度会影响文件***的性能,且新创建的克隆需要进行复杂的配置(如创建共享权限、重新挂载)后才能进行业务,代价较大。因此,亟需新型的方法以提升文件***的管理效率,节省存储空间,使得数据在文件***中的流动更加灵活。
为了解决上述技术问题,本申请提供了一种文件***管理方法,本申请实施例的文件***管理方法能够实现在基于树状结构创建的级联的克隆文件***中,响应于数据同步请求,实现各个节点之间数据的增量或全量同步,使得数据能够在各个节点之间灵活流动。从而,通过使得不同版本的文件***之间的数据能够简便的同步,可以控制树状结构中级联的深度,且消除了新创建克隆文件***带来的代价,在节省了存储空间的同时,还可以提升整个文件***的管理效率。
图1示出根据本申请一实施例的应用场景的示意图。如图1所示,本申请实施例的文件***管理方法可用于树状结构的文件管理***1000。文件管理***1000可以包括树状结构的根节点对应的文件***1100(可以称为祖先文件***),以及通过对祖先文件***1100进行克隆操作得到的各级克隆文件***。其中,以文件***1100为父文件***进行克隆操作可以创建文件***1100的子文件***,例如包括文件***1110和文件***1120;该克隆操作还可以包括级联克隆操作(即对父文件***创建克隆,再对父文件***的克隆文件***创建克隆),从而可以创建级联的克隆文件***,例如包括文件***1111和文件***1112(为文件***1110的子文件***)和文件***1121和文件***1122(为文件***1120的子文件***)。
其中,子文件***可以认为是父文件***在某个时间点的创建的可读写副本,子文件***与父文件***中在该时间点及该时间点之前的数据具有一致性。在树状结构的文件管理***1000中可以通过使子文件***以引用父文件***数据的方式,达到文件***之间的连接。文件管理***1000中的各文件***可以用于AI模型训练、数据挖掘等场景。例如,在AI模型训练的场景中,若需要针对同一源数据利用不同的训练模型进行训练,根据本申请实施例的方法,由于文件***1121和文件***1122为基于同一文件***1120创建的克隆文件***,可以基于文件***1121和文件***1122分别使用不同的训练模型,得到不同的目标结果数据。若需要以目标结果数据作为新的数据源,以进行后续训练,根据本申请实施例的方法,可以通过将目标结果数据同步至树状结构中的其他任意文件***,从而可以在其他文件***的基础上进行后续训练,从而无需以目标结果数据作为父文件***继续创建一个或多个新的子文件***,由此能够控制住级联的深度。
需要说明的是,图1中仅以3级的级联文件***为例进行示意,实际上文件管理***1000还可以包括更多(如8级)或更少的级数的文件***。图1中示出的文件***仅作为示例,文件***也可以以文件、目录等进行替换。也就是说,本申请实施例的方法还可适用于对文件***中的文件、或是目录等进行管理,本申请对此不作限制。
上述文件管理***1000可以部署于存储器,该存储器可以是独立的,也可以作为服务器或终端设备中的存储模块,本申请对此不作限制。
本申请涉及的服务器可以位于云端或本地,可以是实体设备,也可以是虚拟设备,如虚拟机、容器等,具有无线通信功能,其中,无线通信功能可设置于该服务器的芯片(***)或其他部件或组件。可以是指具有无线连接功能的设备,无线连接的功能是指可以通过Wi-Fi、蓝牙等无线连接方式与其他服务器或终端设备进行连接,本申请的服务器也可以具有有线连接进行通信的功能。
本申请涉及的终端设备可以是指具有无线连接功能的设备,无线连接的功能是指可以通过Wi-Fi、蓝牙等无线连接方式与其他终端设备或服务器进行连接,本申请的终端设备也可以具有有线连接进行通信的功能。本申请的终端设备可以是触屏的、也可以是非触屏的、也可以是没有屏幕的,触屏的可以通过手指、触控笔等在显示屏幕上点击、滑动等方式对终端设备进行控制,非触屏的设备可以连接鼠标、键盘、触控面板等输入设备,通过输入设备对终端设备进行控制,没有屏幕的设备比如说可以是没有屏幕的蓝牙音箱等。举例来说,本申请的终端设备可以是智能手机、上网本、平板电脑、笔记本电脑、可穿戴电子设备(如智能手环、智能手表等)、TV、虚拟现实设备、音响、电子墨水,等等。
需要说明的是,本申请实施例中的文件管理***1000还可用于其他场景,如应用测试与数据分析、容灾演练和信息技术(information technology,IT)运维等,本申请对此不作限制。
以下通过图2-图11,对本申请实施例的文件***管理方法进行详细的介绍。
图2示出根据本申请一实施例的文件***管理方法的流程图。该方法可用于上述文件管理***1000,如图2所示,该方法包括:
步骤S201,响应于数据同步请求,获取目标文件***和源文件***的信息。
其中,目标文件***和源文件***可以通过树状结构进行连接,目标文件***或源文件***为通过克隆操作创建的文件***。该树状结构可参见图1所示,目标文件***和源文件***可以是文件管理***1000中的任意文件***。
目标文件***的信息和源文件***的信息可以包括目标文件***和源文件***的数据信息、与树状结构内其他文件***的连接关系信息等。
其中,数据信息可以包括文件***的标识、文件大小、以及数据在磁盘中的存储位置等信息。参见图3,示出根据本申请一实施例的文件***的数据布局的示意图。如图3所示,以文件***1100为例,可包括根节点“/”、目录1(如图中dir1)对应的数据、文件1(如图中file1)对应的数据、文件8(如图中file8)对应的数据、目录2(如图中dir2)对应的数据、文件2(如图中file2)对应的数据、文件3(如图中file3)对应的数据和文件4(如图中file4)对应的数据。其中,file1和file8可包括在dir1内,file2和file3可包括在dir2内,上述各个数据的连接关系可参见图中连线所示。
同样以其中的文件***1100为例,可以采用对文件***1100打快照的方式,通过获取文件***1100在打快照的时刻存储的所有数据,实现克隆操作(包括级联克隆操作),得到文件***1100的克隆子文件***(如文件***1110)。例如,若在打快照的时刻,文件***1100的数据信息包括dir1、file1、dir2、file2、file3、file4对应的数据,则在该时刻通过克隆操作得到的文件***1110的数据信息可包括dir1、file1、dir2、file2、file3、file4对应的数据,该文件***1110可以通过在数据信息中引用文件***1100的数据信息中dir1、file1、dir2、file2、file3、file4对应的数据,以建立与文件***1100之间的连接关系(即以文件***1100为父文件***、文件***1110为子文件***的连接关系)。
通过克隆操作建立文件***1120与图1所示的树状结构的其他文件***的方式与上述同理。
在创建文件***后,还可以对文件***中的数据进行处理,对文件***的数据进行处理的方式可以包括删除、添加、对内容进行修改等。其中,在文件***中的数据为引用上一级文件***(即父文件***)中的数据的情况下,对文件***的数据进行删除可以通过断开对父文件***中该数据的引用实现。
参见图4,示出根据本申请一实施例的对文件***中的数据进行处理的示意图。图4中的数据布局可以对应于通过克隆操作的文件***1120,在创建文件***1120时,其数据信息中可包括dir1、file1、dir2、file2、file3、file4对应的数据,如图4所示,以文件***1120为例,对数据的处理包括:删除file1(如图中以横线划去file1)、添加file5和修改file3的内容(修改后的file3如图中file3’所示)。
参见上述介绍,由于根据同一父文件***创建各个子文件***的创建时间可以不同,且在创建各子文件***后,父文件***和各子文件***还可以分别对数据进行处理,从而使得文件***中的数据可以分化的非常多样和复杂。通过本申请实施例的方法,可以在创建文件***之后,使得文件***中的数据能够在各个文件***之间进行同步,从而使文件***中的数据流动更加灵活,以满足不同业务场景的需要,以下对数据同步请求的不同情形作详细的介绍。
可选地,该数据同步请求可包括将源文件***中预定时刻的数据同步至目标文件***。
其中,上述预定时刻可以包括目标文件***中的数据和源文件***中的数据开始存在区别的时刻。从而,可以使目标文件***中的数据和源文件***中的数据能够最大化的进行同步,以满足相应的业务需求。源文件***中预定时刻的数据可以是源文件***在预定时刻下包括的数据。
根据本申请实施例,通过将源文件***中预定时刻的数据同步至目标文件***,可以实现目标文件***的数据同步至某一时刻,从而实现与源文件***间数据的流动,满足相应的业务需求。
可选地,该源文件***可以是目标文件***在树状结构中的上一级或多级文件***,该预定时刻包括源文件***通过克隆操作创建下一级文件***的时刻。
以图1为例,在三级的树状结构中,在源文件***为文件***1100的情况下,目标文件***可以是文件***1100的下一级文件***1110或文件***1120,也可以是文件***1110的下一级文件***1111或文件***1112,或者是文件***1120的下一级文件***1121或文件***1122。如果在大于三级的树状结构中,目标文件***还可以是源文件***的下n级的文件***,其中n为[1,N]中的正整数,N可以根据树状结构的级数确定。
在源文件***为文件***1100且目标文件***为文件***1120的情况下,由于文件***1100与文件***1120开始存在区别的时刻可以是文件***1100通过克隆操作创建文件***1120的时刻,因此,在这种情况下,对应源文件***通过克隆操作创建下一级文件***的时刻可以是文件***1100创建文件***1120的时刻。从而,可以根据该预定时刻将文件***1100中的数据同步至文件***1120,使得文件***1120中的数据与文件***1120创建时的数据一致。这种场景下相当于实现在文件***1120中进行数据回退。
在源文件***为文件***1100且目标文件***为文件***1121的情况下,由于文件***1100与文件***1121开始存在区别的时刻可以是文件***1100通过克隆操作创建文件***1120的时刻,因此,在这种情况下,对应源文件***通过克隆操作创建下一级文件***的时刻可以是文件***1100创建文件***1120的时刻。从而,可以根据该预定时刻将文件***1100中的数据同步至文件***1121,使得文件***1121中的数据与文件***1120创建时的数据一致。这种场景下相当于实现文件***1121进行数据跨级回退。
根据本申请实施例,通过将源文件***中,通过克隆操作创建下一级文件***时的数据同步至目标文件***,可以使得目标文件***的数据能够回退至预定时刻,从而在数据灵活流动的同时,在相应的业务场景之下,无需增加级联的深度,即可基于回退后的目标文件***继续进行相应业务操作,简化了业务流程,提高了效率。
可选地,该数据同步请求可包括将源文件***中预定时刻后的数据修改同步至目标文件***。
其中,源文件***中预定时刻后的数据修改可以包括源文件***中在预定时刻至当前时刻内对数据进行的修改,在对修改进行了同步之后,目标文件***和源文件***的数据将一致。
该修改可以认为是上述图4中对数据的处理,包括对数据的删除、添加和对数据的内容进行修改等。
在同步数据修改的情况下,目标文件***和源文件***可以是树状结构中的任意文件***,可以是同级的文件***,也可以是跨级的文件***。
根据本申请实施例,通过将源文件***中预定时刻后的数据修改同步至目标文件***,可以使得文件***间数据的流动更加灵活,在相应的业务场景之下,无需增加级联的深度,即可基于同步了数据修改后的目标文件***继续进行相应业务操作,简化了业务流程,提高了效率。
步骤S202,根据目标文件***和源文件***的信息,将源文件***中的数据全量或增量同步至目标文件***。
其中,进行增量同步或全量同步可以响应于数据同步请求确定。增量同步可以理解为源文件***仅将预定时刻或预定时刻之后的数据同步至目标文件***,目标文件***中预定时刻以前的数据仍可以引用上一级文件***中数据的方式存在;全量同步可以理解为在进行增量同步时,源文件***还将预定时刻以前的数据同步至目标文件***,使得目标文件***中预定时刻以前的数据可无需以引用上一级文件***中数据的方式存在,从而在全量同步之后,目标文件***可以选择断开与上一级文件***在树状结构中的连接关系。
根据本申请实施例,能够实现在基于树状结构创建的级联的克隆文件***中,响应于数据同步请求,实现各个节点之间数据的增量或全量同步,使得数据能够在各个节点之间灵活流动。从而,通过使得不同版本的文件***之间的数据能够简便的同步,可以控制树状结构中级联的深度,且消除了新创建克隆文件***带来的代价,在节省了存储空间的同时,还可以提升整个文件***的管理效率。
以下结合步骤S201中示出的数据同步请求的不同情形,对将源文件***中的数据全量或增量同步至目标文件***的方式作详细介绍。
其中,上述预定时刻可以通过文件***的信息中的相关标识信息来指示。
可选地,目标文件***和源文件***的信息,可包括以下中的一项或多项:
引用的上一级文件***的信息、指示创建时刻的第一标识、指示当前时刻的第二标识。
这些信息可以作为上述信息中与树状结构内其他文件***的连接关系信息。其中,引用的上一级文件***的信息可以用于指示该文件***的父文件***,例如为父文件***的标识;指示创建时刻的第一标识可以是父文件***创建该文件***时,该文件***引用的数据对应的版本号;指示当前时刻的第二标识可以是该文件***当前的数据对应的版本号。
根据本申请实施例,通过在文件***的信息中包括引用的上一级文件***的信息、指示创建时刻的第一标识、指示当前时刻的第二标识,可以响应于数据同步请求,实现文件***之间的数据灵活同步,从而可以减少管理代价,提升对文件***的管理效率。
可选地,该文件***对应的第一标识可以根据文件***的上一级文件***(即父文件***)在通过克隆操作创建该文件***时对应的第二标识确定。该文件***对应的第二标识在创建时刻可以与第一标识一致,在创建了该文件***之后,若文件***对数据进行了修改,修改后的数据的版本号可以在创建时刻数据对应的版本号的基础上递增,在递增后可相应的更新第二标识,以递增后的版本号作为该文件***的新的第二标识。由此,可以更加准确地记录文件***中的数据变化,以方便文件***之间的数据同步。
除上述信息之外,文件***的信息中的数据信息还可包括文件***在创建之后的每个版本中对数据进行修改的内容。
图5示出根据本申请一实施例的文件***的信息的示意图。图中以文件***1100、文件***1110和文件***1120为例,对文件***中包括的信息进行介绍。
如图5所示,父文件***的标识可以表示上述引用的上一级文件***的信息。文件***1100对应的父文件***的标识为NULL(空)可以表示该文件***1100为树状结构中的祖先文件***,也就是说文件***1100不引用其他文件***的信息,其上一级不存在其他文件***;文件***1110和文件***1120对应的父文件***的标识为1100,可以表示文件***1110和文件***1120均为文件***1100的下一级子文件***。
文件***1100的第一标识为0可以表示文件***1100创建时的版本(version)号为0;文件***1110的第一标识为1可以表示文件***1110创建时的版本号为1,其在创建时引用了文件***1100中对应版本号为1的数据;文件***1120的第一标识为2可以表示文件***1120创建时的版本号为2,其在创建时引用了文件***1100中对应版本号为2的数据。
文件***1100的第二标识为3可以表示文件***1100当前的版本号为3,其在创建后进行了3个版本的修改;文件***1110的第二标识为2可以表示文件***1110当前的版本号为2,其在创建后进行了1个版本的修改;文件***1120的第二标识为3可以表示文件***1120当前的版本号为3,其在创建后进行了1个版本的修改。
以下通过表1-表3示出各文件***在创建之后每个版本中的修改内容。其中,ver1(对应版本号为1)、ver2(对应版本号为2)、ver3(对应版本号为3)可以分别表示不同的版本。对于文件***1100,其在创建之后每个版本中的修改内容可参见表1:
表1
版本号 ver1 ver1 ver1 ver1 ver1 ver1 ver1 ver2
数据 / dir1 dir2 file1 file2 file3 file4 file8
参见表1,文件***1100在ver1中的修改包括创建根节点目录(如图中“/”)、添加dir1、dir2、file1、file2、file3和file4,在ver2中的修改包括添加file8。
对于文件***1110,根据第一标识的指示,其在创建后引用了文件***1100中ver1对应的数据,包括dir1、dir2、file1、file2、file3和file4,在此基础上,文件***1110在创建之后每个版本中的修改内容可参见表2:
表2
参见表2,文件***1110在其ver2中的修改包括删除file4(可以通过断开对文件***1100中file4的引用实现),经过ver2的修改,文件***1110中的数据包括dir1、dir2、file1、file2和file3。
对于文件***1120,根据第一标识的指示,其在创建后引用了文件***1100中ver2对应的数据,包括dir1、dir2、file1、file2、file3、file4和file8,在此基础上,文件***1120创建之后每个版本中的修改内容可参见表3:
表3
参见表3,文件***1120在其ver3中的修改包括删除file1(可以通过断开对文件***1100中file1的引用实现)和添加file5,经过ver3的修改,文件***1120中的数据包括dir1、dir2、file2、file3、file4和file5。
以下在图5的基础上对实现数据全量或增量同步的方式作详细介绍。
图6示出根据本申请一实施例的文件***管理方法的流程图。如图6所示,在全量同步或增量同步的情况下,该步骤S202,可包括:
步骤S2021,根据目标文件***和/或源文件***分别对应的引用的上一级文件***的信息,确定指示预定时刻的第三标识。
其中,可以根据目标文件***和/或源文件***分别对应的引用的上一级文件***的信息,确定目标文件***与源文件***中的数据在开始存在区别前的最后一个版本,以该版本的版本号作为第三标识。
在数据同步请求为将源文件***中预定时刻的数据同步至目标文件***的情况下,以下通过图7-图8,对步骤S2021的过程进行说明。
源文件***可以是目标文件***的父文件***,即源文件***与目标文件***为相邻上下级的文件***,其示例可参见图7,示出根据本申请一实施例的文件***之间进行数据同步的示意图。如图7所示,源文件***为文件***1100,目标文件***为文件***1120,图中箭头指向的方向可表示数据同步的方向。
在这种情况下,预定时刻可以是文件***1100通过克隆操作创建文件***1120的时刻,相当于将目标文件***(即文件***1120)中的数据版本回退至出生时刻。可选地,该步骤S2021,可包括:
在根据目标文件***对应的引用的上一级文件***的信息,确定源文件***为目标文件***的上一级文件***的情况下,可以以目标文件***对应的第一标识作为第三标识。
例如,根据文件***1120对应的引用的上一级文件***的信息(如图中父文件***的标识)为文件***1100,可以确定源文件***与目标文件***为父子关系,则第三标识可以是文件***1120对应的第一标识,即ver2,表示文件***1100通过克隆操作创建文件***1120时(可以称为文件***1120的出生时刻)文件***1120的版本为ver2。
源文件***还可以是目标文件***的父文件***的上一级或多级文件***,即源文件***与目标文件***为跨级的文件***,其示例可参见图8,示出根据本申请一实施例的文件***之间进行数据同步的示意图。如图8所示,源文件***为文件***1100,目标文件***为文件***1121,图中箭头指向的方向可表示数据同步的方向。
在这种情况下,预定时刻可以是文件***1100通过克隆操作创建文件***1120的时刻,相当于将目标文件***(即文件***1121)中的数据版本跨级回退至文件***1120的出生时刻。可选地,该步骤S2021,可包括:
在根据目标文件***对应的引用的上一级文件***的信息,确定源文件***为目标文件***的上两级或两级以上文件***的情况下,以源文件***的下一级文件***对应的第一标识作为第三标识。
例如,可以通过目标文件***(即文件***1121)对应的引用的上一级文件***的信息,逐级向上查询,直至查询到引用的上一级文件***的信息指示源文件***(即文件***1100)时,确定此时源文件***为目标文件***的上两级或两级(此处为两级)以上文件***,则可以以源文件***的下一级文件***对应的第一标识作为第三标识。则第三标识可以是文件***1120对应的第一标识,即ver2,也即表示在ver2之后,文件***1100与文件***1121中的数据开始存在区别。
在数据同步请求为将源文件***中预定时刻后的数据修改同步至目标文件***的情况下,以下通过图7-图11,对步骤S2021的过程进行说明。
其中,在源文件***为目标文件***的父文件***的情况下,确定第三标识的过程可同图7中示意的过程;在源文件***为目标文件***的跨级文件***,即父文件***的上一级或多级文件***的情况下,确定第三标识的过程可同图8中示意的过程。
目标文件***还可以是源文件***的父文件***,即目标文件***与源文件***为相邻上下级的文件***,其示例可参见图9,示出根据本申请一实施例的文件***之间进行数据同步的示意图。如图9所示,目标文件***为文件***1100,源文件***为文件***1120,图中箭头指向的方向可表示数据同步的方向。
在这种情况下,相当于将下一级文件***中的数据修改反向同步至上一级文件***中。此时,预定时刻可以包括文件***1100与文件***1120中的数据开始存在区别的时刻。可选地,该步骤S2021,可包括:
在根据源文件***对应的引用的上一级文件***的信息,确定目标文件***为源文件***的上一级文件***的情况下,以源文件***对应的第一标识作为第三标识。
例如,根据文件***1120对应的引用的上一级文件***的信息(如图中父文件***的标识)为文件***1100,可以确定目标文件***与源文件***为父子关系,则第三标识可以是源文件***即文件***1120对应的第一标识,即ver2,表示从版本号2开始,文件***1100与文件***1120的数据开始存在区别。
目标文件***还可以是源文件***的父文件***的上一级或多级文件***,即目标文件***与源文件***为跨级的文件***,其示例可参见图10,示出根据本申请一实施例的文件***之间进行数据同步的示意图。如图10所示,目标文件***为文件***1100,源文件***为文件***1121,图中箭头指向的方向可表示数据同步的方向。
在这种情况下,相当于将下级文件***中的数据跨级修改反向同步至上级文件***中。此时,预定时刻可以包括文件***1100与文件***1121中的数据开始存在区别的时刻。可选地,该步骤S2021,可包括:
在根据源文件***对应的引用的上一级文件***的信息,确定目标文件***为源文件***的上两级或两级以上文件***的情况下,以目标文件***的下一级文件***对应的第一标识作为第三标识。
例如,可以通过源文件***(即文件***1121)对应的引用的上一级文件***的信息逐级向上查询,直至查询到引用的上一级文件***的信息指示源文件***(即文件***1100)时,确定此时目标文件***为源文件***的上两级或两级(此处为两级)以上文件***,则可以以目标文件***的下一级文件***对应的第一标识作为第三标识。则第三标识可以是文件***1120对应的第一标识,即ver2,表示从版本号2开始,文件***1100与文件***1121中的数据开始存在区别。
目标文件***和源文件***还可以是树状结构的文件***中不同子树下的文件***,其示例可参见图11,示出根据本申请一实施例的文件***之间进行数据同步的示意图。如图11所示,目标文件***为文件***1110,源文件***为文件***1121,图中箭头指向的方向可表示数据同步的方向。
在这种情况下,相当于文件***中的数据修改可以同步至任意其它文件***中。此时,预定时刻可以包括文件***1110与文件***1121中的数据开始存在区别的时刻。可选地,该步骤S2021,可包括:
在根据源文件***和目标文件***分别对应的引用的上一级文件***的信息,确定源文件***和目标文件***存在共同的根节点对应的文件***的情况下,根据根节点对应的文件***的下一级文件***对应的第一标识,确定第三标识。
例如,可以通过源文件***(即文件***1121)对应的引用的上一级文件***的信息逐级向上查询,且通过目标文件***(即文件***1110)对应的引用的上一级文件***的信息逐级向上查询,直至查询到二者引用的上一级文件***的信息指示的文件***为同一文件***(即文件***1100)时,确定源文件***和目标文件***存在共同的根节点对应的文件***(即文件***1100),则可以根据根节点对应的文件***的下一级文件***对应的第一标识,确定第三标识。此时,可以根据文件***1100的下一级文件***(包括文件***1110和文件***1120),以文件***1110和文件***1120中对应第一标识中值更小的版本号作为第三标识,即ver1(如图,为文件***1110对应的第一标识),表示从版本号1开始,文件***1110与文件***1121的数据开始存在区别。
目标文件***为文件***1121,源文件***为文件***1110的情况可参照上述,同理。
在确定了第三标识之后,可以根据第三标识在源文件***与目标文件***之间进行数据同步,参见下述,其中,在增量或全量同步的场景中,可以首先对目标文件***中第三标识后的数据进行处理。
步骤S2022,将源文件***中目标文件***在第三标识之后修改的数据写入目标文件***。
其中,可以扫描目标文件***中在第三标识后存在修改的数据,并在源文件***中读取相应的数据写入目标文件***中,作为目标文件***最新版本的修改。
以图7为例,文件***1120在ver2后对数据的修改可参见表3,即在ver3中删除file1和添加file5。则可以在文件***1100中读取file1和file5的数据并写入文件***1120,作为文件***1120的ver4的修改,其中参见表1可知,文件***1100中file1有数据,则可以直接读出file1数据并写入文件***1120中,而文件***1100中不存在file5,则可以读出全0写入文件***1120中file5的相应位置(相当于在文件***1120中删除file5)。
其中,在数据同步请求为将源文件***中预定时刻的数据同步至目标文件***的情况下,将源文件***中目标文件***在第三标识之后修改的数据写入目标文件***后,可以完成增量的同步,也就是说,目标文件***中第三标识以前的数据还是引用父文件***中数据,目标文件***与源文件***仍然通过树状结构相连接。
在数据同步请求为将源文件***中预定时刻的数据同步至目标文件***的情况下,全量同步的情况可参见后述步骤S2024及步骤S203中的叙述。
根据本申请实施例,通过确定指示预定时刻的第三标识,并将源文件***中目标文件***在第三标识之后修改的数据写入目标文件***,可以使目标文件***中的数据回退至与源文件***中的数据开始产生区别的时刻,从而可以更好的实现文件***之间数据的同步,满足不同版本间数据简便快速流动的需求。
可选地,在数据同步请求为将源文件***中预定时刻后的数据修改同步至目标文件***的情况下,除了执行上述步骤S2021-步骤S2022,参见图6,该步骤S202,还可包括:
步骤S2023,将源文件***中在第三标识后修改的数据写入目标文件***。
其中,可以在源文件***中读取第三标识后存在修改的数据并写入目标文件***中,作为目标文件***最新版本的修改。
以图7为例,文件***1100在ver2后对数据的修改可参见表1,即在ver3中添加file8。则可以在文件***1100中读取file8的数据并写入文件***1120,作为文件***1120的ver4的修改。
其中,在数据同步请求为将源文件***中预定时刻后的数据修改同步至目标文件***的情况下,将源文件***中在第三标识之后修改的数据写入目标文件***后,可以完成增量的同步,也就是说,目标文件***中第三标识以前的数据还是引用父文件***中数据,目标文件***与源文件***仍然通过树状结构相连接。
在数据同步请求为将源文件***中预定时刻后的数据修改同步至目标文件***的情况下,全量同步的情况可参见后述步骤S2024及步骤S203中的叙述。
根据本申请实施例,通过将源文件***中在第三标识之后修改的数据写入目标文件***,可以在增量同步的情况下,完成文件***之间数据修改的同步,从而可以满足不同版本间数据简便快速流动的需求。
可选地,若数据同步请求中指示目标文件***与源文件***中的同步方式为全量同步,此时源文件***可以是目标文件***在树状结构中的上一级或多级文件***,通过全量同步的方式,能够使目标文件***能够断开与上一级文件***的连接,成为独立的文件***。在此场景下,参见图6,该步骤S202,还可包括:
步骤S2024,将源文件***中在第三标识及第三标识前的数据写入目标文件***。
其中,可以在源文件***中读取第三标识及点标识前的全部数据并写入目标文件***中。如上述图7、图8所示的场景可适用全量同步的方式。
以图7为例,文件***1100在ver2及ver2前的全部数据,可参见表1中ver2及ver2前的数据修改确定,即在ver1中在文件***1100中添加“/”、dir1、dir2、file1、file2、file3,在ver2中添加file4,可知,文件***1100在ver2及ver2前的全部数据包括“/”、dir1、dir2、file1、file2、file3、file4。则可以在文件***1100中读取“/”、dir1、dir2、file1、file2、file3、file4的数据并写入文件***1120。
在此情况下,由于在步骤S2024之前,文件***1120中ver2及ver2之前的数据可以通过引用父文件***中的数据实现,通过将ver2及ver2之前的数据重新写入目标文件***,即文件***1120,则文件***1120中可以无需再引用父文件***中的数据,可以通过后续步骤断开目标文件***与其上一级文件***之间的连接,从而可以实现数据的全量同步。
返回参见图2,在全量同步的场景中,该方法还可包括:
步骤S203,断开目标文件***和目标文件***在树状结构中的上一级文件***之间的连接关系。
通过断开目标文件***和目标文件***在树状结构中的上一级文件***之间的连接关系,可以使得目标文件***成为独立的文件***,即称为非克隆的普通文件***,后续还可以以该目标文件***作为根节点对应的文件***,通过克隆操作,创建新的树状结构的克隆文件***。
根据本申请实施例,通过将源文件***中在第三标识及第三标识前的数据写入目标文件***,可以完成文件***之间数据的全量同步,通过断开目标文件***与目标文件***在树状结构中的上一级文件***之间的连接关系,可以在全量同步后使得目标文件***成为独立的非克隆普通文件***,由此可以控制树状结构中级联的深度,消除了新创建克隆文件***带来的配置代价,可以提升文件***的管理效率。
可选地,参见图6,该步骤S203,可包括:
步骤S2031,将目标文件***对应的第一标识和引用的上一级文件***的信息置为空。
例如,可以将目标文件***中父文件***的标识置为NULL,表示目标文件***不引用其他文件***的信息;且将目标文件***对应的第一标识置为0,表示目标文件***创建时的版本号为0。从而可以实现将目标文件***变为非克隆的普通文件***。
根据本申请实施例,通过将目标文件***对应的引用的上一级文件***的信息和第一标识置为空,可以实现在全量同步的场景中,断开目标文件***与目标文件***在树状结构中的上一级文件***之间的连接关系,使得目标文件***成为独立的非克隆普通文件***,由此可以控制树状结构中级联的深度,消除了新创建克隆文件***带来的配置代价。
图12示出根据本申请一实施例的文件***管理装置的结构图。如图12所示,该装置可包括:
获取模块1201,用于响应于数据同步请求,获取目标文件***和源文件***的信息。
数据同步模块1202,用于根据目标文件***和源文件***的信息,将源文件***中的数据全量或增量同步至目标文件***。
其中,目标文件***和源文件***通过树状结构进行连接,目标文件***或源文件***为通过克隆操作创建的文件***。
根据本申请实施例,能够实现在基于树状结构创建的级联的克隆文件***中,响应于数据同步请求,实现各个节点之间数据的增量或全量同步,使得数据能够在各个节点之间灵活流动。从而,通过使得不同版本的文件***之间的数据能够简便的同步,可以控制树状结构中级联的深度,且消除了新创建克隆文件***带来的代价,在节省了存储空间的同时,还可以提升整个文件***的管理效率。
可选地,数据同步请求可包括将源文件***中预定时刻的数据同步至目标文件***。
根据本申请实施例,通过将源文件***中预定时刻的数据同步至目标文件***,可以实现目标文件***的数据同步至某一时刻,从而实现与源文件***间数据的流动,满足相应的业务需求。
可选地,数据同步请求可包括将源文件***中预定时刻后的数据修改同步至目标文件***。
根据本申请实施例,通过将源文件***中预定时刻后的数据修改同步至目标文件***,可以使得文件***间数据的流动更加灵活,在相应的业务场景之下,无需增加级联的深度,即可基于同步了数据修改后的目标文件***继续进行相应业务操作,简化了业务流程,提高了效率。
可选地,预定时刻包括目标文件***中的数据和源文件***中的数据开始存在区别的时刻。
根据本申请实施例,可以使目标文件***中的数据和源文件***中的数据能够最大化的进行同步,以满足相应的业务需求。
可选地,源文件***为目标文件***在树状结构中的上一级或多级文件***,预定时刻包括源文件***通过克隆操作创建下一级文件***的时刻。
根据本申请实施例,通过将源文件***中,通过克隆操作创建下一级文件***时的数据同步至目标文件***,可以使得目标文件***的数据能够回退至预定时刻,从而在数据灵活流动的同时,在相应的业务场景之下,无需增加级联的深度,即可基于回退后的目标文件***继续进行相应业务操作,简化了业务流程,提高了效率。
可选地,目标文件***和源文件***的信息,包括以下中的一项或多项:
引用的上一级文件***的信息、指示创建时刻的第一标识、指示当前时刻的第二标识。
根据本申请实施例,通过在文件***的信息中包括引用的上一级文件***的信息、指示创建时刻的第一标识、指示当前时刻的第二标识,可以响应于数据同步请求,实现文件***之间的数据灵活同步,从而可以减少管理代价,提升对文件***的管理效率。
可选地,文件***对应的第一标识根据文件***的上一级文件***在通过克隆操作创建文件***时对应的第二标识确定。
根据本申请实施例,可以更加准确地记录文件***中的数据变化,以方便文件***之间的数据同步。
可选地,该数据同步模块1202,用于:
根据目标文件***和/或源文件***分别对应的引用的上一级文件***的信息,确定指示预定时刻的第三标识;
将源文件***中目标文件***在第三标识之后修改的数据写入目标文件***。
根据本申请实施例,通过确定指示预定时刻的第三标识,并将源文件***中目标文件***在第三标识之后修改的数据写入目标文件***,可以使目标文件***中的数据回退至与源文件***中的数据开始产生区别的时刻,从而可以更好的实现文件***之间数据的同步,满足不同版本间数据简便快速流动的需求。
可选地,根据目标文件***和/或源文件***分别对应的引用的上一级文件***的信息,确定指示预定时刻的第三标识,包括以下中的至少一种:
在根据目标文件***对应的引用的上一级文件***的信息,确定源文件***为所述目标文件***的上一级文件***的情况下,以目标文件***对应的第一标识作为第三标识;
在根据目标文件***对应的引用的上一级文件***的信息,确定源文件***为目标文件***的上两级或两级以上文件***的情况下,以源文件***的下一级文件***对应的第一标识作为第三标识;
在根据源文件***对应的引用的上一级文件***的信息,确定目标文件***为源文件***的上一级文件***的情况下,以源文件***对应的第一标识作为第三标识;
在根据源文件***对应的引用的上一级文件***的信息,确定目标文件***为源文件***的上两级或两级以上文件***的情况下,以目标文件***的下一级文件***对应的第一标识作为第三标识;
在根据源文件***和目标文件***分别对应的引用的上一级文件***的信息,确定源文件***和目标文件***存在共同的根节点对应的文件***的情况下,根据根节点对应的文件***的下一级文件***对应的第一标识,确定第三标识。
根据本申请实施例,通过在不同的情况下,分别确定第三标识,可以使树状结构中任意两个文件***之间的数据能够灵活同步,以满足相应业务的需求。
可选地,在数据同步请求为将源文件***中预定时刻后的数据修改同步至目标文件***的情况下,该数据同步模块1202,还用于:
将源文件***中在第三标识后修改的数据写入目标文件***。
根据本申请实施例,通过将源文件***中在第三标识之后修改的数据写入目标文件***,可以在增量同步的情况下,完成文件***之间数据修改的同步,从而可以满足不同版本间数据简便快速流动的需求。
可选地,该数据同步模块1202,还用于:
将源文件***中在第三标识及第三标识前的数据写入目标文件***;
该装置还包括:
断开模块,用于断开目标文件***和目标文件***在树状结构中的上一级文件***之间的连接关系。
根据本申请实施例,通过将源文件***中在第三标识及第三标识前的数据写入目标文件***,可以完成文件***之间数据的全量同步,通过断开目标文件***与目标文件***在树状结构中的上一级文件***之间的连接关系,可以在全量同步后使得目标文件***成为独立的非克隆普通文件***,由此可以控制树状结构中级联的深度,消除了新创建克隆文件***带来的配置代价,可以提升文件***的管理效率。
可选地,该断开模块,用于:
将目标文件***对应的第一标识和引用的上一级文件***的信息置为空。
根据本申请实施例,通过将目标文件***对应的引用的上一级文件***的信息和第一标识置为空,可以实现在全量同步的场景中,断开目标文件***与目标文件***在树状结构中的上一级文件***之间的连接关系,使得目标文件***成为独立的非克隆普通文件***,由此可以控制树状结构中级联的深度,消除了新创建克隆文件***带来的配置代价。
本申请的实施例提供了一种文件***管理装置,包括:处理器以及用于存储处理器可执行指令的存储器;其中,所述处理器被配置为执行所述指令时实现上述方法。
本申请的实施例提供了一种终端设备,该终端设备可以执行上述文件***管理方法。
本申请的实施例提供了一种非易失性计算机可读存储介质,其上存储有计算机程序指令,所述计算机程序指令被处理器执行时实现上述方法。
本申请的实施例提供了一种计算机程序产品,包括计算机可读代码,或者承载有计算机可读代码的非易失性计算机可读存储介质,当所述计算机可读代码在电子设备的处理器中运行时,所述电子设备中的处理器执行上述方法。
图13示出根据本申请一实施例的电子设备1300的结构图。如图13所示,该电子设备1300可以是上述文件管理***1000。该电子设备1300包括至少一个处理器1801,至少一个存储器1802、至少一个通信接口1803。此外,该电子设备还可以包括天线等通用部件,在此不再详述。
下面结合图13对电子设备1300的各个构成部件进行具体的介绍。
处理器1801可以是通用中央处理器(CPU),微处理器,特定应用集成电路(application-specificintegrated circuit,ASIC),或一个或多个用于控制以上方案程序执行的集成电路。处理器1801可以包括一个或多个处理单元,例如:处理器1801可以包括应用处理器(application processor,AP),调制解调处理器,图形处理器(graphicsprocessing unit,GPU),图像信号处理器(image signal processor,ISP),控制器,视频编解码器,数字信号处理器(digital signal processor,DSP),基带处理器,和/或神经网络处理器(neural-network processing unit,NPU)等。其中,不同的处理单元可以是独立的器件,也可以集成在一个或多个处理器中。
通信接口1803,用于与其他电子设备或通信网络通信,如以太网,无线接入网(RAN),核心网,无线局域网(Wireless Local Area Networks,WLAN)等。
存储器1802可以是只读存储器(read-only memory,ROM)或可存储静态信息和指令的其他类型的静态存储设备,随机存取存储器(random access memory,RAM)或者可存储信息和指令的其他类型的动态存储设备,也可以是电可擦可编程只读存储器(ElectricallyErasable Programmable Read-Only Memory,EEPROM)、只读光盘(CompactDisc Read-Only Memory,CD-ROM)或其他光盘存储、光碟存储(包括压缩光碟、激光碟、光碟、数字通用光碟、蓝光光碟等)、磁盘存储介质或者其他磁存储设备、或者能够用于携带或存储具有指令或数据结构形式的期望的程序代码并能够由计算机存取的任何其他介质,但不限于此。存储器可以是独立存在,通过总线与处理器相连接。存储器也可以和处理器集成在一起。该存储器可用于存储上述文件***。
其中,所述存储器1802用于存储执行以上方案的应用程序代码,并由处理器1801来控制执行。所述处理器1801用于执行所述存储器1802中存储的应用程序代码。
在上述实施例中,对各个实施例的描述都各有侧重,某个实施例中没有详述的部分,可以参见其他实施例的相关描述。
计算机可读存储介质可以是可以保持和存储由指令执行设备使用的指令的有形设备。计算机可读存储介质例如可以是――但不限于――电存储设备、磁存储设备、光存储设备、电磁存储设备、半导体存储设备或者上述的任意合适的组合。计算机可读存储介质的更具体的例子(非穷举的列表)包括:便携式计算机盘、硬盘、随机存取存储器(RandomAccess Memory,RAM)、只读存储器(Read Only Memory,ROM)、可擦式可编程只读存储器(Electrically Programmable Read-Only-Memory,EPROM或闪存)、静态随机存取存储器(Static Random-Access Memory,SRAM)、便携式压缩盘只读存储器(Compact Disc Read-Only Memory,CD-ROM)、数字多功能盘(Digital Video Disc,DVD)、记忆棒、软盘、机械编码设备、例如其上存储有指令的打孔卡或凹槽内凸起结构、以及上述的任意合适的组合。
这里所描述的计算机可读程序指令或代码可以从计算机可读存储介质下载到各个计算/处理设备,或者通过网络、例如因特网、局域网、广域网和/或无线网下载到外部计算机或外部存储设备。网络可以包括铜传输电缆、光纤传输、无线传输、路由器、防火墙、交换机、网关计算机和/或边缘服务器。每个计算/处理设备中的网络适配卡或者网络接口从网络接收计算机可读程序指令,并转发该计算机可读程序指令,以供存储在各个计算/处理设备中的计算机可读存储介质中。
用于执行本申请操作的计算机程序指令可以是汇编指令、指令集架构(Instruction Set Architecture,ISA)指令、机器指令、机器相关指令、微代码、固件指令、状态设置数据、或者以一种或多种编程语言的任意组合编写的源代码或目标代码,所述编程语言包括面向对象的编程语言—诸如Smalltalk、C++等,以及常规的过程式编程语言—诸如“C”语言或类似的编程语言。计算机可读程序指令可以完全地在用户计算机上执行、部分地在用户计算机上执行、作为一个独立的软件包执行、部分在用户计算机上部分在远程计算机上执行、或者完全在远程计算机或服务器上执行。在涉及远程计算机的情形中,远程计算机可以通过任意种类的网络—包括局域网(Local Area Network,LAN)或广域网(WideArea Network,WAN)—连接到用户计算机,或者,可以连接到外部计算机(例如利用因特网服务提供商来通过因特网连接)。在一些实施例中,通过利用计算机可读程序指令的状态信息来个性化定制电子电路,例如可编程逻辑电路、现场可编程门阵列(Field-ProgrammableGate Array,FPGA)或可编程逻辑阵列(Programmable Logic Array,PLA),该电子电路可以执行计算机可读程序指令,从而实现本申请的各个方面。
这里参照根据本申请实施例的方法、装置(***)和计算机程序产品的流程图和/或框图描述了本申请的各个方面。应当理解,流程图和/或框图的每个方框以及流程图和/或框图中各方框的组合,都可以由计算机可读程序指令实现。
这些计算机可读程序指令可以提供给通用计算机、专用计算机或其它可编程数据处理装置的处理器,从而生产出一种机器,使得这些指令在通过计算机或其它可编程数据处理装置的处理器执行时,产生了实现流程图和/或框图中的一个或多个方框中规定的功能/动作的装置。也可以把这些计算机可读程序指令存储在计算机可读存储介质中,这些指令使得计算机、可编程数据处理装置和/或其他设备以特定方式工作,从而,存储有指令的计算机可读介质则包括一个制造品,其包括实现流程图和/或框图中的一个或多个方框中规定的功能/动作的各个方面的指令。
也可以把计算机可读程序指令加载到计算机、其它可编程数据处理装置、或其它设备上,使得在计算机、其它可编程数据处理装置或其它设备上执行一系列操作步骤,以产生计算机实现的过程,从而使得在计算机、其它可编程数据处理装置、或其它设备上执行的指令实现流程图和/或框图中的一个或多个方框中规定的功能/动作。
附图中的流程图和框图显示了根据本申请的多个实施例的装置、***、方法和计算机程序产品的可能实现的体系架构、功能和操作。在这点上,流程图或框图中的每个方框可以代表一个模块、程序段或指令的一部分,所述模块、程序段或指令的一部分包含一个或多个用于实现规定的逻辑功能的可执行指令。在有些作为替换的实现中,方框中所标注的功能也可以以不同于附图中所标注的顺序发生。例如,两个连续的方框实际上可以基本并行地执行,它们有时也可以按相反的顺序执行,这依所涉及的功能而定。
也要注意的是,框图和/或流程图中的每个方框、以及框图和/或流程图中的方框的组合,可以用执行相应的功能或动作的硬件(例如电路或ASIC(Application SpecificIntegrated Circuit,专用集成电路))来实现,或者可以用硬件和软件的组合,如固件等来实现。
尽管在此结合各实施例对本发明进行了描述,然而,在实施所要求保护的本发明过程中,本领域技术人员通过查看所述附图、公开内容、以及所附权利要求书,可理解并实现所述公开实施例的其它变化。在权利要求中,“包括”(comprising)一词不排除其他组成部分或步骤,“一”或“一个”不排除多个的情况。单个处理器或其它单元可以实现权利要求中列举的若干项功能。相互不同的从属权利要求中记载了某些措施,但这并不表示这些措施不能组合起来产生良好的效果。
以上已经描述了本申请的各实施例,上述说明是示例性的,并非穷尽性的,并且也不限于所披露的各实施例。在不偏离所说明的各实施例的范围的情况下,对于本技术领域的普通技术人员来说许多修改和变更都是显而易见的。本文中所用术语的选择,旨在最好地解释各实施例的原理、实际应用或对市场中的技术的改进,或者使本技术领域的其它普通技术人员能理解本文披露的各实施例。

Claims (27)

1.一种文件***管理方法,其特征在于,所述方法包括:
响应于数据同步请求,获取目标文件***和源文件***的信息;
根据所述目标文件***和所述源文件***的信息,将所述源文件***中的数据全量或增量同步至目标文件***;
其中,所述目标文件***和所述源文件***通过树状结构进行连接,所述目标文件***或所述源文件***为通过克隆操作创建的文件***。
2.根据权利要求1所述的方法,其特征在于,所述数据同步请求包括将所述源文件***中预定时刻的数据同步至所述目标文件***。
3.根据权利要求1或2所述的方法,其特征在于,所述数据同步请求包括将源文件***中预定时刻后的数据修改同步至目标文件***。
4.根据权利要求2或3所述的方法,其特征在于,所述预定时刻包括所述目标文件***中的数据和所述源文件***中的数据开始存在区别的时刻。
5.根据权利要求2或3所述的方法,其特征在于,所述源文件***为所述目标文件***在树状结构中的上一级或多级文件***,所述预定时刻包括源文件***通过克隆操作创建下一级文件***的时刻。
6.根据权利要求1-5任一项所述的方法,其特征在于,所述目标文件***和源文件***的信息,包括以下中的一项或多项:
引用的上一级文件***的信息、指示创建时刻的第一标识、指示当前时刻的第二标识。
7.根据权利要求6的所述的方法,其特征在于,文件***对应的所述第一标识根据所述文件***的上一级文件***在通过克隆操作创建所述文件***时对应的所述第二标识确定。
8.根据权利要求6或7所述的方法,其特征在于,所述根据所述目标文件***和所述源文件***的信息,将所述源文件***中的数据全量或增量同步至目标文件***,包括:
根据所述目标文件***和/或所述源文件***分别对应的所述引用的上一级文件***的信息,确定指示所述预定时刻的第三标识;
将所述源文件***中所述目标文件***在所述第三标识之后修改的数据写入所述目标文件***。
9.根据权利要求8所述的方法,其特征在于,所述根据所述目标文件***和/或所述源文件***分别对应的所述引用的上一级文件***的信息,确定指示所述预定时刻的第三标识,包括以下中的至少一种:
在根据所述目标文件***对应的所述引用的上一级文件***的信息,确定所述源文件***为所述目标文件***的上一级文件***的情况下,以所述目标文件***对应的第一标识作为所述第三标识;
在根据所述目标文件***对应的所述引用的上一级文件***的信息,确定所述源文件***为所述目标文件***的上两级或两级以上文件***的情况下,以所述源文件***的下一级文件***对应的第一标识作为所述第三标识;
在根据所述源文件***对应的所述引用的上一级文件***的信息,确定所述目标文件***为所述源文件***的上一级文件***的情况下,以所述源文件***对应的第一标识作为所述第三标识;
在根据所述源文件***对应的所述引用的上一级文件***的信息,确定所述目标文件***为所述源文件***的上两级或两级以上文件***的情况下,以所述目标文件***的下一级文件***对应的第一标识作为所述第三标识;
在根据所述源文件***和所述目标文件***分别对应的所述引用的上一级文件***的信息,确定所述源文件***和所述目标文件***存在共同的根节点对应的文件***的情况下,根据所述根节点对应的文件***的下一级文件***对应的第一标识,确定所述第三标识。
10.根据权利要求8或9所述的方法,其特征在于,在所述数据同步请求为将源文件***中预定时刻后的数据修改同步至目标文件***的情况下,所述根据所述目标文件***和所述源文件***的信息,将所述源文件***中的数据全量或增量同步至目标文件***,还包括:
将所述源文件***中在所述第三标识后修改的数据写入所述目标文件***。
11.根据权利要求8-10任一项所述的方法,其特征在于,根据所述目标文件***和所述源文件***的信息,将所述源文件***中的数据全量同步至目标文件***,还包括:
将所述源文件***中在所述第三标识及所述第三标识前的数据写入所述目标文件***;
所述方法还包括:
断开所述目标文件***和所述目标文件***在所述树状结构中的上一级文件***之间的连接关系。
12.根据权利要求11所述的方法,其特征在于,所述断开所述目标文件***和所述目标文件***在所述树状结构中的上一级文件***之间的连接关系,包括:
将所述目标文件***对应的所述第一标识和所述引用的上一级文件***的信息置为空。
13.一种文件***管理装置,其特征在于,所述装置包括:
获取模块,用于响应于数据同步请求,获取目标文件***和源文件***的信息;
数据同步模块,用于根据所述目标文件***和所述源文件***的信息,将所述源文件***中的数据全量或增量同步至目标文件***;
其中,所述目标文件***和所述源文件***通过树状结构进行连接,所述目标文件***或所述源文件***为通过克隆操作创建的文件***。
14.根据权利要求13所述的装置,其特征在于,所述数据同步请求包括将所述源文件***中预定时刻的数据同步至所述目标文件***。
15.根据权利要求13或14所述的装置,其特征在于,所述数据同步请求包括将源文件***中预定时刻后的数据修改同步至目标文件***。
16.根据权利要求14或15所述的装置,其特征在于,所述预定时刻包括所述目标文件***中的数据和所述源文件***中的数据开始存在区别的时刻。
17.根据权利要求14或15所述的装置,其特征在于,所述源文件***为所述目标文件***在树状结构中的上一级或多级文件***,所述预定时刻包括源文件***通过克隆操作创建下一级文件***的时刻。
18.根据权利要求13-17任一项所述的装置,其特征在于,所述目标文件***和源文件***的信息,包括以下中的一项或多项:
引用的上一级文件***的信息、指示创建时刻的第一标识、指示当前时刻的第二标识。
19.根据权利要求18的所述的装置,其特征在于,文件***对应的所述第一标识根据所述文件***的上一级文件***在通过克隆操作创建所述文件***时对应的所述第二标识确定。
20.根据权利要求18或19所述的装置,其特征在于,所述数据同步模块,用于:
根据所述目标文件***和/或所述源文件***分别对应的所述引用的上一级文件***的信息,确定指示所述预定时刻的第三标识;
将所述源文件***中所述目标文件***在所述第三标识之后修改的数据写入所述目标文件***。
21.根据权利要求20所述的装置,其特征在于,所述根据所述目标文件***和/或所述源文件***分别对应的所述引用的上一级文件***的信息,确定指示所述预定时刻的第三标识,包括以下中的至少一种:
在根据所述目标文件***对应的所述引用的上一级文件***的信息,确定所述源文件***为所述目标文件***的上一级文件***的情况下,以所述目标文件***对应的第一标识作为所述第三标识;
在根据所述目标文件***对应的所述引用的上一级文件***的信息,确定所述源文件***为所述目标文件***的上两级或两级以上文件***的情况下,以所述源文件***的下一级文件***对应的第一标识作为所述第三标识;
在根据所述源文件***对应的所述引用的上一级文件***的信息,确定所述目标文件***为所述源文件***的上一级文件***的情况下,以所述源文件***对应的第一标识作为所述第三标识;
在根据所述源文件***对应的所述引用的上一级文件***的信息,确定所述目标文件***为所述源文件***的上两级或两级以上文件***的情况下,以所述目标文件***的下一级文件***对应的第一标识作为所述第三标识;
在根据所述源文件***和所述目标文件***分别对应的所述引用的上一级文件***的信息,确定所述源文件***和所述目标文件***存在共同的根节点对应的文件***的情况下,根据所述根节点对应的文件***的下一级文件***对应的第一标识,确定所述第三标识。
22.根据权利要求20或21所述的装置,其特征在于,在所述数据同步请求为将源文件***中预定时刻后的数据修改同步至目标文件***的情况下,所述数据同步模块,还用于:
将所述源文件***中在所述第三标识后修改的数据写入所述目标文件***。
23.根据权利要求20-22中任一项所述的装置,其特征在于,所述数据同步模块,还用于:
将所述源文件***中在所述第三标识及所述第三标识前的数据写入所述目标文件***;
所述装置还包括:
断开模块,用于断开所述目标文件***和所述目标文件***在所述树状结构中的上一级文件***之间的连接关系。
24.根据权利要求23所述的装置,其特征在于,所述断开模块,用于:
将所述目标文件***对应的所述第一标识和所述引用的上一级文件***的信息置为空。
25.一种文件***管理装置,其特征在于,包括:
处理器;
用于存储处理器可执行指令的存储器;
其中,所述处理器被配置为执行所述指令时实现权利要求1-12任意一项所述的方法。
26.一种非易失性计算机可读存储介质,其上存储有计算机程序指令,其特征在于,所述计算机程序指令被处理器执行时实现权利要求1-12中任意一项所述的方法。
27.一种计算机程序产品,包括计算机可读代码,或者承载有计算机可读代码的非易失性计算机可读存储介质,当所述计算机可读代码在电子设备中运行时,所述电子设备中的处理器执行权利要求1-12中任意一项所述的方法。
CN202211241709.1A 2022-10-11 2022-10-11 文件***管理方法、装置和存储介质 Pending CN117873955A (zh)

Priority Applications (2)

Application Number Priority Date Filing Date Title
CN202211241709.1A CN117873955A (zh) 2022-10-11 2022-10-11 文件***管理方法、装置和存储介质
PCT/CN2023/103850 WO2024078029A1 (zh) 2022-10-11 2023-06-29 文件***管理方法、装置和存储介质

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
CN202211241709.1A CN117873955A (zh) 2022-10-11 2022-10-11 文件***管理方法、装置和存储介质

Publications (1)

Publication Number Publication Date
CN117873955A true CN117873955A (zh) 2024-04-12

Family

ID=90593472

Family Applications (1)

Application Number Title Priority Date Filing Date
CN202211241709.1A Pending CN117873955A (zh) 2022-10-11 2022-10-11 文件***管理方法、装置和存储介质

Country Status (2)

Country Link
CN (1) CN117873955A (zh)
WO (1) WO2024078029A1 (zh)

Family Cites Families (6)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN100541441C (zh) * 2007-11-09 2009-09-16 中国科学院计算技术研究所 一种计算机文件***的快照创建、删除及修改方法
JP5775177B2 (ja) * 2011-09-14 2015-09-09 株式会社日立製作所 クローンファイル作成方法と、それを用いたファイルシステム
US10776213B2 (en) * 2017-08-31 2020-09-15 Cohesity, Inc. Restoring a database using a fully hydrated backup
CN110018989B (zh) * 2017-11-13 2021-05-18 华为技术有限公司 一种快照比对的方法和装置
EP4087212A4 (en) * 2020-01-17 2023-01-04 Huawei Technologies Co., Ltd. METHOD AND APPARATUS FOR CLONING A FILE SYSTEM
CN114175008A (zh) * 2020-02-07 2022-03-11 华为技术有限公司 快速文件快照和克隆

Also Published As

Publication number Publication date
WO2024078029A1 (zh) 2024-04-18

Similar Documents

Publication Publication Date Title
US11429305B2 (en) Performing backup operations using replicas
US11741046B2 (en) Method and apparatus for creating system disk snapshot of virtual machine
CN110569311B (zh) 一种数据库的数据同步方法、设备和计算机存储介质
KR102128139B1 (ko) 플레이스홀더에 의한 파일 관리 기법
US10055149B2 (en) Intelligent snapshot tree replication
US20170344433A1 (en) Apparatus and method for data migration
US8805849B1 (en) Enabling use of analytic functions for distributed storage system data
US8495022B1 (en) Systems and methods for synthetic backups
CN102857570A (zh) 文件的云同步方法及云存储服务器
CN111104069B (zh) 分布式存储***的多区域数据处理方法、装置及电子设备
CN104714755A (zh) 一种快照管理方法及装置
CN103473065A (zh) 一种可快速还原***盘的虚拟机创建方法
CN105094924A (zh) 镜像文件的导入方法及装置
WO2022082891A1 (zh) 大数据采集方法、***、计算机设备及其存储介质
US20220382653A1 (en) Storage restore system, storage restore method, and storage medium
CN104965835A (zh) 一种分布式文件***的文件读写方法及装置
US9063949B2 (en) Inferring a sequence of editing operations to facilitate merging versions of a shared document
CN104462290A (zh) 文件***复制方法及装置
CN112559913A (zh) 一种数据处理方法、装置、计算设备及可读存储介质
CN111176901A (zh) 一种hdfs删除文件恢复方法、终端设备及存储介质
CN117873955A (zh) 文件***管理方法、装置和存储介质
CN116383161A (zh) 一种文件同步方法、装置以及介质
CN110232047B (zh) Cad文件的时间线管理***、方法、计算机可读存储介质及计算机终端
US10242025B2 (en) Efficient differential techniques for metafiles
US10936550B2 (en) Synchronizing different representations of content

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