CN114579520B - 镜像数据处理方法、镜像数据加载方法及装置 - Google Patents
镜像数据处理方法、镜像数据加载方法及装置 Download PDFInfo
- Publication number
- CN114579520B CN114579520B CN202210214021.8A CN202210214021A CN114579520B CN 114579520 B CN114579520 B CN 114579520B CN 202210214021 A CN202210214021 A CN 202210214021A CN 114579520 B CN114579520 B CN 114579520B
- Authority
- CN
- China
- Prior art keywords
- image data
- mirror image
- index information
- file
- layer
- 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
Links
- 238000011068 loading method Methods 0.000 title claims abstract description 45
- 238000003672 processing method Methods 0.000 title claims abstract description 17
- 238000000034 method Methods 0.000 claims description 28
- 238000012545 processing Methods 0.000 claims description 16
- 238000000605 extraction Methods 0.000 claims description 3
- 238000010586 diagram Methods 0.000 description 13
- 238000004590 computer program Methods 0.000 description 11
- 238000004891 communication Methods 0.000 description 8
- 230000008569 process Effects 0.000 description 5
- 230000006837 decompression Effects 0.000 description 4
- 230000006870 function Effects 0.000 description 3
- 238000012986 modification Methods 0.000 description 3
- 230000004048 modification Effects 0.000 description 3
- 230000003287 optical effect Effects 0.000 description 3
- 230000004044 response Effects 0.000 description 3
- 238000005516 engineering process Methods 0.000 description 2
- 230000003993 interaction Effects 0.000 description 2
- 238000003491 array Methods 0.000 description 1
- 238000013473 artificial intelligence Methods 0.000 description 1
- 238000004364 calculation method Methods 0.000 description 1
- 230000001413 cellular effect Effects 0.000 description 1
- 238000010276 construction Methods 0.000 description 1
- 230000007547 defect Effects 0.000 description 1
- 238000013461 design Methods 0.000 description 1
- 239000004973 liquid crystal related substance Substances 0.000 description 1
- 238000010801 machine learning Methods 0.000 description 1
- 239000013307 optical fiber Substances 0.000 description 1
- 239000004065 semiconductor Substances 0.000 description 1
- 230000001953 sensory effect Effects 0.000 description 1
- 238000006467 substitution reaction Methods 0.000 description 1
- 230000000007 visual effect Effects 0.000 description 1
Images
Classifications
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F16/00—Information retrieval; Database structures therefor; File system structures therefor
- G06F16/10—File systems; File servers
- G06F16/13—File access structures, e.g. distributed indices
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F16/00—Information retrieval; Database structures therefor; File system structures therefor
- G06F16/10—File systems; File servers
- G06F16/14—Details of searching files based on file metadata
- G06F16/148—File search processing
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F16/00—Information retrieval; Database structures therefor; File system structures therefor
- G06F16/10—File systems; File servers
- G06F16/17—Details of further file system functions
- G06F16/172—Caching, prefetching or hoarding of files
-
- 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/45562—Creating, deleting, cloning virtual machine instances
-
- Y—GENERAL TAGGING OF NEW TECHNOLOGICAL DEVELOPMENTS; GENERAL TAGGING OF CROSS-SECTIONAL TECHNOLOGIES SPANNING OVER SEVERAL SECTIONS OF THE IPC; TECHNICAL SUBJECTS COVERED BY FORMER USPC CROSS-REFERENCE ART COLLECTIONS [XRACs] AND DIGESTS
- Y02—TECHNOLOGIES OR APPLICATIONS FOR MITIGATION OR ADAPTATION AGAINST CLIMATE CHANGE
- Y02D—CLIMATE CHANGE MITIGATION TECHNOLOGIES IN INFORMATION AND COMMUNICATION TECHNOLOGIES [ICT], I.E. INFORMATION AND COMMUNICATION TECHNOLOGIES AIMING AT THE REDUCTION OF THEIR OWN ENERGY USE
- Y02D10/00—Energy efficient computing, e.g. low power processors, power management or thermal management
Landscapes
- Engineering & Computer Science (AREA)
- Theoretical Computer Science (AREA)
- Physics & Mathematics (AREA)
- General Engineering & Computer Science (AREA)
- General Physics & Mathematics (AREA)
- Data Mining & Analysis (AREA)
- Databases & Information Systems (AREA)
- Software Systems (AREA)
- Library & Information Science (AREA)
- Information Retrieval, Db Structures And Fs Structures Therefor (AREA)
Abstract
本公开提供了一种镜像数据处理方法、镜像数据加载方法、装置、设备、存储介质以及程序产品,涉及云计算技术领域。具体实现方案为:获取原始镜像数据中的多个层文件;将多个层文件存储至文件存储器,得到与多个层文件对应的层文件索引信息;根据层文件索引信息,生成配置镜像数据;在原始镜像数据中添加与配置镜像数据对应的镜像数据索引信息,得到目标镜像数据;以及存储配置镜像数据和目标镜像数据。
Description
技术领域
本公开涉及云计算技术领域。
背景技术
随着云原生技术的大规模推广,容器在企业内部的应用范围越来越广。在实际的业务场景中,用户希望可以快速启动容器,以利用容器提供对应的服务。启动容器时需要创建容器,并向容器中加载镜像数据。当镜像数据的数据大小较大时,例如达到GB(吉字节)级别时,镜像数据的下载和解压等过程比较耗时,会导致容器的启动时间不能满足业务的诉求。
发明内容
本公开提供了一种镜像数据处理方法、镜像数据加载方法、装置、设备、存储介质以及程序产品。
根据本公开的一方面,提供了一种镜像数据处理方法,包括:获取原始镜像数据中的多个层文件;将所述多个层文件存储至文件存储器,得到与所述多个层文件对应的层文件索引信息;根据所述层文件索引信息,生成配置镜像数据;在所述原始镜像数据中添加与所述配置镜像数据对应的镜像数据索引信息,得到目标镜像数据;以及存储所述配置镜像数据和所述目标镜像数据。
根据本公开的另一方面,提供了一种镜像数据加载方法,包括:创建原始容器;确定与所述原始容器对应的目标镜像数据是否配置有镜像数据索引信息;在确定所述目标镜像数据配置有镜像数据索引信息的情况下,根据所述镜像数据索引信息,获取与所述目标镜像数据对应的配置镜像数据,其中,所述配置镜像数据包括层文件索引信息;根据所述层文件索引信息,从文件存储器中获取与所述目标镜像数据对应的层文件;以及将所述层文件加载至所述原始容器中。
根据本公开的一方面,提供了一种镜像数据处理装置,包括:提取模块,用于获取原始镜像数据中的多个层文件;第一存储模块,用于将原始镜像数据中的多个层文件存储至文件存储器,得到与所述多个层文件对应的层文件索引信息;生成模块,用于根据所述层文件索引信息,生成配置镜像数据;添加模块,用于在所述原始镜像数据中添加与所述配置镜像数据对应的镜像数据索引信息,得到目标镜像数据;以及第二存储模块,用于存储所述配置镜像数据和所述目标镜像数据。
根据本公开的另一方面,提供了一种镜像数据加载装置,包括:创建模块,用于创建原始容器;确定模块,用于确定与所述原始容器对应的目标镜像数据是否配置有镜像数据索引信息;第一获取模块,用于在确定所述目标镜像数据配置有镜像数据索引信息的情况下,根据所述镜像数据索引信息,获取与所述目标镜像数据对应的配置镜像数据,其中,所述配置镜像数据包括层文件索引信息;第二获取模块,用于根据所述层文件索引信息,从文件存储器中获取与所述目标镜像数据对应的层文件;以及加载模块,用于将所述层文件加载至所述原始容器中。
本公开的另一个方面提供了一种电子设备,包括:至少一个处理器;以及与所述至少一个处理器通信连接的存储器;其中,所述存储器存储有可被所述至少一个处理器执行的指令,所述指令被所述至少一个处理器执行,以使所述至少一个处理器能够执行本公开实施例所示的方法。
根据本公开实施例的另一方面,提供了一种存储有计算机指令的非瞬时计算机可读存储介质,其中,所述计算机指令用于使所述计算机执行本公开实施例所示的方法。
根据本公开实施例的另一方面,提供了一种计算机程序产品,包括计算机程序/指令,其特征在于,该计算机程序/指令被处理器执行时实现本公开实施例所示方法的步骤。
应当理解,本部分所描述的内容并非旨在标识本公开的实施例的关键或重要特征,也不用于限制本公开的范围。本公开的其它特征将通过以下的说明书而变得容易理解。
附图说明
附图用于更好地理解本方案,不构成对本公开的限定。其中:
图1是根据本公开实施例的镜像数据处理方法、镜像数据加载方法、装置、电子设备和存储介质的应用场景示意图;
图2示意性示出了根据本公开的实施例的镜像数据处理方法的流程图;
图3示意性示出了根据本公开的实施例的镜像数据加载方法示意图;
图4示意性示出了根据本公开的实施例的将原始镜像数据中的多个层文件存储至文件存储器的方法示意图;
图5示意性示出了根据本公开的实施例的生成配置镜像数据的方法示意图;
图6示意性示出了根据本公开另一实施例的镜像数据处理的示意图;
图7示意性示出了根据本公开另一实施例的镜像数据加载的示意图;
图8示意性示出了根据本公开实施例的镜像数据处理装置的框图;
图9示意性示出了根据本公开实施例的镜像数据加载装置的框图;以及
图10示意性示出了可以用来实施本公开的实施例的示例电子设备的框图。
具体实施方式
以下结合附图对本公开的示范性实施例做出说明,其中包括本公开实施例的各种细节以助于理解,应当将它们认为仅仅是示范性的。因此,本领域普通技术人员应当认识到,可以对这里描述的实施例做出各种改变和修改,而不会背离本公开的范围和精神。同样,为了清楚和简明,以下的描述中省略了对公知功能和结构的描述。
以下将结合图1对本公开提供的镜像数据处理方法、镜像数据加载方法及装置的应用场景进行描述。
图1是根据本公开实施例的镜像数据处理方法、镜像数据加载方法、装置、电子设备和存储介质的应用场景示意图。需要注意的是,图1所示仅为可以应用本公开实施例的***架构的示例,以帮助本领域技术人员理解本公开的技术内容,但并不意味着本公开实施例不可以用于其他设备、***、环境或场景。
如图1所示,该应用场景100包括容器管理平台110、镜像仓库120和文件存储器130。
根据本公开的实施例,容器管理平台110可以用于管理部署在主机上的容器化应用。容器管理平台110例如可以包括EKS(Elastic Kubernetes Service,弹性Kubernetes服务)平台。
镜像仓库120是一种存储库或存储库集合,可以用于存储容器化应用所需的镜像数据。镜像仓库120例如可以包括harbor镜像仓库。
文件存储器130可以用于存储各种文件数据,例如可以用于存储容器中的层文件。文件存储器130例如可以包括弹性块存储(Elastic Block Store,EBS)***。
根据本公开的实施例,文件存储器130和镜像仓库120可以位于容器管理平台110的远端。容器管理平台110可以通过网络与文件存储器130和镜像仓库120进行交互。
根据本公开的实施例,用户可以通过容器管理平台110上传或创建原始镜像数据,然后对该原始镜像数据进行存储。其中,该原始镜像包括多个层文件。在存储原始镜像时,可以将原始镜像数据中的多个层文件存储至文件存储器130,得到与多个层文件对应的层文件索引信息。然后基于根据层文件索引信息,生成配置镜像数据。在原始镜像数据中添加与配置镜像数据对应的镜像数据索引信息,得到目标镜像数据。将配置镜像数据和目标镜像数据存储至镜像仓库120。
根据本公开的实施例,用户可以通过容器管理平台110创建原始容器。容器管理平台110可以确定与原始容器对应的目标镜像数据是否配置有镜像数据索引信息。在确定目标镜像数据配置有镜像数据索引信息的情况下,根据镜像数据索引信息,获取与目标镜像数据对应的配置镜像数据,其中,配置镜像数据包括层文件索引信息。然后根据层文件索引信息,从文件存储器中获取与目标镜像数据对应的层文件。接着将层文件加载至原始容器中。
相关技术在向容器中加载镜像数据时,需要对镜像数据进行解压,得到镜像数据中的层文件,然后将层文件加载至容器中,解压的时间较长,导致镜像数据的加载时间较长。
根据本公开的实施例,通过将镜像数据中的层文件存储至文件存储器,在加载镜像时,可以直接从文件存储器中获取层文件,不需要解压,从而可以缩短镜像数据的加载时间。
本公开的技术方案中,所涉及的镜像数据等数据的收集、存储、使用、加工、传输、提供和公开等处理,均符合相关法律法规的规定,且不违背公序良俗。
图2示意性示出了根据本公开的实施例的镜像数据处理方法的流程图。
如图2所示,该镜像数据处理方法包括在操作S210,获取原始镜像数据中的多个层文件。
根据本公开的实施例,例如可以对原始镜像数据进行解压,得到原始镜像数据中的多个层文件。
在操作S220,将原始镜像数据中的多个层文件存储至文件存储器,得到与多个层文件对应的层文件索引信息。
根据本公开的实施例,层文件索引信息可以包括多个层文件在文件存储器中的唯一标识。层文件索引信息可以指向该多个层文件,可以根据层文件索引信息,在文件存储器中查找到该多个层文件。
示例性地,本实施例中,例如可以由文件存储器生成与多个层文件对应的哈希值,作为层文件索引信息。
然后,在操作S230,根据层文件索引信息,生成配置镜像数据。
根据本公开的实施例,例如可以生成一个包含层文件索引信息的镜像数据,作为配置镜像数据。
在操作S240,在原始镜像数据中添加与配置镜像数据对应的镜像数据索引信息,得到目标镜像数据。
根据本公开的实施例,可以为配置镜像数据设置镜像数据索引信息,该镜像数据索引信息指向该配置镜像数据。示例性地,本实施例中,镜像数据索引信息例如可以包括配置镜像数据的镜像标识。
在操作S250,存储配置镜像数据和目标镜像数据。
根据本公开的实施例,例如可以将配置镜像数据和目标镜像数据存储至镜像仓库。可以理解的是,在实际的应用场景中,也可以将配置镜像数据和目标镜像数据存储至镜像仓库之外的其他设备中,本公开对此不作具体限定。
根据本公开的实施例,通过将镜像数据中的层文件提取出来存储在文件存储器中。从而在加载镜像时,可以直接从文件存储器中获取层文件,不需要解压,可以缩短镜像的加载时间。
图3示意性示出了根据本公开的实施例的镜像数据加载方法示意图。
如图3所示,该镜像数据加载方法包括在操作S310,创建原始容器。
根据本公开的实施例,可以响应于用户的容器创建请求,创建对应于容器创建请求的容器,即原始容器。
在操作S320,确定与原始容器对应的目标镜像数据是否配置有镜像数据索引信息。在确定目标镜像数据配置有镜像数据索引信息的情况下,执行操作S330~S350。在确定目标镜像数据没有配置镜像数据索引信息的情况下,执行操作S360~S370。
根据本公开的实施例,目标镜像数据可以为待加载至原始容器中的镜像数据。镜像数据索引信息可以用于指向与目标镜像数据对应的配置镜像数据。如果目标镜像数据配置有镜像数据索引信息,则表示存在与目标镜像数据对应的配置镜像数据。
在操作S330,根据镜像数据索引信息,获取与目标镜像数据对应的配置镜像数据。
根据本公开的实施例,配置镜像数据包括层文件索引信息。层文件索引信息可以用于指向文件存储器中与目标镜像数据对应的层文件。
在操作S340,根据层文件索引信息,从文件存储器中获取与目标镜像数据对应的层文件。
在操作S350,将层文件加载至原始容器中。
根据本公开的实施例,操作S350例如包括将目标层文件和合并层文件添加至原始容器的根目录位置。
根据本公开的实施例,根据配置镜像数据中的层文件索引信息,可以直接从文件存储器中获取对应的层文件,并将层文件加载至原始容器中,不需要对数据进行解压,从而可以缩短镜像的加载时间。
在操作S360,下载目标镜像数据。
在操作S370,将目标镜像数据加载至原始容器中。
根据本公开的实施例,如果目标镜像数据没有配置镜像数据索引信息,则可以下载目标镜像数据。然后将目标镜像数据解压,得到目标镜像数据中的层文件,再将这些层文件加载至原始容器中,以完成镜像数据的加载。
根据本公开的另一实施例,由于目标镜像数据还保留了原始镜像数据中的层文件,因此可以在无法获得文件存储器中的层文件的情况下,下载该目标镜像数据,然后将目标镜像数据加载至原始容器中,从而可以提高镜像数据的加载成功率。
根据本公开的实施例,在镜像数据处理时,例如可以在原始镜像数据中添加注释字段(annotation),然后将镜像数据索引信息添加至注释字段。
对应地,根据本公开的实施例,在镜像数据加载时,例如可以读取目标镜像数据中的注释字段。然后查找注释字段中是否存在镜像数据索引信息。在注释字段中存在镜像数据索引信息的情况下,确定目标镜像数据配置有镜像数据索引信息。
根据本公开的另一实施例,在镜像数据中包含的层文件的较多的情况下,将这些层文件存储至文件存储器的过程中,会对文件存储器造成较大的存储压力。基于此,可以对镜像数据中的层文件进行合并,从而减少数据量,减低文件存储器的存储压力。
基于此,图4示意性示出了根据本公开的实施例的将原始镜像数据中的多个层文件存储至文件存储器的方法示意图。
如图4所示,该将原始镜像数据中的多个层文件存储至文件存储器方法410包括在操作S411,确定多个层文件中的目标层文件。
根据本公开的实施例,目标层文件可以根据实际需要确定。例如,可以确定多个层文件中的存储有预定数据的层文件,作为目标层文件。其中,预定数据可以根据实际需要确定。又例如,可以确定多个层文件中数据大小大于预定阈值的层文件,作为目标层文件。其中,预定阈值可以根据实际需要确定。
在操作S412,将多个层文件中除目标层文件之外的其他层文件合并,得到合并层文件。
根据本公开的实施例,例如可以将其他层文件中同名的目标合并,将其他层文件中同名文件覆盖,得到合并层文件。
示例地,本实施例中,例如可以利用OverlayFS服务执行将其他层文件合并的操作,得到合并层文件。
在操作S413,将目标层文件和合并层文件存储至文件存储器,得到目标层文件的索引信息和合并层文件的索引信息,作为层文件索引信息。
根据本公开的实施例,层文件索引信息包括目标层文件的索引信息和合并层文件的索引信息。其中,目标层文件的索引信息用于指向文件存储器中的目标层文件,合并层文件的索引信息用于指向文件存储器中的合并层文件。
根据本公开的实施例,例如可以针对目标层文件,生成唯一的文件标识,作为目标层文件的索引信息。另外可以针对合并层文件,生成唯一的文件标识,作为合并层文件的索引信息。其中,文件标识例如可以通过哈希计算得到。
对应地,根据本公开的实施例,在镜像数据加载时,例如可以通过获取与目标镜像数据对应的配置镜像数据,得到配置镜像数据包含的目标层文件的索引信息和合并层文件的索引信息。然后可以根据目标层文件的索引信息,获取文件存储器中目标层文件。根据合并层文件的索引信息,获取文件存储器中合并层文件。
图5示意性示出了根据本公开的实施例的生成配置镜像数据的方法示意图。
如图5所示,该生成配置镜像数据的方法520包括在操作S521,创建配置镜像数据。
根据本公开的实施例,配置镜像数据可以包括第一空白层文件和第二空白层文件。第一空白层文件和第二空白层文件中内容为空白,即不包含实际的数据内容。
在操作S522,将目标层文件的索引信息写入配置镜像数据中的第一空白层文件。
根据本公开的实施例,例如可以在第一空白层文件中添加注释字段,然后将目标层文件的索引信息添加至该注释字段。
在操作S523,将合并层文件的索引信息写入配置镜像数据的第二空白层文件。
根据本公开的实施例,例如可以在第二空白层文件中添加注释字段,然后将合并层文件的索引信息添加至该注释字段。
对应地,根据本公开的实施例,在镜像数据加载时,例如可以从配置镜像数据的第一空白层文件中获取目标层文件的索引信息,可以从配置镜像数据的第二空白层文件中获取合并层文件的索引信息。
下面参考图6~图7,结合具体实施例对上文所示的镜像数据处理方法和镜像数据加载方法做进一步说明。本领域技术人员可以理解,以下示例实施例仅用于理解本公开,本公开并不局限于此。
示例性地,本实施例中,原始镜像数据、配置镜像数据和目标镜像数据可以包括符合OCI(Open Container Initiative,开放容器计划)规范的镜像数据。容器例如可以包括docker容器。
图6示意性示出了根据本公开另一实施例的镜像数据处理的示意图。
在图6中示出了,用户可以发送原始镜像数据的存储请求。其中,原始镜像数据的镜像标识为a,原始镜像数据包括n个层文件layer 1~layer n,其中n为大于2的正整数。
响应于接收到该存储请求,可以获取原始镜像中的n个层文件。然后确定n个层文件中的目标层文件。示例性地,本实施例中,可以确定n个层文件中包含基础数据的层文件layer n,作为目标层文件。接着,可以将多个层文件中除layer n之外的其他层文件合并,得到合并层文件layer’。将目标层文件layer n和合并层文件layer’存储至文件存储器,得到目标层文件的索引信息flagl和合并层文件的索引信息flag2,作为层文件索引信息。
然后,创建配置镜像数据。其中,配置镜像数据的镜像标识为b,配置镜像数据包括第一空白层文件和第二空白层文件。其中,第一空白层文件对应于layer n,可以将layer n的索引信息flagl写入第一空白层文件。第二空白层文件对应于layer’,可以将layer’的索引信息flag2写入第二空白层文件。
接下来,确定配置镜像数据的镜像标识b为与配置镜像数据对应的镜像数据索引信息。基于此,可以在原始镜像数据中添加镜像标识b,得到目标镜像数据,该目标镜像数据的标识仍为a。
接着,将配置镜像数据和目标镜像数据存储至镜像仓库。
图7示意性示出了根据本公开另一实施例的镜像数据加载的示意图。
在图7中示出了,用户可以发送容器创建请求,其中,该容器创建请求用于请求创建容器,并将目标镜像数据加载至容器中。其中,目标镜像数据的镜像标识为a。
响应于接收到该容器创建请求,可以创建容器,即原始容器。然后可以通过CRI(Container Runtime Interface,容器运行时接口)plugin(插件),检测需要下载的目标镜像数据a是否配置有镜像数据索引信息。示例地,本实施例中,可以读取目标镜像数据a中的注释字段,查找注释字段中是否存在镜像数据索引信息。如果注释字段中存在镜像数据索引信息,则表示目标镜像数据a配置有镜像数据索引信息。如果注释字段中不存在镜像数据索引信息,则表示目标镜像数据a没有配置有镜像数据索引信息。
另外,在确定目标镜像数据配置有镜像数据索引信息的情况下,还可以进一步查看是否满足获取条件。其中,获取条件例如可以包括文件存储器提供的获取接口是否可用,是否使用对应于文件存储器的snapshot(快照)模块等。在获取条满足的情况下,根据镜像数据索引信息,向原始容器发送镜像下载请求。
原始容器在接受到带有镜像数据索引信息的镜像下载请求后,根据镜像数据索引信息,获取镜像数据a’,并分别处理镜像数据a’的每个层文件。例如,获取镜像数据a’的层文件layer’中的层文件索引信息,可以包含该层文件索引信息的下载请求发送到snapshot模块。
snapshot模块检测到下载请求中带有层文件索引信息,根据层文件索引信息获取到对应层文件layer’的唯一标识,调用文件存储器的获取接口,将文件存储器中的层文件layer’挂载到与原始容器对应的本地位置,例如根目录位置,并且返回数据已存在。
同样地,可以将文件存储器中的layer n也挂载到与原始容器对应的本地位置。
原始容器检测到本地位置中的层文件layer’和layer n已存在,就会跳过对目标镜像数据中层文件的下载流程,从而节省了加载时长。
图8示意性示出了根据本公开实施例的镜像数据处理装置的框图。
如图8所示,该镜像数据处理装置800包括提取模块810、第一存储模块820、生成模块830、添加模块840和第二存储模块850。
提取模块810,用于获取原始镜像数据中的多个层文件。
第一存储模块820,用于将原始镜像数据中的多个层文件存储至文件存储器,得到与多个层文件对应的层文件索引信息。
生成模块830,用于根据层文件索引信息,生成配置镜像数据;
添加模块840,用于在原始镜像数据中添加与配置镜像数据对应的镜像数据索引信息,得到目标镜像数据。
第二存储模块850,用于存储配置镜像数据和目标镜像数据。
图9示意性示出了根据本公开实施例的镜像数据加载装置的框图。
如图9所示,该镜像数据加载装置900包括创建模块910、确定模块920、第一获取模块930、第二获取模块940和加载模块950。
创建模块910,用于创建原始容器。
确定模块920,用于确定与原始容器对应的目标镜像数据是否配置有镜像数据索引信息。
第一获取模块930,用于在确定目标镜像数据配置有镜像数据索引信息的情况下,根据镜像数据索引信息,获取与目标镜像数据对应的配置镜像数据,其中,配置镜像数据包括层文件索引信息。
第二获取模块940,用于根据层文件索引信息,从文件存储器中获取与目标镜像数据对应的层文件。
加载模块950,用于将层文件加载至原始容器中。
根据本公开的实施例,本公开还提供了一种电子设备、一种可读存储介质和一种计算机程序产品。
图10示意性示出了可以用来实施本公开的实施例的示例电子设备1000的框图。电子设备旨在表示各种形式的数字计算机,诸如,膝上型计算机、台式计算机、工作台、个人数字助理、服务器、刀片式服务器、大型计算机、和其它适合的计算机。电子设备还可以表示各种形式的移动装置,诸如,个人数字处理、蜂窝电话、智能电话、可穿戴设备和其它类似的计算装置。本文所示的部件、它们的连接和关系、以及它们的功能仅仅作为示例,并且不意在限制本文中描述的和/或者要求的本公开的实现。
如图10所示,设备1000包括计算单元1001,其可以根据存储在只读存储器(ROM)1002中的计算机程序或者从存储单元1008加载到随机访问存储器(RAM)1003中的计算机程序,来执行各种适当的动作和处理。在RAM 1003中,还可存储设备1000操作所需的各种程序和数据。计算单元1001、ROM 1002以及RAM 1003通过总线1004彼此相连。输入/输出(I/O)接口1005也连接至总线1004。
设备1000中的多个部件连接至I/O接口1005,包括:输入单元1006,例如键盘、鼠标等;输出单元1007,例如各种类型的显示器、扬声器等;存储单元1008,例如磁盘、光盘等;以及通信单元1009,例如网卡、调制解调器、无线通信收发机等。通信单元1009允许设备1000通过诸如因特网的计算机网络和/或各种电信网络与其他设备交换信息/数据。
计算单元1001可以是各种具有处理和计算能力的通用和/或专用处理组件。计算单元1001的一些示例包括但不限于中央处理单元(CPU)、图形处理单元(GPU)、各种专用的人工智能(AI)计算芯片、各种运行机器学习模型算法的计算单元、数字信号处理器(DSP)、以及任何适当的处理器、控制器、微控制器等。计算单元1001执行上文所描述的各个方法和处理,例如镜像数据处理方法和镜像数据加载方法。例如,在一些实施例中,镜像数据处理方法和镜像数据加载方法可被实现为计算机软件程序,其被有形地包含于机器可读介质,例如存储单元1008。在一些实施例中,计算机程序的部分或者全部可以经由ROM 1002和/或通信单元1009而被载入和/或安装到设备1000上。当计算机程序加载到RAM 1003并由计算单元1001执行时,可以执行上文描述的镜像数据处理方法和镜像数据加载方法的一个或多个步骤。备选地,在其他实施例中,计算单元1001可以通过其他任何适当的方式(例如,借助于固件)而被配置为执行镜像数据处理方法和镜像数据加载方法。
本文中以上描述的***和技术的各种实施方式可以在数字电子电路***、集成电路***、现场可编程门阵列(FPGA)、专用集成电路(ASIC)、专用标准产品(ASSP)、芯片上***的***(SOC)、复杂可编程逻辑设备(CPLD)、计算机硬件、固件、软件、和/或它们的组合中实现。这些各种实施方式可以包括:实施在一个或者多个计算机程序中,该一个或者多个计算机程序可在包括至少一个可编程处理器的可编程***上执行和/或解释,该可编程处理器可以是专用或者通用可编程处理器,可以从存储***、至少一个输入装置、和至少一个输出装置接收数据和指令,并且将数据和指令传输至该存储***、该至少一个输入装置、和该至少一个输出装置。
用于实施本公开的方法的程序代码可以采用一个或多个编程语言的任何组合来编写。这些程序代码可以提供给通用计算机、专用计算机或其他可编程数据处理装置的处理器或控制器,使得程序代码当由处理器或控制器执行时使流程图和/或框图中所规定的功能/操作被实施。程序代码可以完全在机器上执行、部分地在机器上执行,作为独立软件包部分地在机器上执行且部分地在远程机器上执行或完全在远程机器或服务器上执行。
在本公开的上下文中,机器可读介质可以是有形的介质,其可以包含或存储以供指令执行***、装置或设备使用或与指令执行***、装置或设备结合地使用的程序。机器可读介质可以是机器可读信号介质或机器可读储存介质。机器可读介质可以包括但不限于电子的、磁性的、光学的、电磁的、红外的、或半导体***、装置或设备,或者上述内容的任何合适组合。机器可读存储介质的更具体示例会包括基于一个或多个线的电气连接、便携式计算机盘、硬盘、随机存取存储器(RAM)、只读存储器(ROM)、可擦除可编程只读存储器(EPROM或快闪存储器)、光纤、便捷式紧凑盘只读存储器(CD-ROM)、光学储存设备、磁储存设备、或上述内容的任何合适组合。
为了提供与用户的交互,可以在计算机上实施此处描述的***和技术,该计算机具有:用于向用户显示信息的显示装置(例如,CRT(阴极射线管)或者LCD(液晶显示器)监视器);以及键盘和指向装置(例如,鼠标或者轨迹球),用户可以通过该键盘和该指向装置来将输入提供给计算机。其它种类的装置还可以用于提供与用户的交互;例如,提供给用户的反馈可以是任何形式的传感反馈(例如,视觉反馈、听觉反馈、或者触觉反馈);并且可以用任何形式(包括声输入、语音输入或者、触觉输入)来接收来自用户的输入。
可以将此处描述的***和技术实施在包括后台部件的计算***(例如,作为数据服务器)、或者包括中间件部件的计算***(例如,应用服务器)、或者包括前端部件的计算***(例如,具有图形用户界面或者网络浏览器的用户计算机,用户可以通过该图形用户界面或者该网络浏览器来与此处描述的***和技术的实施方式交互)、或者包括这种后台部件、中间件部件、或者前端部件的任何组合的计算***中。可以通过任何形式或者介质的数字数据通信(例如,通信网络)来将***的部件相互连接。通信网络的示例包括:局域网(LAN)、广域网(WAN)和互联网。
计算机***可以包括客户端和服务器。客户端和服务器一般远离彼此并且通常通过通信网络进行交互。通过在相应的计算机上运行并且彼此具有客户端-服务器关系的计算机程序来产生客户端和服务器的关系。
服务器可以是云服务器,又称为云计算服务器或云主机,是云计算服务体系中的一项主机产品,以解决了传统物理主机与VPS服务(Virtual Private Server,或简称VPS)中,存在的管理难度大,业务扩展性弱的缺陷。服务器也可以为分布式***的服务器,或者是结合了区块链的服务器。
应该理解,可以使用上面所示的各种形式的流程,重新排序、增加或删除步骤。例如,本发公开中记载的各步骤可以并行地执行也可以顺序地执行也可以不同的次序执行,只要能够实现本公开公开的技术方案所期望的结果,本文在此不进行限制。
上述具体实施方式,并不构成对本公开保护范围的限制。本领域技术人员应该明白的是,根据设计要求和其他因素,可以进行各种修改、组合、子组合和替代。任何在本公开的精神和原则之内所作的修改、等同替换和改进等,均应包含在本公开保护范围之内。
Claims (11)
1.一种镜像数据处理方法,包括:
获取原始镜像数据中的多个层文件;
将所述多个层文件存储至文件存储器,得到与所述多个层文件对应的层文件索引信息;
创建配置镜像数据;
将所述层文件索引信息写入所述配置镜像数据;
在所述原始镜像数据中添加与所述配置镜像数据对应的镜像数据索引信息,得到目标镜像数据;以及
存储所述配置镜像数据和所述目标镜像数据;
其中,所述将所述多个层文件存储至文件存储器包括:
确定所述多个层文件中数据大小大于预定阈值的层文件,作为目标层文件;
将所述多个层文件中除目标层文件之外的其他层文件合并,得到合并层文件;以及
将所述目标层文件和所述合并层文件存储至所述文件存储器,得到所述目标层文件的索引信息和所述合并层文件的索引信息,作为所述层文件索引信息。
2.根据权利要求1所述的方法,其中,所述配置镜像数据包括第一空白层文件和第二空白层文件;所述将所述层文件索引信息写入所述配置镜像数据,包括:
将所述目标层文件的索引信息写入所述配置镜像数据中的第一空白层文件;以及
将所述合并层文件的索引信息写入所述配置镜像数据中的第二空白层文件。
3.根据权利要求1所述的方法,其中,所述在所述原始镜像数据中添加与所述配置镜像数据对应的镜像数据索引信息,包括:
在所述原始镜像数据中添加注释字段;以及
将所述镜像数据索引信息添加至所述注释字段。
4.一种镜像数据加载方法,包括:
创建原始容器;
确定与所述原始容器对应的目标镜像数据是否配置有镜像数据索引信息;
在确定所述目标镜像数据配置有镜像数据索引信息的情况下,根据所述镜像数据索引信息,获取与所述目标镜像数据对应的配置镜像数据,其中,所述配置镜像数据包括层文件索引信息,所述层文件索引信息包括目标层文件的索引信息和合并层文件的索引信息;
根据所述层文件索引信息,从文件存储器中获取与所述目标镜像数据对应的层文件;以及
将所述层文件加载至所述原始容器中;
其中,所述根据所述层文件索引信息,从文件存储器中获取与所述目标镜像数据对应的层文件,包括:
根据所述目标层文件的索引信息,获取文件存储器中所述目标层文件;其中,所述目标层文件是数据大小大于预定阈值的层文件;以及
根据所述合并层文件的索引信息,获取文件存储器中所述合并层文件。
5.根据权利要求4所述的方法,其中,所述确定与所述原始容器对应的目标镜像数据是否配置有镜像数据索引信息包括:
读取所述目标镜像数据中的注释字段;
查找所述注释字段中是否存在所述镜像数据索引信息;以及
在注释字段中存在所述镜像数据索引信息的情况下,确定目标镜像数据配置有所述镜像数据索引信息。
6.根据权利要求4所述的方法,其中,所述将所述层文件加载至所述原始容器中包括:
将所述目标层文件和所述合并层文件添加至所述原始容器的根目录位置。
7.根据权利要求4所述的方法,还包括:
在无法从文件存储器中获取所述层文件的情况下,下载所述目标镜像数据;以及
将所述目标镜像数据加载至所述原始容器中。
8.一种镜像数据处理装置,包括:
提取模块,用于获取原始镜像数据中的多个层文件;
第一存储模块,用于将原始镜像数据中的多个层文件存储至文件存储器,得到与所述多个层文件对应的层文件索引信息;
生成模块,用于创建配置镜像数据;将所述层文件索引信息写入所述配置镜像数据;
添加模块,用于在所述原始镜像数据中添加与所述配置镜像数据对应的镜像数据索引信息,得到目标镜像数据;以及
第二存储模块,用于存储所述配置镜像数据和所述目标镜像数据;
其中,所述第一存储模块还用于确定所述多个层文件中数据大小大于预定阈值的层文件,作为目标层文件;将所述多个层文件中除目标层文件之外的其他层文件合并,得到合并层文件;以及将所述目标层文件和所述合并层文件存储至所述文件存储器,得到所述目标层文件的索引信息和所述合并层文件的索引信息,作为所述层文件索引信息。
9.一种镜像数据加载装置,包括:
创建模块,用于创建原始容器;
确定模块,用于确定与所述原始容器对应的目标镜像数据是否配置有镜像数据索引信息;
第一获取模块,用于在确定所述目标镜像数据配置有镜像数据索引信息的情况下,根据所述镜像数据索引信息,获取与所述目标镜像数据对应的配置镜像数据,其中,所述配置镜像数据包括层文件索引信息,所述层文件索引信息包括目标层文件的索引信息和合并层文件的索引信息;
第二获取模块,用于根据所述层文件索引信息,从文件存储器中获取与所述目标镜像数据对应的层文件;以及
加载模块,用于将所述层文件加载至所述原始容器中;
其中,所述第二获取模块还用于根据所述目标层文件的索引信息,获取文件存储器中所述目标层文件;根据所述合并层文件的索引信息,获取文件存储器中所述合并层文件;所述目标层文件是数据大小大于预定阈值的层文件。
10.一种电子设备,包括:
至少一个处理器;以及
与所述至少一个处理器通信连接的存储器;其中,
所述存储器存储有可被所述至少一个处理器执行的指令,所述指令被所述至少一个处理器执行,以使所述至少一个处理器能够执行权利要求1-7中任一项所述的方法。
11.一种存储有计算机指令的非瞬时计算机可读存储介质,其中,所述计算机指令用于使所述计算机执行根据权利要求1-7中任一项所述的方法。
Priority Applications (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN202210214021.8A CN114579520B (zh) | 2022-03-04 | 2022-03-04 | 镜像数据处理方法、镜像数据加载方法及装置 |
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN202210214021.8A CN114579520B (zh) | 2022-03-04 | 2022-03-04 | 镜像数据处理方法、镜像数据加载方法及装置 |
Publications (2)
Publication Number | Publication Date |
---|---|
CN114579520A CN114579520A (zh) | 2022-06-03 |
CN114579520B true CN114579520B (zh) | 2023-05-05 |
Family
ID=81779387
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
CN202210214021.8A Active CN114579520B (zh) | 2022-03-04 | 2022-03-04 | 镜像数据处理方法、镜像数据加载方法及装置 |
Country Status (1)
Country | Link |
---|---|
CN (1) | CN114579520B (zh) |
Family Cites Families (4)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN110659100B (zh) * | 2018-06-29 | 2022-05-24 | 华为技术有限公司 | 容器管理方法、装置和设备 |
CN111324360B (zh) * | 2020-01-09 | 2022-04-01 | 华中科技大学 | 一种面向边缘计算的容器镜像构建方法和*** |
CN112671892B (zh) * | 2020-12-22 | 2022-11-18 | 北京百度网讯科技有限公司 | 数据传输方法、装置、电子设备及介质 |
CN113934510A (zh) * | 2021-10-18 | 2022-01-14 | 重庆紫光华山智安科技有限公司 | 镜像处理方法、装置、电子设备及计算机可读存储介质 |
-
2022
- 2022-03-04 CN CN202210214021.8A patent/CN114579520B/zh active Active
Also Published As
Publication number | Publication date |
---|---|
CN114579520A (zh) | 2022-06-03 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
CN108846753B (zh) | 用于处理数据的方法和装置 | |
CN113961510B (zh) | 一种文件处理方法、装置、设备及存储介质 | |
CN113378855A (zh) | 用于处理多任务的方法、相关装置及计算机程序产品 | |
CN112671892B (zh) | 数据传输方法、装置、电子设备及介质 | |
CN117289956B (zh) | 镜像制作方法、装置、电子设备和存储介质 | |
CN115934076B (zh) | 跨平台客户端的微服务提供装置、方法和电子设备 | |
CN114579520B (zh) | 镜像数据处理方法、镜像数据加载方法及装置 | |
CN112433757A (zh) | 一种确定接口调用关系的方法和装置 | |
CN113868254B (zh) | 图数据库中的实体节点去重方法、设备和存储介质 | |
CN112714163B (zh) | 数据传输方法、装置、电子设备和介质 | |
CN112540805B (zh) | 集成项目打包方法、装置、设备、存储介质以及程序产品 | |
CN113326038B (zh) | 用于提供服务的方法、装置、设备、存储介质及程序产品 | |
CN114997329A (zh) | 用于生成模型的方法、装置、设备、介质和产品 | |
CN112052347B (zh) | 图像存储方法、装置以及电子设备 | |
CN114896317A (zh) | 一种数据结构转换方法、装置、电子设备及存储介质 | |
CN112784596A (zh) | 一种识别敏感词的方法和装置 | |
CN114546522B (zh) | 应用的图片配置方法、装置、电子设备及存储介质 | |
CN112783507B (zh) | 数据引流回放方法、装置、电子设备及可读存储介质 | |
CN116363260B (zh) | 图像生成方法、装置及电子设备 | |
CN112560462B (zh) | 事件抽取服务的生成方法、装置、服务器以及介质 | |
CN114327271B (zh) | 生命周期的管理方法、装置、设备以及存储介质 | |
CN116909752B (zh) | 一种页面的镜像存储方法、装置、设备及存储介质 | |
CN114816467B (zh) | 升级文件的生成方法、装置和电子设备 | |
CN116382787A (zh) | 在页面中加载动画的方法、装置、电子设备与可读存储介质 | |
CN116708362A (zh) | 通信地址的处理方法、装置、设备及存储介质 |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
PB01 | Publication | ||
PB01 | Publication | ||
SE01 | Entry into force of request for substantive examination | ||
SE01 | Entry into force of request for substantive examination | ||
GR01 | Patent grant | ||
GR01 | Patent grant |