CN110955494B - 一种虚拟机磁盘镜像构建方法、装置、设备、介质 - Google Patents

一种虚拟机磁盘镜像构建方法、装置、设备、介质 Download PDF

Info

Publication number
CN110955494B
CN110955494B CN201911121547.6A CN201911121547A CN110955494B CN 110955494 B CN110955494 B CN 110955494B CN 201911121547 A CN201911121547 A CN 201911121547A CN 110955494 B CN110955494 B CN 110955494B
Authority
CN
China
Prior art keywords
virtual machine
target
rootfs
image
container
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
CN201911121547.6A
Other languages
English (en)
Other versions
CN110955494A (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.)
Beijing Inspur Data Technology Co Ltd
Original Assignee
Beijing Inspur Data 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 Beijing Inspur Data Technology Co Ltd filed Critical Beijing Inspur Data Technology Co Ltd
Priority to CN201911121547.6A priority Critical patent/CN110955494B/zh
Publication of CN110955494A publication Critical patent/CN110955494A/zh
Application granted granted Critical
Publication of CN110955494B publication Critical patent/CN110955494B/zh
Active legal-status Critical Current
Anticipated expiration legal-status Critical

Links

Images

Classifications

    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F9/00Arrangements for program control, e.g. control units
    • G06F9/06Arrangements 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/44Arrangements for executing specific programs
    • G06F9/455Emulation; Interpretation; Software simulation, e.g. virtualisation or emulation of application or operating system execution engines
    • G06F9/45533Hypervisors; Virtual machine monitors
    • G06F9/45558Hypervisor-specific management and integration aspects
    • 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/18File system types
    • G06F16/188Virtual file systems
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F9/00Arrangements for program control, e.g. control units
    • G06F9/06Arrangements 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/44Arrangements for executing specific programs
    • G06F9/455Emulation; Interpretation; Software simulation, e.g. virtualisation or emulation of application or operating system execution engines
    • G06F9/45533Hypervisors; Virtual machine monitors
    • G06F9/45558Hypervisor-specific management and integration aspects
    • G06F2009/45562Creating, deleting, cloning virtual machine instances
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F9/00Arrangements for program control, e.g. control units
    • G06F9/06Arrangements 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/44Arrangements for executing specific programs
    • G06F9/455Emulation; Interpretation; Software simulation, e.g. virtualisation or emulation of application or operating system execution engines
    • G06F9/45533Hypervisors; Virtual machine monitors
    • G06F9/45558Hypervisor-specific management and integration aspects
    • G06F2009/45575Starting, 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)
  • Data Mining & Analysis (AREA)
  • Databases & Information Systems (AREA)
  • Stored Programmes (AREA)

Abstract

本申请公开了一种虚拟机磁盘镜像构建方法、装置、设备、介质,该方法包括:利用目标docker镜像启动容器,并在所述容器中进行目标软件的安装和目标文件的剪裁,构建出虚拟机镜像系统rootfs;利用所述容器与宿主机操作系统的目录共享机制,构建目标虚拟机镜像系统rootfs;退出所述容器后,根据所述目标虚拟机镜像系统rootfs占用的磁盘空间大小,建立虚拟机磁盘镜像文件,以存放所述目标虚拟机镜像系统rootfs;将所述虚拟机磁盘镜像文件挂载到所述宿主机的第二目标目录下;将所述第二目标目录下的所述目标虚拟机镜像系统rootfs拷贝到虚拟机镜像系统的根分区下,得到可用的虚拟机磁盘镜像。这样能够降低虚拟机磁盘镜像构建的复杂度,且不会对宿主机系统造成影响。

Description

一种虚拟机磁盘镜像构建方法、装置、设备、介质
技术领域
本申请涉及虚拟化技术领域,特别涉及一种虚拟机磁盘镜像构建方法、装置、设备、介质。
背景技术
随着当前云计算的发展,虚拟化技术得到广泛的应用,用户可以根据自身业务的不同需要对虚拟机的操作系统进行个性化定制,现有的定制方法一般是针对不同的Linux操作系统发行版选择相应的ISO(光盘镜像文件)进行最小化安装,然后在虚拟机或物理机下进行操作系统的构建和剪裁等,最后生成定制化的虚拟机磁盘镜像文件,此方法需要在物理机和虚拟机之间频繁切换操作,增加了系统定制的复杂度,且会对宿主机系统造成影响。
发明内容
有鉴于此,本申请的目的在于提供一种虚拟机磁盘镜像构建方法、装置、设备、介质,能够降低虚拟机磁盘镜像构建的复杂度,且不会对宿主机系统造成影响。其具体方案如下:
第一方面,本申请公开了一种虚拟机磁盘镜像构建方法,包括:
利用目标docker镜像启动容器,并在所述容器中进行目标软件的安装和目标文件的剪裁,构建出虚拟机镜像系统rootfs;
利用所述容器与宿主机操作系统的目录共享机制,将宿主机下用于存储所述虚拟机镜像系统rootfs的第一目标目录挂载到所述容器下,并将容器rootfs拷贝到所述宿主机的所述第一目标目录下,得到目标虚拟机镜像系统rootfs;
退出所述容器后,根据所述目标虚拟机镜像系统rootfs占用的磁盘空间大小,建立虚拟机磁盘镜像文件,以存放所述目标虚拟机镜像系统rootfs;
将存放着所述目标虚拟机镜像系统rootfs的所述虚拟机磁盘镜像文件挂载到所述宿主机的第二目标目录下;
将所述第二目标目录下的所述目标虚拟机镜像系统rootfs拷贝到虚拟机镜像系统的根分区下,并将所述虚拟机磁盘镜像文件卸载,得到可用的虚拟机磁盘镜像。
可选的,所述利用目标docker镜像启动容器之前,还包括:
启动虚拟机镜像系统构建脚本,并选择虚拟机镜像系统的基础操作系统和版本。
可选的,所述启动虚拟机镜像系统构建脚本,并选择所述虚拟机镜像系统的基础操作系统和版本之后,还包括:
根据所述基础操作系统和所述版本,下载相应的mini版本的docker镜像。
可选的,所述将容器rootfs拷贝到所述宿主机的所述第一目标目录下,得到目标虚拟机镜像系统rootfs之后,还包括:
在所述容器中对所述目标虚拟机镜像系统rootfs进行剪裁优化。
可选的,所述根据所述目标虚拟机镜像系统rootfs占用的磁盘空间大小,建立虚拟机磁盘镜像文件,以存放所述目标虚拟机镜像系统rootfs,包括:
根据所述目标虚拟机镜像系统rootfs占用的磁盘空间大小,利用qemu-image命令建立虚拟机磁盘镜像文件,并在所述虚拟机磁盘镜像文件中创建磁盘分区,以存放所述目标虚拟机镜像系统rootfs。
可选的,所述将存放着所述目标虚拟机镜像系统rootfs的所述虚拟机磁盘镜像文件挂载到所述宿主机的第一目标目录下,包括:
将存放着所述目标虚拟机镜像系统rootfs的所述虚拟机磁盘镜像文件以loop方式作为块设备挂载到所述宿主机的第二目标目录下。
可选的,所述在所述容器中对所述目标虚拟机镜像系统rootfs进行剪裁优化,包括:
在所述容器中对所述目标虚拟机镜像系统rootfs中的冗余的二进制文件、系统服务、依赖库以及帮助文档进行剪裁。
第四方面,本申请公开了一种虚拟机磁盘镜像构建装置,包括:
容器启动模块,用于利用目标docker镜像启动容器;
第一rootfs构建模块,用于在所述容器中进行目标软件的安装和目标文件的剪裁,构建出虚拟机镜像系统rootfs;
第二rootfs构建模块,用于利用所述容器与宿主机操作系统的目录共享机制,将宿主机下用于存储所述虚拟机镜像系统rootfs的第一目标目录挂载到所述容器下,并将容器rootfs拷贝到所述宿主机的所述第一目标目录下,得到目标虚拟机镜像系统rootfs;
磁盘镜像文件建立模块,用于退出所述容器后,根据所述目标虚拟机镜像系统rootfs占用的磁盘空间大小,建立虚拟机磁盘镜像文件,以存放所述目标虚拟机镜像系统rootfs;
文件挂载模块,用于将存放着所述目标虚拟机镜像系统rootfs的所述虚拟机磁盘镜像文件挂载到所述宿主机的第二目标目录下;
文件拷贝模块,用于将所述第二目标目录下的所述目标虚拟机镜像系统rootfs拷贝到所述虚拟机镜像系统的根分区下;
文件卸载模块,用于将所述虚拟机磁盘镜像文件卸载,得到可用的虚拟机磁盘镜像。
第五方面,本申请公开了一种虚拟机磁盘镜像构建设备,包括:
存储器和处理器;
其中,所述存储器,用于存储计算机程序;
所述处理器,用于执行所述计算机程序,以实现前述公开的虚拟机磁盘镜像构建方法。
第四方面,本申请公开了一种计算机可读存储介质,用于保存计算机程序,其中,所述计算机程序被处理器执行时实现前述公开的虚拟机磁盘镜像构建方法。
可见,本申请先利用目标docker镜像启动容器,并在所述容器中进行目标软件的安装和目标文件的剪裁,构建出虚拟机镜像系统rootfs;再利用所述容器与宿主机操作系统的目录共享机制,将宿主机下用于存储所述虚拟机镜像系统rootfs的第一目标目录挂载到所述容器下,并将容器rootfs拷贝到所述宿主机的所述第一目标目录下,得到目标虚拟机镜像系统rootfs;退出所述容器后,根据所述目标虚拟机镜像系统rootfs占用的磁盘空间大小,建立虚拟机磁盘镜像文件,以存放所述目标虚拟机镜像系统rootfs;将存放着所述目标虚拟机镜像系统rootfs的所述虚拟机磁盘镜像文件挂载到所述宿主机的第二目标目录下;将所述第二目标目录下的所述目标虚拟机镜像系统rootfs拷贝到虚拟机镜像系统的根分区下,并将所述虚拟机磁盘镜像文件卸载,得到可用的虚拟机磁盘镜像。这样能够降低虚拟机磁盘镜像构建的复杂度,且在容器内进行相关软件的安装和文件的剪裁不会对宿主机系统造成影响。
附图说明
为了更清楚地说明本申请实施例或现有技术中的技术方案,下面将对实施例或现有技术描述中所需要使用的附图作简单地介绍,显而易见地,下面描述中的附图仅仅是本申请的实施例,对于本领域普通技术人员来讲,在不付出创造性劳动的前提下,还可以根据提供的附图获得其他的附图。
图1为本申请公开的一种虚拟机磁盘镜像构建方法流程图;
图2为本申请公开的一种具体的虚拟机磁盘镜像构建方法流程图;
图3为本申请公开的一种虚拟机磁盘镜像构建装置结构示意图;
图4为本申请公开的一种虚拟机磁盘镜像构建设备结构图;
图5为本申请公开的一种终端结构图。
具体实施方式
下面将结合本申请实施例中的附图,对本申请实施例中的技术方案进行清楚、完整地描述,显然,所描述的实施例仅仅是本申请一部分实施例,而不是全部的实施例。基于本申请中的实施例,本领域普通技术人员在没有做出创造性劳动前提下所获得的所有其他实施例,都属于本申请保护的范围。
目前,定制虚拟机磁盘镜像的方法一般是针对不同的Linux操作系统发行版选择相应的ISO进行最小化安装,然后在虚拟机或物理机下进行操作系统的构建和剪裁等,最后生成定制化的虚拟机磁盘镜像文件,此方法需要在物理机和虚拟机之间频繁切换操作,难以通过自动化方式实现,增加了系统定制的复杂度,且会对宿主机系统造成影响。有鉴于此,本申请提出了一种虚拟机磁盘镜像构建方法,能够降低虚拟机磁盘镜像构建的复杂度,且在容器内进行相关软件的安装和文件的剪裁不会对宿主机系统造成影响。
本申请实施例公开了一种虚拟机磁盘镜像构建方法,参见图1所示,该方法包括:
步骤S11:利用目标docker镜像启动容器,并在所述容器中进行目标软件的安装和目标文件的剪裁,构建出虚拟机镜像系统rootfs。
本申请实施例中,需要先利用目标docker镜像启动容器,并在所述容器中惊醒目标软件的安装和目标文件的剪裁,构建出虚拟机镜像系统rootfs,其中,所述目标软件为根据实际虚拟机镜像系统的需求确定的软件;所述目标文件包括但不限于二进制文件或文档;docker为一种开源的容器引擎,相对于Qemu是一种轻量级虚拟化技术,可以实现用户应用程序的隔离;rootfs为linux下的根文件系统,一般为磁盘主分区下操作系统的整个目录结构。
步骤S12:利用所述容器与宿主机操作系统的目录共享机制,将宿主机下用于存储所述虚拟机镜像系统rootfs的第一目标目录挂载到所述容器下,并将容器rootfs拷贝到所述宿主机的所述第一目标目录下,得到目标虚拟机镜像系统rootfs。
在具体的实施过程中,构建出所述虚拟机镜像系统rootfs后,需要利用所述容器与所述宿主机操作系统的目录共享机制,将所述宿主机下用于存储所述虚拟机镜像系统rootfs的第一目标目录挂载到所述容器下,在将容器rootfs拷贝到所述宿主机的所述第一目标目录中,得到目标虚拟机镜像系统rootfs。在得到所述目标虚拟机镜像系统rootfs之后,还包括:在所述容器中对所述目标虚拟机镜像系统rootfs中的冗余的二进制文件、系统服务、依赖库以及帮助文档进行剪裁,以避免冗余服务的启动和磁盘占用。
步骤S13:退出所述容器后,根据所述目标虚拟机镜像系统rootfs占用的磁盘空间大小,建立虚拟机磁盘镜像文件,以存放所述目标虚拟机镜像系统rootfs。
可以理解的是,在对所述目标虚拟机镜像rootfs相应的剪裁之后,需要退出所述容器,并根据所述目标虚拟机镜像rootfs占用磁盘空间的大小,建立相应的虚拟机磁盘镜像文件,以存放所述目标虚拟机镜像rootfs。具体的,根据所述目标虚拟机镜像系统rootfs占用的磁盘空间大小,建立虚拟机磁盘镜像文件,在所述虚拟机磁盘镜像文件上创建磁盘分区,建立文件系统用于存放所述目标虚拟机镜像系统rootfs。
步骤S14:将存放着所述目标虚拟机镜像系统rootfs的所述虚拟机磁盘镜像文件挂载到所述宿主机的第二目标目录下。
本实施例中,将所述目标虚拟机镜像系统rootfs存放到所述虚拟机磁盘镜像文件中之后,需要将所述虚拟机磁盘镜像文件挂载到所述宿主机答第二目标目录下,其中,所述第二目标目录为预先选定的一个目录。
步骤S15:将所述第二目标目录下的所述目标虚拟机镜像系统rootfs拷贝到虚拟机镜像系统的根分区下,并将所述虚拟机磁盘镜像文件卸载,得到可用的虚拟机磁盘镜像。
在具体的实施过程中,需要将所述第二目录下的所述目标虚拟机镜像系统rootfs拷贝到虚拟机镜像系统的根分区下,并将所述虚拟机磁盘镜像文件卸载,以得到可用的虚拟机磁盘镜像。
可见,本申请先利用目标docker镜像启动容器,并在所述容器中进行目标软件的安装和目标文件的剪裁,构建出虚拟机镜像系统rootfs;再利用所述容器与宿主机操作系统的目录共享机制,将宿主机下用于存储所述虚拟机镜像系统rootfs的第一目标目录挂载到所述容器下,并将容器rootfs拷贝到所述宿主机的所述第一目标目录下,得到目标虚拟机镜像系统rootfs;退出所述容器后,根据所述目标虚拟机镜像系统rootfs占用的磁盘空间大小,建立虚拟机磁盘镜像文件,以存放所述目标虚拟机镜像系统rootfs;将存放着所述目标虚拟机镜像系统rootfs的所述虚拟机磁盘镜像文件挂载到所述宿主机的第二目标目录下;将所述第二目标目录下的所述目标虚拟机镜像系统rootfs拷贝到虚拟机镜像系统的根分区下,并将所述虚拟机磁盘镜像文件卸载,得到可用的虚拟机磁盘镜像。这样能够降低虚拟机磁盘镜像构建的复杂度,且在容器内进行相关软件的安装和文件的剪裁不会对宿主机系统造成影响。
参见图2所示,本申请实施例公开了一种具体的虚拟机磁盘镜像构建方法,该方法包括:
步骤S21:启动虚拟机镜像系统构建脚本,并选择虚拟机镜像系统的基础操作系统和版本。
本实施例中,首先需要启动虚拟机镜像系统构建脚本,并选择虚拟机镜像的基础操作系统和版本。其中,所述基础操作系统包括但不限于redhat、centos、ubuntu等。
步骤S22:根据所述基础操作系统和所述版本,下载相应的mini版本的docker镜像。
在具体的实施过程中,需要根据所述基础操作系统和所述版本,下载相应的mini版本的docker镜像。所述mini版本的docker镜像具有所述基础操作系统的基本功能。
步骤S23:利用所述docker镜像启动容器,并在所述容器中进行目标软件的安装和目标文件的剪裁,构建出虚拟机镜像系统rootfs。
步骤S24:利用所述容器与宿主机操作系统的目录共享机制,将宿主机下用于存储所述虚拟机镜像系统rootfs的第一目标目录挂载到所述容器下,并将容器rootfs拷贝到所述宿主机的所述第一目标目录下,得到目标虚拟机镜像系统rootfs。
步骤S25:退出所述容器后,根据所述目标虚拟机镜像系统rootfs占用的磁盘空间大小,利用qemu-image命令建立虚拟机磁盘镜像文件,并在所述虚拟机磁盘镜像文件中创建磁盘分区,以存放所述目标虚拟机镜像系统rootfs。
在具体的实施过程中,在退出所述容器之后,需要根据所述目标虚拟机镜像系统rootfs占用的磁盘空间大小,利用qemu-image命令建立虚拟机磁盘镜像文件,并在所述虚拟机磁盘镜像文件中创建磁盘分区,以存放所述目标虚拟机镜像系统rootfs。其中,Qemu是一种Linux下开源虚拟化软件,可作为虚拟机模拟多种类型的cpu、外设等运行。
步骤S26:将存放着所述目标虚拟机镜像系统rootfs的所述虚拟机磁盘镜像文件以loop方式作为块设备挂载到所述宿主机的第二目标目录下。
可以理解的是,将所述目标虚拟机镜像系统rootfs存储到所述虚拟机磁盘镜像文件中之后,需要将所述虚拟机磁盘镜像文件以loop方式作为块设备挂载到所述宿主机的第二目标目录下。
步骤S27:将所述第二目标目录下的所述目标虚拟机镜像系统rootfs拷贝到虚拟机镜像系统的根分区下,并将所述虚拟机磁盘镜像文件卸载,得到可用的虚拟机磁盘镜像。
参见图3所示,本申请实施例公开了一种虚拟机磁盘镜像构建装置,包括:
容器启动模块11,用于利用目标docker镜像启动容器;
第一rootfs构建模块12,用于在所述容器中进行目标软件的安装和目标文件的剪裁,构建出虚拟机镜像系统rootfs;
第二rootfs构建模块13,用于利用所述容器与宿主机操作系统的目录共享机制,将宿主机下用于存储所述虚拟机镜像系统rootfs的第一目标目录挂载到所述容器下,并将容器rootfs拷贝到所述宿主机的所述第一目标目录下,得到目标虚拟机镜像系统rootfs;
磁盘镜像文件建立模块14,用于退出所述容器后,根据所述目标虚拟机镜像系统rootfs占用的磁盘空间大小,建立虚拟机磁盘镜像文件,以存放所述目标虚拟机镜像系统rootfs;
文件挂载模块15,用于将存放着所述目标虚拟机镜像系统rootfs的所述虚拟机磁盘镜像文件挂载到所述宿主机的第二目标目录下;
文件拷贝模块16,用于将所述第二目标目录下的所述目标虚拟机镜像系统rootfs拷贝到所述虚拟机镜像系统的根分区下;
文件卸载模块17,用于将所述虚拟机磁盘镜像文件卸载,得到可用的虚拟机磁盘镜像。
可见,本申请先利用目标docker镜像启动容器,并在所述容器中进行目标软件的安装和目标文件的剪裁,构建出虚拟机镜像系统rootfs;再利用所述容器与宿主机操作系统的目录共享机制,将宿主机下用于存储所述虚拟机镜像系统rootfs的第一目标目录挂载到所述容器下,并将容器rootfs拷贝到所述宿主机的所述第一目标目录下,得到目标虚拟机镜像系统rootfs;退出所述容器后,根据所述目标虚拟机镜像系统rootfs占用的磁盘空间大小,建立虚拟机磁盘镜像文件,以存放所述目标虚拟机镜像系统rootfs;将存放着所述目标虚拟机镜像系统rootfs的所述虚拟机磁盘镜像文件挂载到所述宿主机的第二目标目录下;将所述第二目标目录下的所述目标虚拟机镜像系统rootfs拷贝到虚拟机镜像系统的根分区下,并将所述虚拟机磁盘镜像文件卸载,得到可用的虚拟机磁盘镜像。这样能够降低虚拟机磁盘镜像构建的复杂度,且在容器内进行相关软件的安装和文件的剪裁不会对宿主机系统造成影响。
进一步的,参见图4所示,本申请实施例还公开了一种虚拟机磁盘镜像构建设备,包括:处理器21和存储器22。
其中,所述存储器22,用于存储计算机程序;所述处理器21,用于执行所述计算机程序,以实现前述实施例中公开的虚拟机磁盘镜像构建方法。
其中,关于上述虚拟机磁盘镜像构建方法的具体过程可以参考前述实施例中公开的相应内容,在此不再进行赘述。
参见图5所示,本申请公开了一种终端20,包括前述实施例中的处理器21和存储器22。关于上述处理器21具体可以执行的步骤可以参考前述实施例中公开的相应内容,在此不再进行赘述。
进一步的,本实施例中的终端20,还可以具体包括:电源23、通信接口24、输入输出接口25以及通信总线26;其中,所述电源23用于为所述终端20上的各硬件设备提供工作电压;所述通信接口24能够为所述终端20与外接设备之间的数据传输通道,其所遵循的通信协议是能够使用于本申请技术方案的任意通信协议,在此不对其做具体限定;所述输入输出接口25,用于获取外界输入的数据或向外界输出数据,其具体的接口类型可以根据具体应用需要进行选取,在此不进行具体限定。
进一步的,本申请实施例还公开了一种计算机可读存储介质,用于保存计算机程序,其中,所述计算机程序被处理器执行时实现以下步骤:
利用目标docker镜像启动容器,并在所述容器中进行目标软件的安装和目标文件的剪裁,构建出虚拟机镜像系统rootfs;利用所述容器与宿主机操作系统的目录共享机制,将宿主机下用于存储所述虚拟机镜像系统rootfs的第一目标目录挂载到所述容器下,并将容器rootfs拷贝到所述宿主机的所述第一目标目录下,得到目标虚拟机镜像系统rootfs;退出所述容器后,根据所述目标虚拟机镜像系统rootfs占用的磁盘空间大小,建立虚拟机磁盘镜像文件,以存放所述目标虚拟机镜像系统rootfs;将存放着所述目标虚拟机镜像系统rootfs的所述虚拟机磁盘镜像文件挂载到所述宿主机的第二目标目录下;将所述第二目标目录下的所述目标虚拟机镜像系统rootfs拷贝到虚拟机镜像系统的根分区下,并将所述虚拟机磁盘镜像文件卸载,得到可用的虚拟机磁盘镜像。
可见,本申请先利用目标docker镜像启动容器,并在所述容器中进行目标软件的安装和目标文件的剪裁,构建出虚拟机镜像系统rootfs;再利用所述容器与宿主机操作系统的目录共享机制,将宿主机下用于存储所述虚拟机镜像系统rootfs的第一目标目录挂载到所述容器下,并将容器rootfs拷贝到所述宿主机的所述第一目标目录下,得到目标虚拟机镜像系统rootfs;退出所述容器后,根据所述目标虚拟机镜像系统rootfs占用的磁盘空间大小,建立虚拟机磁盘镜像文件,以存放所述目标虚拟机镜像系统rootfs;将存放着所述目标虚拟机镜像系统rootfs的所述虚拟机磁盘镜像文件挂载到所述宿主机的第二目标目录下;将所述第二目标目录下的所述目标虚拟机镜像系统rootfs拷贝到虚拟机镜像系统的根分区下,并将所述虚拟机磁盘镜像文件卸载,得到可用的虚拟机磁盘镜像。这样能够降低虚拟机磁盘镜像构建的复杂度,且在容器内进行相关软件的安装和文件的剪裁不会对宿主机系统造成影响。
本实施例中,所述计算机可读存储介质中保存的计算机子程序被处理器执行时,可以具体实现以下步骤:启动虚拟机镜像系统构建脚本,并选择虚拟机镜像系统的基础操作系统和版本。
本实施例中,所述计算机可读存储介质中保存的计算机子程序被处理器执行时,可以具体实现以下步骤:根据所述基础操作系统和所述版本,下载相应的mini版本的docker镜像。
本实施例中,所述计算机可读存储介质中保存的计算机子程序被处理器执行时,可以具体实现以下步骤:在所述容器中对所述目标虚拟机镜像系统rootfs进行剪裁优化。
本实施例中,所述计算机可读存储介质中保存的计算机子程序被处理器执行时,可以具体实现以下步骤:根据所述目标虚拟机镜像系统rootfs占用的磁盘空间大小,利用qemu-image命令建立虚拟机磁盘镜像文件,并在所述虚拟机磁盘镜像文件中创建磁盘分区,以存放所述目标虚拟机镜像系统rootfs。
本实施例中,所述计算机可读存储介质中保存的计算机子程序被处理器执行时,可以具体实现以下步骤:将存放着所述目标虚拟机镜像系统rootfs的所述虚拟机磁盘镜像文件以loop方式作为块设备挂载到所述宿主机的第二目标目录下。
本实施例中,所述计算机可读存储介质中保存的计算机子程序被处理器执行时,可以具体实现以下步骤:在所述容器中对所述目标虚拟机镜像系统rootfs中的冗余的二进制文件、系统服务、依赖库以及帮助文档进行剪裁。
本说明书中各个实施例采用递进的方式描述,每个实施例重点说明的都是与其它实施例的不同之处,各个实施例之间相同或相似部分互相参见即可。对于实施例公开的装置而言,由于其与实施例公开的方法相对应,所以描述的比较简单,相关之处参见方法部分说明即可。
结合本文中所公开的实施例描述的方法或算法的步骤可以直接用硬件、处理器执行的软件模块,或者二者的结合来实施。软件模块可以置于随机存储器(RAM)、内存、只读存储器(ROM)、电可编程ROM、电可擦除可编程ROM、寄存器、硬盘、可移动磁盘、CD-ROM、或技术领域内所公知的任意其它形式的存储介质中。
最后,还需要说明的是,在本文中,诸如第一和第二之类的关系术语仅仅用来将一个实体或者操作与另一个实体或者操作区分开来,而不一定要求或者暗示这些实体或操作之间存在任何这种实际的关系或者顺序。而且,术语“包括”、“包含”或者其任何其他变体意在涵盖非排他性的包含,从而使得一系列包含其他要素的过程、方法、物品或者设备不仅包括那些要素,而且还包括没有明确列出的其他要素,或者是还包括为这种过程、方法、物品或者设备所固有的要素。在没有更多限制的情况下,由语句“包括一个……”限定的要素,并不排除在包括所述要素的过程、方法、物品或者设备中还存在另外的相同要素。
以上对本申请所提供的一种虚拟机磁盘镜像构建方法、装置、设备、介质进行了详细介绍,本文中应用了具体个例对本申请的原理及实施方式进行了阐述,以上实施例的说明只是用于帮助理解本申请的方法及其核心思想;同时,对于本领域的一般技术人员,依据本申请的思想,在具体实施方式及应用范围上均会有改变之处,综上所述,本说明书内容不应理解为对本申请的限制。

Claims (10)

1.一种虚拟机磁盘镜像构建方法,其特征在于,包括:
利用目标docker镜像启动容器,并在所述容器中进行目标软件的安装和目标文件的剪裁,构建出虚拟机镜像系统rootfs;
利用所述容器与宿主机操作系统的目录共享机制,将宿主机下用于存储所述虚拟机镜像系统rootfs的第一目标目录挂载到所述容器下,并将容器rootfs拷贝到所述宿主机的所述第一目标目录下,得到目标虚拟机镜像系统rootfs;
退出所述容器后,根据所述目标虚拟机镜像系统rootfs占用的磁盘空间大小,建立虚拟机磁盘镜像文件,以存放所述目标虚拟机镜像系统rootfs;
将存放着所述目标虚拟机镜像系统rootfs的所述虚拟机磁盘镜像文件挂载到所述宿主机的第二目标目录下;
将所述第二目标目录下的所述目标虚拟机镜像系统rootfs拷贝到虚拟机镜像系统的根分区下,并将所述虚拟机磁盘镜像文件卸载,得到可用的虚拟机磁盘镜像。
2.根据权利要求1所述的虚拟机磁盘镜像构建方法,其特征在于,所述利用目标docker镜像启动容器之前,还包括:
启动虚拟机镜像系统构建脚本,并选择虚拟机镜像系统的基础操作系统和版本。
3.根据权利要求2所述的虚拟机磁盘镜像构建方法,其特征在于,所述启动虚拟机镜像系统构建脚本,并选择所述虚拟机镜像系统的基础操作系统和版本之后,还包括:
根据所述基础操作系统和所述版本,下载相应的mini版本的docker镜像。
4.根据权利要求3所述的虚拟机磁盘镜像构建方法,其特征在于,所述将容器rootfs拷贝到所述宿主机的所述第一目标目录下,得到目标虚拟机镜像系统rootfs之后,还包括:
在所述容器中对所述目标虚拟机镜像系统rootfs进行剪裁优化。
5.根据权利要求4所述的虚拟机磁盘镜像构建方法,其特征在于,所述根据所述目标虚拟机镜像系统rootfs占用的磁盘空间大小,建立虚拟机磁盘镜像文件,以存放所述目标虚拟机镜像系统rootfs,包括:
根据所述目标虚拟机镜像系统rootfs占用的磁盘空间大小,利用qemu-image命令建立虚拟机磁盘镜像文件,并在所述虚拟机磁盘镜像文件中创建磁盘分区,以存放所述目标虚拟机镜像系统rootfs。
6.根据权利要求5所述的虚拟机磁盘镜像构建方法,其特征在于,所述将存放着所述目标虚拟机镜像系统rootfs的所述虚拟机磁盘镜像文件挂载到所述宿主机的第一目标目录下,包括:
将存放着所述目标虚拟机镜像系统rootfs的所述虚拟机磁盘镜像文件以loop方式作为块设备挂载到所述宿主机的第二目标目录下。
7.根据权利要求4至6任一项所述的虚拟机磁盘镜像构建方法,其特征在于,所述在所述容器中对所述目标虚拟机镜像系统rootfs进行剪裁优化,包括:
在所述容器中对所述目标虚拟机镜像系统rootfs中的冗余的二进制文件、系统服务、依赖库以及帮助文档进行剪裁。
8.一种虚拟机磁盘镜像构建装置,其特征在于,包括:
容器启动模块,用于利用目标docker镜像启动容器;
第一rootfs构建模块,用于在所述容器中进行目标软件的安装和目标文件的剪裁,构建出虚拟机镜像系统rootfs;
第二rootfs构建模块,用于利用所述容器与宿主机操作系统的目录共享机制,将宿主机下用于存储所述虚拟机镜像系统rootfs的第一目标目录挂载到所述容器下,并将容器rootfs拷贝到所述宿主机的所述第一目标目录下,得到目标虚拟机镜像系统rootfs;
磁盘镜像文件建立模块,用于退出所述容器后,根据所述目标虚拟机镜像系统rootfs占用的磁盘空间大小,建立虚拟机磁盘镜像文件,以存放所述目标虚拟机镜像系统rootfs;
文件挂载模块,用于将存放着所述目标虚拟机镜像系统rootfs的所述虚拟机磁盘镜像文件挂载到所述宿主机的第二目标目录下;
文件拷贝模块,用于将所述第二目标目录下的所述目标虚拟机镜像系统rootfs拷贝到所述虚拟机镜像系统的根分区下;
文件卸载模块,用于将所述虚拟机磁盘镜像文件卸载,得到可用的虚拟机磁盘镜像。
9.一种虚拟机磁盘镜像构建设备,包括:
存储器和处理器;
其中,所述存储器,用于存储计算机程序;
所述处理器,用于执行所述计算机程序,以实现权利要求1至7任一项所述的虚拟机磁盘镜像构建方法。
10.一种计算机可读存储介质,用于保存计算机程序,其中,所述计算机程序被处理器执行时实现如权利要求1至7任一项所述的虚拟机磁盘镜像构建方法。
CN201911121547.6A 2019-11-15 2019-11-15 一种虚拟机磁盘镜像构建方法、装置、设备、介质 Active CN110955494B (zh)

Priority Applications (1)

Application Number Priority Date Filing Date Title
CN201911121547.6A CN110955494B (zh) 2019-11-15 2019-11-15 一种虚拟机磁盘镜像构建方法、装置、设备、介质

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
CN201911121547.6A CN110955494B (zh) 2019-11-15 2019-11-15 一种虚拟机磁盘镜像构建方法、装置、设备、介质

Publications (2)

Publication Number Publication Date
CN110955494A CN110955494A (zh) 2020-04-03
CN110955494B true CN110955494B (zh) 2022-04-22

Family

ID=69977545

Family Applications (1)

Application Number Title Priority Date Filing Date
CN201911121547.6A Active CN110955494B (zh) 2019-11-15 2019-11-15 一种虚拟机磁盘镜像构建方法、装置、设备、介质

Country Status (1)

Country Link
CN (1) CN110955494B (zh)

Families Citing this family (5)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN111782339B (zh) * 2020-06-28 2024-04-12 京东科技控股股份有限公司 一种容器创建方法、装置、电子设备及存储介质
CN112685134A (zh) * 2020-12-31 2021-04-20 中科星图股份有限公司 一种在容器环境中基于镜像装载的镜像构建及装载方法
CN114201239B (zh) * 2022-02-17 2022-05-17 苏州浪潮智能科技有限公司 一种系统适配方法、装置及电子设备和存储介质
CN115454572A (zh) * 2022-09-20 2022-12-09 北京志凌海纳科技有限公司 基于Docker工具构建虚拟机磁盘镜像的方法及系统
CN115774701B (zh) * 2022-12-01 2023-11-28 北京首都在线科技股份有限公司 数据共享方法、装置、电子设备及存储介质

Citations (6)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US9223966B1 (en) * 2014-05-04 2015-12-29 Symantec Corporation Systems and methods for replicating computing system environments
WO2017092672A1 (zh) * 2015-12-03 2017-06-08 华为技术有限公司 一种Docker容器运行方法和装置
CN107229509A (zh) * 2017-06-09 2017-10-03 山东超越数控电子有限公司 一种飞腾平台下容器型虚拟机的创建方法
CN107766130A (zh) * 2016-08-22 2018-03-06 中国电信股份有限公司 虚拟机向容器迁移的方法和装置
CN108664313A (zh) * 2018-05-18 2018-10-16 广州杰赛科技股份有限公司 镜像文件在线制作方法、装置、服务器、系统及存储介质
CN109597626A (zh) * 2017-09-30 2019-04-09 北京国双科技有限公司 一种组件部署方法和装置

Patent Citations (6)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US9223966B1 (en) * 2014-05-04 2015-12-29 Symantec Corporation Systems and methods for replicating computing system environments
WO2017092672A1 (zh) * 2015-12-03 2017-06-08 华为技术有限公司 一种Docker容器运行方法和装置
CN107766130A (zh) * 2016-08-22 2018-03-06 中国电信股份有限公司 虚拟机向容器迁移的方法和装置
CN107229509A (zh) * 2017-06-09 2017-10-03 山东超越数控电子有限公司 一种飞腾平台下容器型虚拟机的创建方法
CN109597626A (zh) * 2017-09-30 2019-04-09 北京国双科技有限公司 一种组件部署方法和装置
CN108664313A (zh) * 2018-05-18 2018-10-16 广州杰赛科技股份有限公司 镜像文件在线制作方法、装置、服务器、系统及存储介质

Non-Patent Citations (2)

* Cited by examiner, † Cited by third party
Title
Docker容器在省级数据中心云平台上的应用探析;段国建;《金融电子化 》;20190315;全文 *
Efficient service handoff across edge servers via docker container migration;Lele Ma;《SEC "17: Proceedings of the Second ACM》;20171031;全文 *

Also Published As

Publication number Publication date
CN110955494A (zh) 2020-04-03

Similar Documents

Publication Publication Date Title
CN110955494B (zh) 一种虚拟机磁盘镜像构建方法、装置、设备、介质
US9519654B2 (en) Method, device, processing center and system for desktop synchronization
US9332063B2 (en) Versatile application configuration for deployable computing environments
CN105765526A (zh) 通过网络从远程磁盘镜像进行引导
CN109840096B (zh) 操作系统的安装方法及装置
CN107291481B (zh) 一种组件更新方法、装置和系统
CN109669692B (zh) 源码共享方法、服务器、计算机可读存储介质及系统
JPWO2009078285A1 (ja) 無線端末、無線端末の不揮発性メモリ、および診断情報のフェイルセーフ保存方法
CN110109628B (zh) 分布式存储系统的数据重建方法、装置、设备及存储介质
RU2635891C2 (ru) Механизм инсталляции и формат пакета для распараллеливаемых надежных инсталляций
JP2012104150A (ja) ネットワーク環境におけるスペースのカスタマイズ
CN113282342A (zh) 部署方法、装置、系统、电子设备和可读存储介质
CN111433747A (zh) 用于加载操作系统的虚拟存储器
CN111399936A (zh) 一种bmc定制的方法、系统、设备及可读存储介质
CN106293790B (zh) 基于Firefox操作系统的应用程序升级方法和装置
CN112199109B (zh) 一种固件升级方法、装置、设备及介质
CN114637519A (zh) 一种安装基础架构和服务的方法及装置
CN114385251A (zh) 基于存储器的操作系统引导方法、系统、终端及存储介质
CN113485722A (zh) 应用商店的应用程序的上架方法、处理方法及计算机设备
US10127029B1 (en) Operating system installation using logical volumes
CN112988181A (zh) 应用更新方法、装置、终端、服务器和可读存储介质
US20150212866A1 (en) Management system for service of multiple operating environments, and methods thereof
CN115586872A (zh) 一种容器镜像管理方法、装置、设备及存储介质
US20200278871A1 (en) Starting method for multi-mode iot device, multi-mode iot device, and storage medium
CN114610366A (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