Getting Started |
|
The VIX API allows you to automate virtual machine operations on most current VMware platform products.
The VIX API (or “Vix”) is a library for writing scripts and programs to manipulate virtual machines. It is high-level, easy to use, and practical for both script developers and application programmers. The VIX API is designed for three kinds of users:
You can develop VIX API programs on Linux clients or on Microsoft clients (Windows XP and later).
The VIX API supports client programs and scripts written in C, Perl, and COM (Visual Basic, VBscript, C#). For C, a recent version of Visual Studio or Linux libraries, especially libc, is required.
VIX API scripts and programs can perform guest operations on the following guest operating systems:
This VIX API release provides 64-bit libraries for both Windows and Linux, and 64-bit Vix Perl. In the 1.10 release and before, 64-bit Windows systems had to use 32-bit libraries in emulation mode (WoW64), and Vix Perl provided 32-bit support only.
If you want to create a VIX API support request, you first must collect diagnostic information. For instructions, see the knowledge base article Collecting VIX Diagnostic Information.
This release of the VIX API is compatible with VMware Workstation, VMware Player, VMware Server, ESX/ESXi hosts, and vCenter Server.
VIX API Version |
VMware Platform Products |
Library Location |
---|---|---|
1.15.0 |
Workstation 12, Fusion 8, Player 12, or earlier |
Workstation-12.0.0 |
The library location is not important if you use the wrapper library as recommended.
Vix version 1.x supports programs written to version 1.x of the VIX API. Exceptions are noted on function reference pages. For example, VMware Server does not support record and replay, while VMware Workstation does not support virtual machine registration.
Vix libraries are installed with VMware Server and VMware Workstation and provide API compatibility corresponding to the product release. Vix libraries are downward compatible in most cases. If you upgrade VMware Server or VMware Workstation, you should also upgrade any separately installed Vix libraries. For instructions, see Installing the VIX API. You should also upgrade VMware Tools to match the product release.
With vCenter Server, ESX/ESXi hosts, and VMware Server, you run Vix programs remotely. With VMware Workstation, Vix programs usually run on the host.
As noted in the End User License Agreement, the VIX API allows you to build and distribute your own applications. To facilitate this, the following files are designated as redistributable for the purpose of that agreement:
Redistribution of the open source libraries included with the VIX API is governed by their respective open source license agreements.
The VIX API also includes sample code, which you can use as a starting point for your own programs. Code is delivered in the Samples directory installed with VMware VIX. A Makefile is provided for Linux, and an nMakefile for Windows.
On VMware Server and Workstation, you do not need to install any additional VIX API components. Vix libraries are installed by default under “VMware VIX” or vmware-vix. To compile programs on these systems, see Compiling Vix Programs.
To control ESX/ESXi hosts or VMware Server remotely from another machine, you need header files vix.h and vm_basic_types.h, as well as one or more library files. You can get these files in one of two ways:
To install the VIX API files on Windows:
To uninstall the VIX API, go to Start > Settings > Control Panel and use the Add/Remove Programs control panel.
To install the VIX API files on Linux:
wget http://www.vmware.com/downloads/server/VMware-VIX-1.17.0-nnnnnn.i386.bundle
sudo sh VMware-VIX-1.17.0-nnnnnn.i386.bundle
To uninstall the VIX API on Linux, run the following program:
sudo vmware-installer -u vmware-vix
If you are using older Vix libraries, VMware recommends that you upgrade those libraries using the standalone installer. The standalone installer provides a current version of the wrapper library, which allows programs to communicate with any Vix library, regardless of version or target architecture. The wrapper library dynamically loads appropriate library files at connection time.
Otherwise you must link your program to a Vix library that matches the server version. This gets inconvenient if your program communicates with more than one version of the server.
VMware Tools in virtual machines should be kept up-to-date with the VMware version on the host. When upgrading, also update VMware Tools in all guest operating systems. The VIX API relies on a current matching version of VMware Tools to perform many operations.
Upgrading the Vix libraries replaces the older header files, vix.h and vm_basic_types.h with newer header files. The header files are installed at the following locations by default:
Whether or not you use the wrapper library, your programs may call only the functions supported by the host. If you communicate with an older host, you cannot use newer features.
On Windows, the sample programs are installed in C:\Program Files\VMware\VMware VIX\Samples by default. An nMakefile is provided to compile all sample programs using nmake and the Visual Studio C compiler.
On Linux, the sample programs are installed in /usr/share/doc/vmware-vix/VMwareVix/samples/ by default. A Makefile is provided to compile all sample programs using make and the GNU C compiler.
Vix includes a wrapper library, which enables Vix programs to work with multiple supported VMware products and versions. If you link your program with this library, it dynamically loads the appropriate Vix library for a VMware product at runtime, during the VixHost_Connect() call. VMware recommends that you use the wrapper library, although you can compile Vix programs without it.
For Windows, both a static version and a dynamic version of the wrapper library are provided. The static version of the wrapper library is built with Visual Studio 2008 SP1, and requires use of the same Visual Studio release to build and link your application. For Visual Studio 2008 and later releases, the dynamic version of the wrapper library can be used to build your application.
To compile code on Windows with Visual Studio 2008 SP1 using the static wrapper library, follow this procedure. Files are in the C:\Program Files\VMware\VMware VIX folder.
#include "vix.h"
... program code here ...
To compile code on Windows with Visual Studio 2008 or later using the dynamic wrapper library, follow this procedure. Files are in the C:\Program Files\VMware\VMware VIX folder.
#include "vix.h"
... program code here ...
This procedure assumes that you have installed Vix components in the default directories. If you made different choices during the installation, specify your directory choices instead.
#include "vix.h"
... program code here ...
$ gcc -I/usr/include/vmware-vix vixapp.c -o vixapp -lvixAllProducts -ldl -lpthread
If you do not use the wrapper, you need to link the appropriate Vix libraries for the VMware product to which your Vix program connects. Workstation is able to link a debug version of the C runtime library.
To compile your code for use with Workstation 7.1:
#include "vix.h"
... program code here ...
To compile your code for use with Workstation 6.0.x:
#include "vix.h"
... program code here ...
To compile your code for use with VMware Server 1.0:
#include "vix.h"
... program code here ...
To compile your code with VMware Server or VMware Workstation installed:
#include "vix.h"
... program code here ...
gcc -I/usr/include/vmware-vix -o vixapp vixapp.c /usr/lib/vmware-vix/Workstation-7.1.0/32bit/libvix.so
gcc -I/usr/include/vmware-vix -o vixapp vixapp.c /usr/lib/vmware-vix/lib/VIServer-2.0.0/32bit/libvix.so
gcc -I/usr/include/vmware-vix -o vixapp vixapp.c /usr/lib/vmware-vix/lib/server-1/32bit/libvix.so