天天看点

ovftool自动部署/导出ova/ovf模板

一、简介  

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上使用,具体下载链接见后面。

二、安装

已linux 版本为例:

  下载下来之后,直接sh 运行即可:

<code>root@ubuntu:~</code><code># sh VMware-ovftool-4.1.0-2459827-lin.x86_64.bundle</code>

三、OVA、OVF模板部署

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

<code>root@ubuntu:~</code><code># ovftool --X:logLevel=verbose \ </code>

<code>--X:logFile=</code><code>/root/deploy_log-</code><code>`</code><code>date</code> <code>+%Y%m%d` \</code>

<code> </code><code>--noSSLVerify --acceptAllEulas \</code>

<code> </code><code>-dm=thin  -vf=Templates \</code>

<code> </code><code>-ds=POD01-VOL </code>

<code> </code><code>/data/template/centos/MyTest-CentOS6</code><code>.5-64bit-V1.ova \</code>

<code> </code><code>'vi://username:password@pod01-vcenter/POD01(TEST-POD)/host/POD01-CLU01/pod01-clu01-h001.cdscloud.local'</code>

如果ova/ovf模板网卡里带portgroup,一块网卡用参数:-nw或者--network后跟目标网络;

多个网卡可以用--net指定源和目标portgroup,格式类似--net:source-portgroup=target-portgroup:

例如:

--net:vlan10-pod01-Test-Private=vlan11-pod01-Test-Private

多个网卡使用多个--net指定。

参数详解:

--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文件的位置;

pod01-vcenter是vcenter的名称;

POD01(TEST-POD)是数据中心的名称;

host后面接模板部署目标host位置,CLU01代表集群,pod1-clu01-h001.jx.local是集群下的一台宿主机;

需要注意的是,这里的dns要设置好,或者也可用ip地址代替,比如:

<code>vi</code><code>:</code><code>//username</code><code>:[email protected]/?ip=192.168.100.1'</code>

192.168.1.1是vcenter的地址,192.168.100.1是目标宿主机的ip地址;

这里跟vcenter的连接也可以用http的形式,具体详见官方文档。

四、模板导出

导出成ova/ovf模板的常用命令:

<code>ovftool -o \</code>

<code>--powerOffSource \</code>

<code> </code><code>--acceptAllEulas \</code>

<code> </code><code>--machineOutput \</code>

<code> </code><code>--X:logLevel=verbose \</code>

<code> </code><code>--X:logFile=log.log  \</code>

<code> </code><code>--noSSLVerify  \</code>

<code> </code><code>"vi://username:password@pod01-vcenter/POD01(TEST-POD)/vm/MyTestVM"</code> <code>/root/MyTestVM</code><code>.ova</code>

参数介绍:

-o(--overwrite):如果导出的文件名已存在,强制重写;

--powerOffSource:确保VM在被导出之前处于关机的状态

--machineOutput:以机器可读的格式输出ovftool的信息;

另外需要注意的一点是ovftool导出的文件权限问题,默认是600,建议改成644。

五、自动部署

  如果有多个ova文件,自动部署的时候简单点的加个for循环用shell脚本即可,例如:

<code>#!/bin/bash</code>

<code>filename=`</code><code>find</code> <code>/data/template/</code> <code>-name *.ova`</code>

<code># find all ova template</code>

<code>for</code> <code>ova </code><code>in</code> <code>$filename</code>

<code>do</code>

<code>/usr/bin/ovftool</code> <code>--X:logLevel=verbose --X:logFile=</code><code>/root/ovflog-</code><code>`</code><code>date</code> <code>+%Y%m%d`  --noSSLVerify --acceptAllEulas -dm=thin -vf=Templates -ds=POD1-Template `</code><code>echo</code> <code>$ova` </code><code>'vi://username:password*@MyVC/POD1(MyDC)/host/CLU01/pod1-clu01-h001.jx.local'</code>

<code>continue</code>

<code>done</code>

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

<a href="https://www.vmware.com/support/developer/ovf/ovf410/ovftool-410_userguide.pdf" target="_blank">https://www.vmware.com/support/developer/ovf/ovf410/ovftool-410_userguide.pdf</a>

另外ovftool可在VMware官网下载,下载之前需要先注册账号,下载链接如下:

<a href="https://my.vmware.com/cn/web/vmware/details?downloadGroup=OVFTOOL410&amp;productId=491" target="_blank">https://my.vmware.com/cn/web/vmware/details?downloadGroup=OVFTOOL410&amp;productId=491</a>

      本文转自Jx战壕  51CTO博客,原文链接http://blog.51cto.com/xujpxm/1767701:,如需转载请自行联系原作者

继续阅读