How to Use the vSphere Guest API
How to Use the vSphere Guest API
The vSphere Guest API defines functions and data types that you use to extract virtual machine data. This section covers the following topics:vSphere Guest API Runtime Components
To use the vSphere Guest API, the runtime components must be installed in the guest operating system. The runtime components are dynamically loaded binary modules for 32-bit and 64-bit guests. When you install VMware Tools, the vSphere Guest API runtime components are installed automatically. You can also download them from http://www.vmware.com/download/sdk/guest_sdk.html.To make the vSphere Guest API functions available to your program, use your program’s standard methods to load the library.
vSphere Guest API Data Types
The vSphere Guest API uses the data types listed in Data Types to support access to virtual machine data.
vSphere Guest API Functions
The vSphere Guest SDK contains the header file vmGuestLib.h. This file declares the functions and data types that you use to call the vSphere Guest API. The following sections describe the vSphere Guest API functions:Context FunctionsThe vSphere Guest API provides a set of functions that initialize and manipulate the context in which the Guest API operates. Before your application can use the accessor functions to retrieve information about a virtual machine, use the following functions to initialize the vSphere Guest API environment.
VMGuestLibHandle handle,
size_t *bufferSize,
char *pathBuffer );handle is an input parameter specifying the guest library handle.bufferSize is an input/output parameter. It is a pointer to the size of the pathBuffer in bytes. If bufferSize is not large enough to accommodate the path (including a NULL terminator), the function returns VMGUESTLIB_ERROR_BUFFER_TOO_SMALL. In this case, the function uses the bufferSize parameter to return the number of bytes required for the string.pathBuffer is an output parameter. It is a pointer to a buffer that receives the resource pool path string. The path string is NULL-terminated.For information about using resource pools, see the vSphere Resource Management Guide.For more information about ESX resource management, see the vSphere Resource Management Guide, available on the VMware Web site.Limits and ReservationsYou use the Guest API to retrieve information about limits and reservations for CPU and memory. To set limits and reservations, you can use either the vSphere Client or the vSphere API. Setting limits and reservations on a virtual machine ensures that resources are available to that machine and to other virtual machines that draw resources from the same resource pool.To use the vSphere Client to set limits or reservations:
vSphere Guest API Error Codes
Each vSphere Guest API function returns an error code. If successful, the returned error code is VMGUESTLIB_ERROR_SUCCESS. If the function is unable to complete its task, the error code provides information for diagnosing the problem.Use the VMGuestLib_GetErrorText function to retrieve the error text associated with a particular error code. When you call the function, pass the error code to the function; VMGuestLib_GetErrorText returns a pointer to a string containing the error text.Example: Error Handling shows error handling. The C code fragment declares a guest library handle and calls the function VMGuestLib_OpenHandle. If the call is not successful, the code calls VMGuestLib_GetErrorText and displays the error text.Example: Error HandlingVMGuestLibHandle glHandle;glError = VMGuestLib_OpenHandle(&glHandle);if (glError != VMGUESTLIB_ERROR_SUCCESS) {printf("OpenHandle failed: %s\n", VMGuestLib_GetErrorText(glError));}Error Codes lists all error codes defined for the vSphere Guest API.
Help us improve this information. Send feedback to [email protected].
