vmware_guest - Manages virtual machines in vCenter
New in version 2.2.
Synopsis
- Create new virtual machines (from templates or not).
- Power on/power off/restart a virtual machine.
- Modify, rename or remove a virtual machine.
Requirements (on host that executes module)
- python >= 2.6
- PyVmomi
Options
| parameter | required | default | choices | comments |
|---|---|---|---|---|
| annotation (added in 2.3)
| no | A note or annotation to include in the VM. | ||
| cluster (added in 2.3)
| no | The cluster name where the VM will run. | ||
| customization (added in 2.3)
| no | Parameters for OS customization when cloning from template. Common parameters (Linux/Windows): - dns_servers (list): List of DNS servers to configure. - dns_suffix (list): List of domain suffixes, aka DNS search path (default: domain parameter). - domain (string): DNS domain name to use. - hostname (string): Computer hostname (default: shorted name parameter).Parameters related to Windows customization: - autologon (bool): Auto logon after VM customization (default: False). - autologoncount (int): Number of autologon after reboot (default: 1). - domainadmin (string): User used to join in AD domain (mandatory with joindomain). - domainadminpassword (string): Password used to join in AD domain (mandatory with joindomain). - fullname (string): Server owner name (default: Administrator). - joindomain (string): AD domain to join (Not compatible with joinworkgroup). - joinworkgroup (string): Workgroup to join (Not compatible with joindomain, default: WORKGROUP). - orgname (string): Organisation name (default: ACME). - password (string): Local administrator password. - productid (string): Product ID. - runonce (list): List of commands to run at first user logon. - timezone (int): Timezone (See https://msdn.microsoft.com/en-us/library/ms912391.aspx). | ||
| customvalues (added in 2.3)
| no | Define a list of customvalues to set on VM. A customvalue object takes 2 fields key and value. | ||
| datacenter | no | ha-datacenter | Destination datacenter for the deploy operation. | |
| disk | no | A list of disks to add. Valid attributes are: - size_[tb,gb,mb,kb] (integer): Disk storage size in specified unit. - type (string): Valid value is thin (default: None). - datastore (string): Datastore to use for the disk. If autoselect_datastore is enabled, filter datastore selection. - autoselect_datastore (bool): select the less used datastore. | ||
| esxi_hostname | no | The ESXi hostname where the VM will run. | ||
| folder | no | /vm | Destination folder, absolute or relative path to find an existing guest or create the new guest. The folder should include the datacenter. ESX's datacenter is ha-datacenter Examples: folder: /ha-datacenter/vm folder: ha-datacenter/vm folder: /datacenter1/vm folder: datacenter1/vm folder: /datacenter1/vm/folder1 folder: datacenter1/vm/folder1 folder: /folder1/datacenter1/vm folder: folder1/datacenter1/vm folder: /folder1/datacenter1/vm/folder2 folder: vm/folder2 folder: folder2 | |
| force | no | no |
| Ignore warnings and complete the actions. |
| guest_id (added in 2.3)
| no | Set the guest ID (Debian, RHEL, Windows...). This field is required when creating a VM. Valid values are referenced here: https://www.vmware.com/support/developer/converter-sdk/conv55_apireference/vim.vm.GuestOsDescriptor.GuestOsIdentifier.html | ||
| hardware | no | Manage some VM hardware attributes. Valid attributes are: - memory_mb (integer): Amount of memory in MB. - num_cpus (integer): Number of CPUs. - scsi (string): Valid values are buslogic, lsilogic, lsilogicsas and paravirtual (default). | ||
| hostname | yes | The hostname or IP address of the vSphere vCenter. | ||
| is_template (added in 2.3)
| no | no |
| Flag the instance as a template. |
| linked_clone (added in 2.4)
| no | no |
| Whether to create a Linked Clone from the snapshot specified. |
| name | yes | Name of the VM to work with. VM names in vCenter are not necessarily unique, which may be problematic, see name_match. | ||
| name_match | no | first |
| If multiple VMs matching the name, use the first or last found. |
| networks (added in 2.3)
| no | A list of networks (in the order of the NICs). One of the below parameters is required per entry: - name (string): Name of the portgroup for this interface. - vlan (integer): VLAN number for this interface.Optional parameters per entry (used for virtual hardware): - device_type (string): Virtual network device (one of e1000, e1000e, pcnet32, vmxnet2, vmxnet3 (default), sriov). - mac (string): Customize mac address.Optional parameters per entry (used for OS customization): - type (string): Type of IP assignment (either dhcp or static). - ip (string): Static IP address (implies type: static). - netmask (string): Static netmask required for ip. - gateway (string): Static gateway. - dns_servers (string): DNS servers for this network interface (Windows). - domain (string): Domain name for this network interface (Windows). | ||
| password | yes | The password of the vSphere vCenter. aliases: pass, pwd | ||
| resource_pool (added in 2.3)
| no | Affect machine to the given resource pool. Resource pool should be child of the selected host parent. | ||
| snapshot_src (added in 2.4)
| no | Name of an existing snapshot to use to create a clone of a VM. | ||
| state | yes |
| What state should the virtual machine be in? If state is set to present and VM exists, ensure the VM configuration conforms to task arguments. | |
| template | no | Template used to create VM. If this value is not set, VM is created without using a template. If the VM exists already this setting will be ignored. | ||
| username | yes | The username of the vSphere vCenter. aliases: user, admin | ||
| uuid | no | UUID of the instance to manage if known, this is VMware's unique identifier. This is required if name is not supplied. | ||
| validate_certs | no | True |
| Allows connection when SSL certificates are not valid. Set to false when certificates are not trusted. |
| wait_for_ip_address | no | no |
| Wait until vCenter detects an IP address for the VM. This requires vmware-tools (vmtoolsd) to properly work after creation. |
Examples
- name: Create a VM from a template
vmware_guest:
hostname: 192.0.2.44
username: [email protected]
password: vmware
validate_certs: no
folder: /testvms
name: testvm_2
state: poweredon
template: template_el7
disk:
- size_gb: 10
type: thin
datastore: g73_datastore
hardware:
memory_mb: 512
num_cpus: 1
scsi: paravirtual
networks:
- name: VM Network
mac: aa:bb:dd:aa:00:14
wait_for_ip_address: yes
delegate_to: localhost
register: deploy
- name: Clone a VM from Template and customize
vmware_guest:
hostname: 192.168.1.209
username: [email protected]
password: vmware
validate_certs: no
datacenter: datacenter1
cluster: cluster
name: testvm-2
template: template_windows
networks:
- name: VM Network
ip: 192.168.1.100
netmask: 255.255.255.0
gateway: 192.168.1.1
mac: aa:bb:dd:aa:00:14
domain: my_domain
dns_servers:
- 192.168.1.1
- 192.168.1.2
- vlan: 1234
type: dhcp
customization:
autologon: yes
dns_servers:
- 192.168.1.1
- 192.168.1.2
domain: my_domain
password: new_vm_password
runonce:
- powershell.exe -ExecutionPolicy Unrestricted -File C:\Windows\Temp\ConfigureRemotingForAnsible.ps1 -ForceNewSSLCert -EnableCredSSP
delegate_to: localhost
- name: Create a VM template
vmware_guest:
hostname: 192.0.2.88
username: [email protected]
password: vmware
validate_certs: no
datacenter: datacenter1
cluster: vmware_cluster_esx
resource_pool: highperformance_pool
folder: /testvms
name: testvm_6
is_template: yes
guest_id: debian6_64Guest
disk:
- size_gb: 10
type: thin
datastore: g73_datastore
hardware:
memory_mb: 512
num_cpus: 1
scsi: lsilogic
delegate_to: localhost
register: deploy
- name: Rename a VM (requires the VM's uuid)
vmware_guest:
hostname: 192.168.1.209
username: [email protected]
password: vmware
uuid: 421e4592-c069-924d-ce20-7e7533fab926
name: new_name
state: present
delegate_to: localhost
- name: Remove a VM by uuid
vmware_guest:
hostname: 192.168.1.209
username: [email protected]
password: vmware
uuid: 421e4592-c069-924d-ce20-7e7533fab926
state: absent
delegate_to: localhost
Return Values
Common return values are documented here Return Values, the following are the fields unique to this module:
| name | description | returned | type | sample |
|---|---|---|---|---|
| instance | metadata about the new virtualmachine | always | dict | None |
Notes
Note
- Tested on vSphere 5.5 and 6.0
Status
This module is flagged as preview which means that it is not guaranteed to have a backwards compatible interface.
For help in developing on modules, should you be so inclined, please read Community Information & Contributing, Testing Ansible and Developing Modules.
© 2012–2018 Michael DeHaan
© 2018–2019 Red Hat, Inc.
Licensed under the GNU General Public License version 3.
https://docs.ansible.com/ansible/2.4/vmware_guest_module.html