CN107766118A - 一种创建kvm虚拟机的方法和装置 - Google Patents
一种创建kvm虚拟机的方法和装置 Download PDFInfo
- Publication number
- CN107766118A CN107766118A CN201610675508.0A CN201610675508A CN107766118A CN 107766118 A CN107766118 A CN 107766118A CN 201610675508 A CN201610675508 A CN 201610675508A CN 107766118 A CN107766118 A CN 107766118A
- Authority
- CN
- China
- Prior art keywords
- kvm
- virtual machine
- virtual machines
- image file
- shell scripts
- 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
Links
Classifications
-
- 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/45504—Abstract machines for programme code execution, e.g. Java virtual machine [JVM], interpreters, emulators
-
- 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
Landscapes
- Engineering & Computer Science (AREA)
- Software Systems (AREA)
- Theoretical Computer Science (AREA)
- Physics & Mathematics (AREA)
- General Engineering & Computer Science (AREA)
- General Physics & Mathematics (AREA)
- Stored Programmes (AREA)
Abstract
本发明公开了一种创建KVM虚拟机的方法和装置,该方法包括:创建源虚拟机,生成该源虚拟机对应的虚拟机模板镜像文件;设置用于配置网络地址信息的源Shell脚本;将所述虚拟机模板镜像文件和所述源Shell脚本保存到指定物理机上;根据所述虚拟机模板镜像文件在所述指定物理机上创建一个或多个KVM虚拟机;根据所述源Shell脚本为所创建的每个KVM虚拟机配置相应的网络地址信息。本发明提供的技术方案实现了自动化创建KVM虚拟机的方案,与现有技术中需要网络工程师手动创建虚拟机、配置虚拟机网络的方案相比,本方案可以快速、批量、自动化地在指定物理机上创建KVM虚拟机并设置相应的网络地址信息,十分省时省力,符合当前的虚拟机创建需求。
Description
技术领域
本发明涉及虚拟机技术领域,具体涉及一种创建KVM虚拟机的方法和装置。
背景技术
KVM(Kernel-based Virtual Machine),是一个开源的系统虚拟化模块,自Linux2.6.20之后集成在Linux的各个主要发行版本中,它使用Linux自身的调度器进行管理。KVM的虚拟化需要硬件支持(如Intel VT技术或者AMD V技术),是基于硬件的完全虚拟化。Libvirt,是一套免费、开源的支持Linux下主流虚拟化工具的C函数库,是目前使用最为广泛的对KVM虚拟机进行管理的工具和应用程序接口(API)。Libguestfs,是一套用于访问和修改虚拟机(VM)磁盘映像的工具,该工具可以在不启动KVM guest主机的情况下直接查看guest主机的文件内容,也可直接对img镜像文件执行写入文件和/或复制文件到外面的物理机的操作,也可以像linux mount(挂载命令)一样支持挂载操作。
现有技术中,KVM虚拟机的创建方式是:网络工程师搭建网络环境,搭建KVM环境,手动创建虚拟机,配置虚拟机网络;整个流程均是由网络工程师手动完成,这种方式对网络工程师依赖性比较强,不利于批量创建具有不同网络地址信息的虚拟机。
发明内容
鉴于上述问题,提出了本发明以便提供一种克服上述问题或者至少部分地解决上述问题的创建KVM虚拟机的方法和装置。
依据本发明的一个方面,提供了一种创建KVM虚拟机的方法,该方法包括:
创建源虚拟机,生成该源虚拟机对应的虚拟机模板镜像文件;
设置用于配置网络地址信息的源Shell脚本;
将虚拟机模板镜像文件和源Shell脚本保存到指定物理机上;
根据虚拟机模板镜像文件在指定物理机上创建一个或多个KVM虚拟机;
根据源Shell脚本为所创建的每个KVM虚拟机配置相应的网络地址信息。
可选地,根据源Shell脚本为所创建的每个KVM虚拟机配置相应的网络地址信息包括:
对于所创建的每个KVM虚拟机,
根据源Shell脚本生成该KVM虚拟机对应的Shell脚本;
启动该KVM虚拟机,运行该KVM虚拟机对应的Shell脚本;
利用该KVM虚拟机对应的Shell脚本为该KVM虚拟机配置相应的网络地址信息。
可选地,根据源Shell脚本生成该KVM虚拟机对应的Shell脚本包括:
复制源Shell脚本;
获取该KVM虚拟机对应的网络地址信息,将所获取的网络地址信息设置到该复制的源Shell脚本中,将经过设置的该复制的源Shell脚本作为该KVM虚拟机对应的Shell脚本。
可选地,根据虚拟机模板镜像文件在所述指定物理机上创建一个或多个KVM虚拟机包括:
对于每个待创建的KVM虚拟机,
根据虚拟机模板镜像文件生成该KVM虚拟机对应的镜像文件;
根据该KVM虚拟机对应的镜像文件,在指定物理机上创建该KVM虚拟机。
可选地,根据虚拟机模板镜像文件生成该KVM虚拟机对应的镜像文件包括:
复制虚拟机模板镜像文件到指定存储目录,将该复制的虚拟机模板镜像文件中的系统信息删除;
获取该KVM虚拟机对应的参数信息,将所获取的参数信息设置到该复制的虚拟机模板镜像文件中,为该复制的虚拟机模板镜像文件设置主机名和管理员权限;将经过设置的该复制的虚拟机模板镜像文件作为该KVM虚拟机对应的镜像文件。
可选地,KVM虚拟机对应的参数信息包括:KVM虚拟机的唯一标识,和/或,KVM虚拟机的MAC地址。
可选地,创建一个源虚拟机,生成该源虚拟机对应的虚拟机模板镜像文件的步骤和设置用于配置网络地址信息的源Shell脚本的步骤不是在指定物理机上执行的;
则将虚拟机模板镜像文件和源Shell脚本保存到指定物理机上包括:远程登录所述指定物理机,将虚拟机模板镜像文件和源Shell脚本上传到指定物理机的指定文件夹中。
依据本发明的另一个方面,提供了一种创建KVM虚拟机的装置,该装置包括:
模板创建单元,用于创建一个源虚拟机,生成该源虚拟机对应的虚拟机模板镜像文件;
脚本设置单元,用于设置用于配置网络地址信息的源Shell脚本;
虚拟机创建单元,适于将虚拟机模板镜像文件和源Shell脚本保存到指定物理机上;根据虚拟机模板镜像文件在指定物理机上创建一个或多个KVM虚拟机;根据源Shell脚本为所创建的每个KVM虚拟机配置相应的网络地址信息。
可选地,虚拟机创建单元,用于对于所创建的每个KVM虚拟机,根据源Shell脚本生成该KVM虚拟机对应的Shell脚本;启动该KVM虚拟机,运行该KVM虚拟机对应的Shell脚本;利用该KVM虚拟机对应的Shell脚本为该KVM虚拟机配置相应的网络地址信息。
可选地,虚拟机创建单元,用于复制源Shell脚本;获取该KVM虚拟机对应的网络地址信息,将所获取的网络地址信息设置到该复制的源Shell脚本中,将经过设置的该复制的源Shell脚本作为该KVM虚拟机对应的Shell脚本。
可选地,虚拟机创建单元,用于对于每个待创建的KVM虚拟机,根据虚拟机模板镜像文件生成该KVM虚拟机对应的镜像文件;根据该KVM虚拟机对应的镜像文件,在指定物理机上创建该KVM虚拟机。
可选地,虚拟机创建单元,用于复制虚拟机模板镜像文件到指定存储目录,将该复制的虚拟机模板镜像文件中的系统信息删除;获取该KVM虚拟机对应的参数信息,将所获取的参数信息设置到该复制的虚拟机模板镜像文件中,为该复制的虚拟机模板镜像文件设置主机名和管理员权限;将经过设置的该复制的虚拟机模板镜像文件作为该KVM虚拟机对应的镜像文件。
可选地,KVM虚拟机对应的参数信息包括:KVM虚拟机的唯一标识,和/或,KVM虚拟机的MAC地址。
可选地,创建KVM虚拟机的装置未设置在指定物理机上,或者,创建KVM虚拟机的装置设置在所述指定物理机上;
当创建KVM虚拟机的装置未设置在指定物理机上时,则虚拟机创建单元,适于远程登录指定物理机,将虚拟机模板镜像文件和源Shell脚本上传到指定物理机的指定文件夹中,根据虚拟机模板镜像文件在指定物理机上创建一个或多个KVM虚拟机,根据源Shell脚本为所创建的每个KVM虚拟机配置相应的网络地址信息。
由上述可知,本发明提供的技术方案通过预先创建的虚拟机模板镜像文件和源Shell脚本,在指定物理机上创建KVM虚拟机并为所创建的每个KVM虚拟机配置相应的网络地址信息,实现了自动化创建KVM虚拟机的方案,与现有技术中需要网络工程师手动创建虚拟机、配置虚拟机网络的方案相比,本方案可以快速、批量、自动化地在指定物理机上创建KVM虚拟机并设置相应的网络地址信息,十分省时省力,符合当前的虚拟机创建需求。
上述说明仅是本发明技术方案的概述,为了能够更清楚了解本发明的技术手段,而可依照说明书的内容予以实施,并且为了让本发明的上述和其它目的、特征和优点能够更明显易懂,以下特举本发明的具体实施方式。
附图说明
通过阅读下文优选实施方式的详细描述,各种其他的优点和益处对于本领域普通技术人员将变得清楚明了。附图仅用于示出优选实施方式的目的,而并不认为是对本发明的限制。而且在整个附图中,用相同的参考符号表示相同的部件。在附图中:
图1示出了根据本发明一个实施例的一种创建KVM虚拟机的方法的流程图;
图2示出了根据本发明一个实施例的一种创建KVM虚拟机的装置的示意图。
具体实施方式
下面将参照附图更详细地描述本公开的示例性实施例。虽然附图中显示了本公开的示例性实施例,然而应当理解,可以以各种形式实现本公开而不应被这里阐述的实施例所限制。相反,提供这些实施例是为了能够更透彻地理解本公开,并且能够将本公开的范围完整的传达给本领域的技术人员。
图1示出了根据本发明一个实施例的一种创建KVM虚拟机的方法的流程图。如图1所示,该方法包括:
步骤S110,创建源虚拟机,生成该源虚拟机对应的虚拟机模板镜像文件。
步骤S120,设置用于配置网络地址信息的源Shell脚本。
步骤S130,将虚拟机模板镜像文件和源Shell脚本保存到指定物理机上。
其中,指定物理机是具有虚拟机搭建需求的物理机。
步骤S140,根据虚拟机模板镜像文件在指定物理机上创建一个或多个KVM虚拟机。
步骤S150,根据源Shell脚本为所创建的每个KVM虚拟机配置相应的网络地址信息。
其中,网络地址信息包括IP地址、子网掩码、网关、DNS等,为每个KVM虚拟机配置该KVM虚拟机对应的网络地址信息,以搭建该KVM虚拟机的网络环境。
需要说明的是,在本发明实施例中不需要使用动态主机配置协议dhcp方式根据MAC地址为KVM虚拟机分配IP地址。而是根据源Shell脚本为KVM虚拟机指定固定的IP地址。
可见,图1所示的方法通过预先创建的虚拟机模板镜像文件和源Shell脚本,在指定物理机上创建KVM虚拟机并为所创建的每个KVM虚拟机配置相应的网络地址信息,实现了自动化创建KVM虚拟机的方案,与现有技术中需要网络工程师手动创建虚拟机、配置虚拟机网络的方案相比,本方案可以快速、批量、自动化地在指定物理机上创建KVM虚拟机并设置相应的网络地址信息,十分省时省力,符合当前的虚拟机创建需求。
在本发明的一个实施例中,上述步骤S110和步骤S120是在指定物理机之外的其他物理机上执行的,则后续步骤S130-S150需要该其他物理机与指定物理机进行远程通信以实现在指定物理机上创建虚拟机的目的。例如,指定物理机为KVM主机,该KVM主机中搭建有KVM环境,步骤S110和步骤S120在一个客机上执行,该客机中搭建有KVM环境,该客机中安装有Libguestfs工具,在客机中创建的一个虚拟机作为源虚拟机或者以客机中原先已有的一个虚拟机作为源虚拟机,该源虚拟机上安装有操作系统,通过Libguestfs工具生成该源虚拟机对应的虚拟机模板镜像文件并保存,以及在客机中编写用于配置网络地址信息的源Shell脚本;通过jsch SSH远程登录到KVM主机上,将客机中的虚拟机模板镜像文件和源Shell脚本上传到KVM主机的指定文件夹中,通过远程登录在KVM主机上根据虚拟机模板镜像文件创建一个或多个KVM虚拟机,并根据源Shell脚本为各个KVM虚拟机配置相应的网络地址信息。
或者,上述步骤S110-S120也可以是在指定物理机上执行的,则后续步骤S130-S150直接在指定物理机上执行,例如,指定物理机为KVM主机,该KVM主机中搭建有KVM环境,以在KVM主机上创建的一个虚拟机作为源虚拟机或者以KVM主机上原先已有的一个虚拟机作为源虚拟机,该源虚拟机上安装有操作系统,通过Libguestfs工具生成该源虚拟机对应的虚拟机模板镜像文件,以及在KVM主机中编写用于配置网络地址信息的源Shell脚本,将虚拟机模板镜像文件和源Shell文件保存到KVM主机的指定文件夹中,根据虚拟机模板镜像文件创建一个或多个KVM虚拟机,并根据源Shell脚本为各个KVM虚拟机配置相应的网络地址信息。
在本发明的一个实施例中,图1所示方法的步骤S140根据虚拟机模板镜像文件在指定物理机上创建一个或多个KVM虚拟机包括:对于每个待创建的KVM虚拟机,根据所述虚拟机模板镜像文件生成该KVM虚拟机对应的镜像文件;根据该KVM虚拟机对应的镜像文件,在所述指定物理机上创建该KVM虚拟机。
具体地,上述根据虚拟机模板镜像文件生成该KVM虚拟机对应的镜像文件包括:复制所述虚拟机模板镜像文件到指定存储目录,将该复制的虚拟机模板镜像文件中的系统信息删除;获取该KVM虚拟机对应的参数信息,将所获取的参数信息设置到该复制的虚拟机模板镜像文件中,为该复制的虚拟机模板镜像文件设置主机名和管理员权限;将经过设置的该复制的虚拟机模板镜像文件作为该KVM虚拟机对应的镜像文件。其中,所述KVM虚拟机对应的参数信息包括:KVM虚拟机的唯一标识,和/或,KVM虚拟机的MAC地址。
本实施例在创建每个KVM虚拟机时,保留指定文件夹中的虚拟机模板镜像文件的原件,复制一份虚拟机模板镜像文件到指定存储目录,在该复制的虚拟机模板镜像文件的基础上,删除该复制的虚拟机模板镜像文件中原有的、与待创建的KVM虚拟机不相符的系统信息,设置与待创建的KVM虚拟机相匹配的参数信息,并设置待创建的KVM虚拟机的主机名,设置管理员权限,使得该经过修改设置的虚拟机模板镜像文件反映出待创建的KVM虚拟机的较为完备的配置信息,即将反映待创建的KVM虚拟机的配置信息的该镜像文件作为该待创建的KVM虚拟机对应的镜像文件,根据对应的镜像文件中的配置信息即可创建相应的KVM虚拟机。
在本发明的一个实施例中,图1所示方法的步骤S150根据源Shell脚本为所创建的每个KVM虚拟机配置相应的网络地址信息包括:对于所创建的每个KVM虚拟机,根据所述源Shell脚本生成该KVM虚拟机对应的Shell脚本;启动该KVM虚拟机,运行该KVM虚拟机对应的Shell脚本;利用该KVM虚拟机对应的Shell脚本为该KVM虚拟机配置相应的网络地址信息。
具体地,上述根据源Shell脚本生成该KVM虚拟机对应的Shell脚本包括:复制源Shell脚本;获取该KVM虚拟机对应的网络地址信息,将所获取的网络地址信息设置到该复制的源Shell脚本中,将经过设置的该复制的源Shell脚本作为该KVM虚拟机对应的Shell脚本。
其中,在复制源Shell脚本之后,如果上述获取该KVM虚拟机对应的网络地址信息是在指定物理机之外的其它机器上执行的,则在获取到KVM虚拟机对应的网络地址信息之后,也需要通过远程通信将获取到的网络地址信息传给复制的源Shell脚本,使得网络地址信息设置到复制的源Shell脚本中,得到KVM虚拟机对应的Shell脚本,该Shell脚本反映了KVM虚拟机对应的网络配置信息;在第一次启动KVM虚拟机时,运行该KVM虚拟机对应的Shell脚本,使得该Shell脚本通过其中的相应的网络地址信息对KVM虚拟机进行配置。对于不同的KVM虚拟机,所传入复制的Shell脚本中的网络地址信息也不同,保证了所创建的KVM的网络环境的可用。
可见,在创建每个KVM虚拟机和为KVM虚拟机配置网络地址信息的过程中,所用到的均为虚拟机模板镜像文件的副本和源Shell脚本的副本,而指定物理机上的指定文件夹中的虚拟机模板镜像文件和源Shell文件一直存在且保持不变,使得无论何时具有创建KVM虚拟机的需求时均可以被满足,使得本发明实施例的方案的可实施时间长、实施范围广的优势。
通过一个具体的例子来说明本方案的实施过程,在本例中,指定物理机为KVM主机,KVM主机上部署有KVM环境、Libguestfs工具、SSH客户端和Libvirt工具,一个KVM客机上部署有KVM环境、Libguestfs工具和SSH客户端,在该KVM客机上创建一个KVM虚拟机作为源虚拟机,通过该KVM客机上的Libguestfs工具生成源虚拟机对应的虚拟机模板镜像文件,编写用于配置网络地址信息的源Shell脚本:setNetworkByMac_template.sh,KVM客机与KVM主机通过SSH客户端的jsch实现进行远程连接,将KVM客机上的虚拟机模板镜像文件和源Shell脚本上传到KVM主机的指定文件中;在想要创建一个KVM虚拟机A时,通过jsch SSH远程登录到KVM主机上运行Linux命令,使得根据指定文件夹中的虚拟机模板镜像文件生成待创建的KVM虚拟机A对应的镜像文件,以及根据指定文件夹中的源Shell脚本生成待创建的KVM虚拟机A对应的Shell脚本,具体运行的Linux命令如表1所示,获取待创建的KVM虚拟机A的唯一标识和MAC地址,复制虚拟机模板镜像文件到Libvirt存储目录,将该将复制的虚拟机模板镜像文件的文件名更改为KVM虚拟机A的镜像文件,复制源Shell脚本setNetworkByMac_template.sh,修改该复制的Shell脚本,将KVM虚拟机A对应的网络地址信息设置到该复制的源Shell脚本中;运行Libguestfs命令virtsysprep,将改名后的KVM虚拟机A的镜像文件中原有的系统信息删除,设置唯一标识和MAC地址,设置主机名和ROOT用户密码(管理员权限)。
接着,根据上述生成的KVM虚拟机A的镜像文件中的配置信息(xml信息),使用Libvirt的domainDefineXML()方法创建KVM虚拟机,再使用Libvirt的create()方法启动该新创建的KVM虚拟机A,在该KVM虚拟机A首次运行时运行上述经设置后的该复制的源Shell脚本,该Shell脚本为KVM虚拟机A配置相应的网络地址信息,至此,KVM虚拟机A创建完成,可以正常使用。再在该KVM主机上创建其他KVM虚拟机时,创建过程与上述一致,在此不再赘述。
表1
图2示出了根据本发明一个实施例的一种创建KVM虚拟机的装置的示意图。如图2所示,该创建KVM虚拟机的装置200包括:
模板创建单元210,用于创建一个源虚拟机,生成该源虚拟机对应的虚拟机模板镜像文件。
脚本设置单元220,用于设置用于配置网络地址信息的源Shell脚本。
虚拟机创建单元230,适于将所述虚拟机模板镜像文件和所述源Shell脚本保存到指定物理机上;根据所述虚拟机模板镜像文件在所述指定物理机上创建一个或多个KVM虚拟机;根据所述源Shell脚本为所创建的每个KVM虚拟机配置相应的网络地址信息。
可见,图2所示的装置通过预先创建的虚拟机模板镜像文件和源Shell脚本,在指定物理机上创建KVM虚拟机并为所创建的每个KVM虚拟机配置相应的网络地址信息,实现了自动化创建KVM虚拟机的方案,与现有技术中需要网络工程师手动创建虚拟机、配置虚拟机网络的方案相比,本方案可以快速、批量、自动化地在指定物理机上创建KVM虚拟机并设置相应的网络地址信息,十分省时省力,符合当前的虚拟机创建需求。
在本发明的一个实施例中,虚拟机创建单元230,用于对于所创建的每个KVM虚拟机,根据所述源Shell脚本生成该KVM虚拟机对应的Shell脚本;启动该KVM虚拟机,运行该KVM虚拟机对应的Shell脚本;利用该KVM虚拟机对应的Shell脚本为该KVM虚拟机配置相应的网络地址信息。
具体地,虚拟机创建单元230,用于复制所述源Shell脚本;获取该KVM虚拟机对应的网络地址信息,将所获取的网络地址信息设置到该复制的源Shell脚本中,将经过设置的该复制的源Shell脚本作为该KVM虚拟机对应的Shell脚本。
在本发明的一个实施例中,虚拟机创建单元230,用于对于每个待创建的KVM虚拟机,根据所述虚拟机模板镜像文件生成该KVM虚拟机对应的镜像文件;根据该KVM虚拟机对应的镜像文件,在所述指定物理机上创建该KVM虚拟机。
具体地,虚拟机创建单元230,用于复制所述虚拟机模板镜像文件到指定存储目录,将该复制的虚拟机模板镜像文件中的系统信息删除;获取该KVM虚拟机对应的参数信息,将所获取的参数信息设置到该复制的虚拟机模板镜像文件中,为该复制的虚拟机模板镜像文件设置主机名和管理员权限;将经过设置的该复制的虚拟机模板镜像文件作为该KVM虚拟机对应的镜像文件。其中,KVM虚拟机对应的参数信息包括:KVM虚拟机的唯一标识,和/或,KVM虚拟机的MAC地址。
在本发明的一个实施例中,创建KVM虚拟机的装置200未设置在所述指定物理机上,或者,创建KVM虚拟机的装置200设置在所述指定物理机上;当创建KVM虚拟机的装置200未设置在所述指定物理机上时,则虚拟机创建单元230,适于远程登录所述指定物理机,将所述虚拟机模板镜像文件和所述源Shell脚本上传到所述指定物理机的指定文件夹中,根据所述虚拟机模板镜像文件在所述指定物理机上创建一个或多个KVM虚拟机,根据所述源Shell脚本为所创建的每个KVM虚拟机配置相应的网络地址信息。
需要说明的是,图2所示装置的各实施例与图1所示方法的各实施例对应相同,上文中已有详细说明,在此不再赘述。
综上所述,本发明提供的技术方案通过预先创建的虚拟机模板镜像文件和源Shell脚本,在指定物理机上创建KVM虚拟机并为所创建的每个KVM虚拟机配置相应的网络地址信息,实现了自动化创建KVM虚拟机的方案,与现有技术中需要网络工程师手动创建虚拟机、配置虚拟机网络的方案相比,本方案可以快速、批量、自动化地在指定物理机上创建KVM虚拟机并设置相应的网络地址信息,十分省时省力,符合当前的虚拟机创建需求。
以上所述仅为本发明的较佳实施例而已,并非用于限定本发明的保护范围。凡在本发明的精神和原则之内所作的任何修改、等同替换、改进等,均包含在本发明的保护范围内。
Claims (10)
1.一种创建KVM虚拟机的方法,其特征在于,该方法包括:
创建源虚拟机,生成该源虚拟机对应的虚拟机模板镜像文件;
设置用于配置网络地址信息的源Shell脚本;
将所述虚拟机模板镜像文件和所述源Shell脚本保存到指定物理机上;
根据所述虚拟机模板镜像文件在所述指定物理机上创建一个或多个KVM虚拟机;
根据所述源Shell脚本为所创建的每个KVM虚拟机配置相应的网络地址信息。
2.如权利要求1所述的方法,其特征在于,所述根据所述源Shell脚本为所创建的每个KVM虚拟机配置相应的网络地址信息包括:
对于所创建的每个KVM虚拟机,
根据所述源Shell脚本生成该KVM虚拟机对应的Shell脚本;
启动该KVM虚拟机,运行该KVM虚拟机对应的Shell脚本;
利用该KVM虚拟机对应的Shell脚本为该KVM虚拟机配置相应的网络地址信息。
3.如权利要求2所述的方法,其特征在于,所述根据所述源Shell脚本生成该KVM虚拟机对应的Shell脚本包括:
复制所述源Shell脚本;
获取该KVM虚拟机对应的网络地址信息,将所获取的网络地址信息设置到该复制的源Shell脚本中,将经过设置的该复制的源Shell脚本作为该KVM虚拟机对应的Shell脚本。
4.如权利要求1所述的方法,其特征在于,所述根据所述虚拟机模板镜像文件在所述指定物理机上创建一个或多个KVM虚拟机包括:
对于每个待创建的KVM虚拟机,
根据所述虚拟机模板镜像文件生成该KVM虚拟机对应的镜像文件;
根据该KVM虚拟机对应的镜像文件,在所述指定物理机上创建该KVM虚拟机。
5.如权利要求4所述的方法,其特征在于,所述根据所述虚拟机模板镜像文件生成该KVM虚拟机对应的镜像文件包括:
复制所述虚拟机模板镜像文件到指定存储目录,将该复制的虚拟机模板镜像文件中的系统信息删除;
获取该KVM虚拟机对应的参数信息,将所获取的参数信息设置到该复制的虚拟机模板镜像文件中,为该复制的虚拟机模板镜像文件设置主机名和管理员权限;将经过设置的该复制的虚拟机模板镜像文件作为该KVM虚拟机对应的镜像文件。
6.如权利要求5所述的方法,其特征在于,
所述KVM虚拟机对应的参数信息包括:KVM虚拟机的唯一标识,和/或,KVM虚拟机的MAC地址。
7.如权利要求1所述的方法,其特征在于,
所述创建一个源虚拟机,生成该源虚拟机对应的虚拟机模板镜像文件的步骤和所述设置用于配置网络地址信息的源Shell脚本的步骤不是在所述指定物理机上执行的;
则所述将所述虚拟机模板镜像文件和所述源Shell脚本保存到指定物理机上包括:远程登录所述指定物理机,将所述虚拟机模板镜像文件和所述源Shell脚本上传到所述指定物理机的指定文件夹中。
8.一种创建KVM虚拟机的装置,其特征在于,该装置包括:
模板创建单元,用于创建一个源虚拟机,生成该源虚拟机对应的虚拟机模板镜像文件;
脚本设置单元,用于设置用于配置网络地址信息的源Shell脚本;
虚拟机创建单元,适于将所述虚拟机模板镜像文件和所述源Shell脚本保存到指定物理机上;根据所述虚拟机模板镜像文件在所述指定物理机上创建一个或多个KVM虚拟机;根据所述源Shell脚本为所创建的每个KVM虚拟机配置相应的网络地址信息。
9.如权利要求8所述的装置,其特征在于,
所述虚拟机创建单元,用于对于所创建的每个KVM虚拟机,根据所述源Shell脚本生成该KVM虚拟机对应的Shell脚本;启动该KVM虚拟机,运行该KVM虚拟机对应的Shell脚本;利用该KVM虚拟机对应的Shell脚本为该KVM虚拟机配置相应的网络地址信息。
10.如权利要求9所述的装置,其特征在于,
所述虚拟机创建单元,用于复制所述源Shell脚本;获取该KVM虚拟机对应的网络地址信息,将所获取的网络地址信息设置到该复制的源Shell脚本中,将经过设置的该复制的源Shell脚本作为该KVM虚拟机对应的Shell脚本。
Priority Applications (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN201610675508.0A CN107766118A (zh) | 2016-08-16 | 2016-08-16 | 一种创建kvm虚拟机的方法和装置 |
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN201610675508.0A CN107766118A (zh) | 2016-08-16 | 2016-08-16 | 一种创建kvm虚拟机的方法和装置 |
Publications (1)
Publication Number | Publication Date |
---|---|
CN107766118A true CN107766118A (zh) | 2018-03-06 |
Family
ID=61260579
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
CN201610675508.0A Pending CN107766118A (zh) | 2016-08-16 | 2016-08-16 | 一种创建kvm虚拟机的方法和装置 |
Country Status (1)
Country | Link |
---|---|
CN (1) | CN107766118A (zh) |
Cited By (6)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN110032414A (zh) * | 2019-03-06 | 2019-07-19 | 联想企业解决方案(新加坡)有限公司 | 远程控制台模式下安全的用户认证的装置和方法 |
CN110377397A (zh) * | 2019-07-09 | 2019-10-25 | 中信百信银行股份有限公司 | 基于虚机复制的存量应用快速部署扩容的方法 |
CN110502316A (zh) * | 2019-08-26 | 2019-11-26 | 杭州安恒信息技术股份有限公司 | 一种基于kvm平台的测试机配置方法、系统及相关装置 |
CN111459606A (zh) * | 2020-03-03 | 2020-07-28 | 山东汇贸电子口岸有限公司 | 一种虚拟化下快速创建虚拟机的方法及服务器 |
CN113312064A (zh) * | 2021-06-01 | 2021-08-27 | 中国民航信息网络股份有限公司 | 物理机的安装配置方法、装置以及计算机可读介质 |
CN115499413A (zh) * | 2022-08-11 | 2022-12-20 | 福建亿榕信息技术有限公司 | 基于kvm的批量配置虚拟机固定ip地址的方法及系统 |
Citations (4)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US20090328077A1 (en) * | 2008-06-25 | 2009-12-31 | International Business Machines Corporation | Software Appliances not Requiring Virtual Machines |
CN101840346A (zh) * | 2009-12-30 | 2010-09-22 | 北京世纪互联宽带数据中心有限公司 | 云主机部署的方法及系统 |
CN102752137A (zh) * | 2012-06-28 | 2012-10-24 | 用友软件股份有限公司 | 主动设置虚拟机网络参数的装置和方法 |
US8972979B2 (en) * | 2011-03-24 | 2015-03-03 | International Business Machines Corporation | Configuration of virtual appliances |
-
2016
- 2016-08-16 CN CN201610675508.0A patent/CN107766118A/zh active Pending
Patent Citations (4)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US20090328077A1 (en) * | 2008-06-25 | 2009-12-31 | International Business Machines Corporation | Software Appliances not Requiring Virtual Machines |
CN101840346A (zh) * | 2009-12-30 | 2010-09-22 | 北京世纪互联宽带数据中心有限公司 | 云主机部署的方法及系统 |
US8972979B2 (en) * | 2011-03-24 | 2015-03-03 | International Business Machines Corporation | Configuration of virtual appliances |
CN102752137A (zh) * | 2012-06-28 | 2012-10-24 | 用友软件股份有限公司 | 主动设置虚拟机网络参数的装置和方法 |
Non-Patent Citations (2)
Title |
---|
(美)常著: "《转型中的企业云服务》", 31 January 2012 * |
陈少春著: "《计算机存储技术与应用》", 31 December 2014, 电子科技大学出版社 * |
Cited By (10)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN110032414A (zh) * | 2019-03-06 | 2019-07-19 | 联想企业解决方案(新加坡)有限公司 | 远程控制台模式下安全的用户认证的装置和方法 |
CN110032414B (zh) * | 2019-03-06 | 2023-06-06 | 联想企业解决方案(新加坡)有限公司 | 远程控制台模式下安全的用户认证的装置和方法 |
CN110377397A (zh) * | 2019-07-09 | 2019-10-25 | 中信百信银行股份有限公司 | 基于虚机复制的存量应用快速部署扩容的方法 |
CN110377397B (zh) * | 2019-07-09 | 2022-02-18 | 中信百信银行股份有限公司 | 基于虚机复制的存量应用快速部署扩容的方法 |
CN110502316A (zh) * | 2019-08-26 | 2019-11-26 | 杭州安恒信息技术股份有限公司 | 一种基于kvm平台的测试机配置方法、系统及相关装置 |
CN111459606A (zh) * | 2020-03-03 | 2020-07-28 | 山东汇贸电子口岸有限公司 | 一种虚拟化下快速创建虚拟机的方法及服务器 |
CN113312064A (zh) * | 2021-06-01 | 2021-08-27 | 中国民航信息网络股份有限公司 | 物理机的安装配置方法、装置以及计算机可读介质 |
CN113312064B (zh) * | 2021-06-01 | 2024-03-26 | 中国民航信息网络股份有限公司 | 物理机的安装配置方法、装置以及计算机可读介质 |
CN115499413A (zh) * | 2022-08-11 | 2022-12-20 | 福建亿榕信息技术有限公司 | 基于kvm的批量配置虚拟机固定ip地址的方法及系统 |
CN115499413B (zh) * | 2022-08-11 | 2023-10-31 | 福建亿榕信息技术有限公司 | 基于kvm的批量配置虚拟机固定ip地址的方法及系统 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
CN107766118A (zh) | 一种创建kvm虚拟机的方法和装置 | |
US10567397B2 (en) | Security-based container scheduling | |
CN109274722B (zh) | 数据共享方法、装置以及电子设备 | |
US7284043B2 (en) | System and method for automated migration from Linux to Windows | |
CN102752137B (zh) | 主动设置虚拟机网络参数的装置和方法 | |
DE112020002323T5 (de) | Container-first-architektur | |
US9471328B2 (en) | Information processor having program and configuration data stored in different storage areas and reflecting configuration data in operation in program | |
CN109547509B (zh) | 一种跨平台部署的方法和系统 | |
DE102015206764A1 (de) | System und Verfahren zum Verwalten von Softwareaktualisierungen an einem Fahrzeugrechensystem | |
CN107783816A (zh) | 虚拟机的创建方法及装置、大数据集群创建的方法及装置 | |
US20160259933A1 (en) | Information processing system, information processing apparatus, and information processing method | |
TW201250482A (en) | System and method for updating virtual machine templates | |
CN106533753A (zh) | 一种分布式系统的角色配置方法及装置 | |
CN108600282A (zh) | 微服务发布方法、装置、存储介质和计算机设备 | |
US10671334B2 (en) | Print system, print server, management server, and job list providing method | |
BR102017003214A2 (pt) | Métodos para fornecer acesso flexível a dados internos de um sistema aviônico e sistema | |
CN104572227A (zh) | 一种基于安腾平台通过bmc刷新cpld fw方法 | |
DE102021109231A1 (de) | Bedienungssystem installation mechanismus | |
JP6351245B2 (ja) | 画像形成装置及びその制御方法、並びにプログラム | |
CN114024951A (zh) | 一种基于云边协同的电力边缘异构部署方法 | |
CN107608764A (zh) | 一种服务器的迁移方法及迁移装置 | |
WO2020131480A1 (en) | Methods, apparatuses and systems for configuring a network environment for a server | |
JP2019134423A (ja) | コンパクトなセキュリティ証明書 | |
CN103051668B (zh) | 一种服务器资源管理系统及管理方法 | |
CN107734018A (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 | ||
CB02 | Change of applicant information |
Address after: Room 818, 8 / F, 34 Haidian Street, Haidian District, Beijing 100080 Applicant after: BEIJING ULTRAPOWER SOFTWARE Co.,Ltd. Address before: 100089 Beijing city Haidian District wanquanzhuang Road No. 28 Wanliu new building 6 storey block A Room 601 Applicant before: BEIJING ULTRAPOWER SOFTWARE Co.,Ltd. |
|
CB02 | Change of applicant information | ||
RJ01 | Rejection of invention patent application after publication |
Application publication date: 20180306 |
|
RJ01 | Rejection of invention patent application after publication |