简介  

OVF(Open Virtualization Format)是多家虚拟化厂商和硬件厂商共同定义的一个虚拟设备的规范,ovf格式的虚拟设备(其实就是一些文件)可以被多家虚拟化软件设备并import到虚拟化环境,比如VMware、XenServer、VirtualBox等等。OVF一般有几个部分组成,分别是ovf文件、mf文件、cert文件、vmdk文件和iso文件。OVF(Open Virtualization Format:开放虚拟化格式 )和OVA(Open Virtualization Appliance:开放虚拟化设备),两者包含所有用于部署虚拟机的必要信息。现在很多软件厂商经常将一个应用直接打包成ovf或ova格式的虚拟设备提供给用户导入到虚拟化环境,比如VMware、Riverbed等等很多公司都有产品通过这种方式发布,这方便了用户部署。

VMware提供ovf、ova模板的部署和导出功能,在手动部署的时候有时会出现无法部署或者部署过程中出错的情况,尤其在大文件部署的时候突然中断很是让人头疼,这里介绍一个工具:ovftool。官网提供多个版本的下载,建议在linux和mac上使用,具体下载链接见后面。

安装

VMware官网下载,下载之前需要先注册账号,下载链接如下:

https://my.vmware.com/cn/web/vmware/details?downloadGroup=OVFTOOL410&productId=491

以ubantu为例:

#下载下来之后,直接sh 运行即可:
root@ubuntu:~# sh VMware-ovftool-4.1.0-2459827-lin.x86_64.bundle

centos详细安装过程:

1、将光盘挂载到系统/mnt目录下。

[root@localhost ~]# mount -t iso9660 /dev/cdrom /mnt

2、将VMware Tools安装包“VMwareTools-9.10.0-2476743.tar.gz”复制到/root目录下

[root@localhost ~]# cp /mnt/cdrom/VMwareTools-9.10.0-2476743.tar.gz /root  

3、将文件解压,解压后的目录为“vmware-tools-distrib”

[root@localhost ~]# tar -xzf VMwareTools-9.10.0-2476743.tar.gz

4、安装程序,位于vmware-tools-distrib的目录,进入到该目录执行安装程序

[root@localhost ~]# cd vmware-tools-distrib

[root@localhost vmware-tools-distrib]# ./vmware-install.pl

如果出现错误“-bash: ./vmware-install.pl: /usr/bin/per: bad interpreter: No such file or directory”表明未安装语言环境,安装程序是perl语言,需要安装perl环境。

[root@localhost vmware-tools-distrib]# yum -y install perl

perl安装完成之后,再执行/vmware-install.pl安装,根据提示应答安装(基本一路回车)。
5、其它问题:在安装vmware tool的过程中,出现如下提示:

What is the location of the "ifconfig" program on your machine?

此处回车不行,安装程序检测系统有没有“ifconfig”命令工具,VMware Tools 对网络的管理需要该工具,可以输入“yes”跳过检查,继续进行安装。

Yum安装ifconfig(建议在安装VMware Tools 之前安装好):
[root@localhost vmware-tools-distrib]#  yum install net-tools

6、如需卸载VMware Tools,输入/usr/bin/vmware-uninstall-tools.pl即可。

  

使用

OVA/OVF模板部署

ovftool安装完即可用,其userguide文档里提供了很多可选参数,下面是我实际使用过程中用的一个语法,基本包含了可能会用到的几个参数:

ova文件导入到 Vcente#将ova文件导入到 Vcenter

ovftool --X:logLevel=verbose 
--X:logFile=/root/deploy.log 
--noSSLVerify --acceptAllEulas 
-dm=thin -vf=Templates 
-ds=POD01-VOL 
/data/template/centos/CentOS6.5-64bit.ova 
"vi://username:password@Vcenter/host/Host_Name/Host_import_name"

参数详解:
--X:logLevel:定义log的级别;
--X:logFile:定义log文件位置,以日期的格式命名;
--noSSLVerify:跳过vSphere连接的SSL认证;
--acceptAllEulas:接受所有用户的licenses;
-dm(--diskMode): 磁盘类型,一般选用thin置备,如果不加此参数,默认硬盘厚置备类型;
-vf(--vmFolder):模板部署的目标目录(即文件夹),我这里假设要部署到Templates目录下面;
-ds(--datastore):模板部署的目标存储位置
vi://:全称”VMware Infrastructure“

用来和数据中心通信的命令行选项,最早是ESX 3版本的一个术语。
格式:”username:password@vcenter名称/数据中心名称/host/指定host“;也可以只指定到cluster。

参数解释:
/data/template/centos/MyTest-CentOS6.5-64bit-V1.ova 是ova文件的位置;及需要导入的voa镜像模板
pod01-vcenter是vcenter的名称;
POD01(TEST-POD)是数据中心的名称;
host后面接模板部署目标host位置,CLU01代表集群,pod1-clu01-h001.jx.local是集群下的一台宿主机;
需要注意的是,这里的dns要设置好,或者也可用ip地址代替,
例如:
vi://username:password@192.168.1.1/?ip=192.168.100.1'
192.168.1.1是vcenter的地址,192.168.100.1是目标宿主机的ip地址
这里跟vcenter的连接也可以用http的形式,具体详见官方文档。


注意:
如果ova/ovf模板网卡里带portgroup
一块网卡用参数:-nw或者--network后跟目标网络;
多个网卡可以用--net指定源和目标portgroup,
格式类似--net:source-portgroup=target-portgroup:

例如:
--net:vlan10-pod01-Test-Private=vlan11-pod01-Test-Private
多个网卡使用多个--net指定。

  

Vcenter导出ova文件 

#导出ova模板文件
ovftool -o 
--powerOffSource 
--acceptAllEulas 
--machineOutput 
--X:logLevel=verbose 
--X:logFile=log.log 
--noSSLVerify 
"vi://username:password@vcenter/datecenter /vm/vmName" /root/vmName.ova

参数解释 -o(--overwrite):如果导出的文件名已存在,强制重写; --powerOffSource:确保VM在被导出之前处于关机的状态; --machineOutput:以机器可读的格式输出ovftool的信息; 注意: 另外需要注意的一点是ovftool导出的文件权限问题,默认是600,建议改成644。 #跨vcenter版本时导出需添加参数--noNvramFile 

官方文档

以下是目前的官方文档链接:

https://www.vmware.com/support/developer/ovf/ovf410/ovftool-410_userguide.pdf

补充说明

批量从vcenter导出脚本

#/bin//bash
for i  in `cat /data/gms/bash/1.txt`
do
ovftool -o --powerOffSource --acceptAllEulas --machineOutput --X:logLevel=verbose --X:logFile=/data/gms/log/$i.log --noSSLVerify "vi://username:password@pod01-vcenter.vsphere.local/POD01(MyDC)/host/SystemTemplates/$i" /data/gms/$i.ova
done

批量将模板导入vcenter

#!/bin/bash
filename=`find /data/gms/ -name *.ova`
# find all ova template
for ova in $filename
do
/usr/bin/ovftool --X:logLevel=verbose --X:logFile=/root/ovflog-`date +%Y%m%d`  --noSSLVerify --acceptAllEulas -dm=thin -vf=Templates -ds=POD1-Template `echo $ova` 'vi://username:password@MyVC/POD01(MyDC)/host/CLU01/pod1-clu01-h001.jx.local'
continue
done