This resource manages a Proxmox VM Qemu container.
You can start from either an ISO, PXE boot the VM, or clone an existing VM. Optimally, you could create a VM resource you will use a clone base with an ISO, and make the rest of the VM resources depend on that base "template" and clone it.
When creating a VM Qemu resource, you create a proxmox_vm_qemu
resource block. For ISO and clone
modes, the name and target node of the VM are the only required parameters.
For the PXE mode, the boot
directive must contain a Network in its boot order. Generally, PXE
boot VMs should NOT contain the Agent config (agent = 1
). PXE boot mode also requires external
infrastructure to support the Network PXE boot request by the VM.
resource "proxmox_vm_qemu" "resource-name" {
name = "VM-name"
target_node = "Node to create the VM on"
iso = "ISO file name"
### or for a Clone VM operation
# clone = "template to clone"
### or for a PXE boot VM operation
# pxe = true
# boot = "scsi0;net0"
# agent = 0
}
With preprovision, you can provision a VM directly from the resource block. This provisioning method is therefore ran **
before** provision blocks. When using preprovision, there are three os_type
options: ubuntu
, centos
or cloud-init
.
resource "proxmox_vm_qemu" "preprovision-test" {
preprovision = true
os_type = "ubuntu"
}
There is a pre-provision phase which is used to set a hostname, initialize eth0, and resize the VM disk to available
space. This is done over SSH with the ssh_forward_ip
, ssh_user
and ssh_private_key
. Disk resize is done if the
file /etc/auto_resize_vda.sh
exists.
resource "proxmox_vm_qemu" "preprovision-test" {
preprovision = true
os_type = "ubuntu"
ssh_forward_ip = "10.0.0.1"
ssh_user = "terraform"
ssh_private_key = <<EOF
-----BEGIN RSA PRIVATE KEY-----
private ssh key terraform
-----END RSA PRIVATE KEY-----
EOF
os_network_config = <<EOF
auto eth0
iface eth0 inet dhcp
EOF
connection {
type = "ssh"
user = "${self.ssh_user}"
private_key = "${self.ssh_private_key}"
host = "${self.ssh_host}"
port = "${self.ssh_port}"
}
}
Cloud-init VMs must be cloned from a cloud-init ready template. When
creating a resource that is using Cloud-Init, there are multi configurations possible. You can use either the cicustom
parameter to create based
on a Cloud-init configuration file or use the Proxmox
variable ciuser
, cipassword
, ipconfig0
, ipconfig1
, ipconfig2
, ipconfig3
, ipconfig4
, ipconfig5
,
ipconfig6
, ipconfig7
, ipconfig8
, ipconfig9
, ipconfig10
, ipconfig11
, ipconfig12
, ipconfig13
,
ipconfig14
,ipconfig15
, searchdomain
, nameserver
and sshkeys
.
For more information, see the Cloud-init guide.
Specifying the pxe = true
option will enable the Virtual Machine to perform a Network Boot (PXE).
In addition to enabling the PXE mode, a few other options should be specified to ensure successful
boot of the VM. A minimal Resource stanza for a PXE boot VM might look like this:
resource "proxmox_vm_qemu" "pxe-minimal-example" {
name = "pxe-minimal-example"
agent = 0
boot = "order=net0;scsi0"
pxe = true
target_node = "test"
network {
bridge = "vmbr0"
firewall = false
link_down = false
model = "e1000"
}
}
The primary options that effect the correct operation of Network PXE boot mode are:
boot
: a valid boot order must be specified with Network type included (egorder=net0;scsi0
)- a valid NIC attached to a network with a PXE boot server must be added to the VM
- generally speaking, disable the Agent (
agent = 0
) unless the installed OS contains the Agent in OS install configurations
Note: Except where explicitly stated in the description, all arguments are assumed to be optional.
The following arguments are supported in the top level resource block.
Argument | Type | Default Value | Description |
---|---|---|---|
name |
str |
Required The name of the VM within Proxmox. | |
target_node |
str |
Required The name of the Proxmox Node on which to place the VM. | |
vmid |
int |
0 |
The ID of the VM in Proxmox. The default value of 0 indicates it should use the next available ID in the sequence. |
desc |
str |
The description of the VM. Shows as the 'Notes' field in the Proxmox GUI. | |
define_connection_info |
bool |
true |
Whether to let terraform define the (SSH) connection parameters for preprovisioners, see config block below. |
bios |
str |
"seabios" |
The BIOS to use, options are seabios or ovmf for UEFI. |
onboot |
bool |
false |
Whether to have the VM startup after the PVE node starts. |
startup |
string |
"" |
The startup and shutdown behaviour |
oncreate |
bool |
true |
Whether to have the VM startup after the VM is created. |
tablet |
bool |
true |
Enable/disable the USB tablet device. This device is usually needed to allow absolute mouse positioning with VNC. |
boot |
str |
The boot order for the VM. For example: order=scsi0;ide2;net0 . The deprecated legacy= syntax is no longer supported. See the boot option in the Proxmox manual for more information. |
|
bootdisk |
str |
Enable booting from specified disk. You shouldn't need to change it under most circumstances. | |
agent |
int |
0 |
Set to 1 to enable the QEMU Guest Agent. Note, you must run the qemu-guest-agent daemon in the guest for this to have any effect. |
iso |
str |
The name of the ISO image to mount to the VM in the format: [storage pool]:iso/[name of iso file]. Only applies when clone is not set. Either clone or iso needs to be set. Note that iso is mutually exclussive with clone and pxe modes. |
|
pxe |
bool |
false |
If set to true , enable PXE boot of the VM. Also requires a boot order be set with Network included (eg boot = "order=net0;scsi0" ). Note that pxe is mutually exclusive with iso and clone modes. |
clone |
str |
The base VM from which to clone to create the new VM. Note that clone is mutually exclussive with pxe and iso modes. |
|
full_clone |
bool |
true |
Set to true to create a full clone, or false to create a linked clone. See the docs about cloning for more info. Only applies when clone is set. |
hastate |
str |
Requested HA state for the resource. One of "started", "stopped", "enabled", "disabled", or "ignored". See the docs about HA for more info. | |
hagroup |
str |
The HA group identifier the resource belongs to (requires hastate to be set!). See the docs about HA for more info. |
|
qemu_os |
str |
"l26" |
The type of OS in the guest. Set properly to allow Proxmox to enable optimizations for the appropriate guest OS. It takes the value from the source template and ignore any changes to resource configuration parameter. |
memory |
int |
512 |
The amount of memory to allocate to the VM in Megabytes. |
balloon |
int |
0 |
The minimum amount of memory to allocate to the VM in Megabytes, when Automatic Memory Allocation is desired. Proxmox will enable a balloon device on the guest to manage dynamic allocation. See the docs about memory for more info. |
sockets |
int |
1 |
The number of CPU sockets to allocate to the VM. |
cores |
int |
1 |
The number of CPU cores per CPU socket to allocate to the VM. |
vcpus |
int |
0 |
The number of vCPUs plugged into the VM when it starts. If 0 , this is set automatically by Proxmox to sockets * cores . |
cpu |
str |
"host" |
The type of CPU to emulate in the Guest. See the docs about CPU Types for more info. |
numa |
bool |
false |
Whether to enable Non-Uniform Memory Access in the guest. |
hotplug |
str |
"network,disk,usb" |
Comma delimited list of hotplug features to enable. Options: network , disk , cpu , memory , usb . Set to 0 to disable hotplug. |
scsihw |
str |
"lsi" |
The SCSI controller to emulate. Options: lsi , lsi53c810 , megasas , pvscsi , virtio-scsi-pci , virtio-scsi-single . |
pool |
str |
The resource pool to which the VM will be added. | |
tags |
str |
Tags of the VM. This is only meta information. | |
force_create |
bool |
false |
If false , and a vm of the same name, on the same node exists, terraform will attempt to reconfigure that VM with these settings. Set to true to always create a new VM (note, the name of the VM must still be unique, otherwise an error will be produced.) |
os_type |
str |
Which provisioning method to use, based on the OS type. Options: ubuntu , centos , cloud-init . |
|
force_recreate_on_change_of |
str |
If the value of this string changes, the VM will be recreated. Useful for allowing this resource to be recreated when arbitrary attributes change. An example where this is useful is a cloudinit configuration (as the cicustom attribute points to a file not the content). |
|
os_network_config |
str |
Only applies when define_connection_info is true. Network configuration to be copied into the VM when preprovisioning ubuntu or centos guests. The specified configuration is added to /etc/network/interfaces for Ubuntu, or /etc/sysconfig/network-scripts/ifcfg-eth0 for CentOS. Forces re-creation on change. |
|
ssh_forward_ip |
str |
Only applies when define_connection_info is true. The IP (and optional colon separated port), to use to connect to the host for preprovisioning. If using cloud-init, this can be left blank. |
|
ssh_user |
str |
Only applies when define_connection_info is true. The user with which to connect to the guest for preprovisioning. Forces re-creation on change. |
|
ssh_private_key |
str |
Only applies when define_connection_info is true. The private key to use when connecting to the guest for preprovisioning. Sensitive. |
|
ci_wait |
int |
30 |
How to long in seconds to wait for before provisioning. |
ciuser |
str |
Override the default cloud-init user for provisioning. | |
cipassword |
str |
Override the default cloud-init user's password. Sensitive. | |
cicustom |
str |
Instead specifying ciuser, cipasword, etc... you can specify the path to a custom cloud-init config file here. Grants more flexibility in configuring cloud-init. | |
cloudinit_cdrom_storage |
str |
Set the storage location for the cloud-init drive. Required when specifying cicustom . |
|
searchdomain |
str |
Sets default DNS search domain suffix. | |
nameserver |
str |
Sets default DNS server for guest. | |
sshkeys |
str |
Newline delimited list of SSH public keys to add to authorized keys file for the cloud-init user. | |
ipconfig0 |
str |
The first IP address to assign to the guest. Format: [gw=<GatewayIPv4>] [,gw6=<GatewayIPv6>] [,ip=<IPv4Format/CIDR>] [,ip6=<IPv6Format/CIDR>] . |
|
ipconfig1 to ipconfig15 |
str |
The second IP address to assign to the guest. Same format as ipconfig0 . |
|
automatic_reboot |
bool |
true |
Automatically reboot the VM when parameter changes require this. If disabled the provider will emit a warning when the VM needs to be rebooted. |
The vga
block is used to configure the display device. It may be specified multiple times, however only the first
instance of the block will be used.
See the docs about display for more details.
Argument | Type | Default Value | Description |
---|---|---|---|
type |
str |
"std" |
The type of display to virtualize. Options: cirrus , none , qxl , qxl2 , qxl3 , qxl4 , serial0 , serial1 , serial2 , serial3 , std , virtio , vmware . |
memory |
int |
Sets the VGA memory (in MiB). Has no effect with serial display type. |
The network
block is used to configure the network devices. It may be specified multiple times. The order in which the
blocks are specified determines the ID for each net device. i.e. The first network
block will become net0
, the
second will be net1
etc...
See the docs about network devices for more details.
Argument | Type | Default Value | Description |
---|---|---|---|
model |
str |
Required Network Card Model. The virtio model provides the best performance with very low CPU overhead. If your guest does not support this driver, it is usually best to use e1000. Options: e1000 , e1000-82540em , e1000-82544gc , e1000-82545em , i82551 , i82557b , i82559er , ne2k_isa , ne2k_pci , pcnet , rtl8139 , virtio , vmxnet3 . |
|
macaddr |
str |
Override the randomly generated MAC Address for the VM. Requires the MAC Address be Unicast. | |
bridge |
str |
"nat" |
Bridge to which the network device should be attached. The Proxmox VE standard bridge is called vmbr0 . |
tag |
int |
-1 |
The VLAN tag to apply to packets on this device. -1 disables VLAN tagging. |
firewall |
bool |
false |
Whether to enable the Proxmox firewall on this network device. |
rate |
int |
0 |
Network device rate limit in mbps (megabytes per second) as floating point number. Set to 0 to disable rate limiting. |
queues |
int |
1 |
Number of packet queues to be used on the device. Requires virtio model to have an effect. |
link_down |
bool |
false |
Whether this interface should be disconnected (like pulling the plug). |
The disks
block is used to configure the disk devices. It may be specified once. There are four types of disk ide
,sata
,scsi
and virtio
. Configuration for these sub types can be found in their respective chapters:
cdrom
: Disks.x.Cdrom Block.disk
: Disks.x.Disk Block.passthrough
: Disks.x.Passthrough Block.
resource "proxmox_vm_qemu" "resource-name" {
//<arguments omitted for brevity...>
disks {
ide {
//<arguments omitted for brevity...>
}
sata {
//<arguments omitted for brevity...>
}
scsi {
//<arguments omitted for brevity...>
}
virtio {
//<arguments omitted for brevity...>
}
}
}
The disks.ide
block is used to configure disks of type ide. It may only be specified once. It has the options ide0
through ide1
. Each disk can have only one of the following mutually exclusive sub types cdrom
, disk
, passthrough
. Configuration for these sub types can be found in their respective chapters:
cdrom
: Disks.x.Cdrom Block.disk
: Disks.x.Disk Block.passthrough
: Disks.x.Passthrough Block.
resource "proxmox_vm_qemu" "resource-name" {
//<arguments omitted for brevity...>
disks {
ide {
ide0 {
disk {
//<arguments omitted for brevity...>
}
}
ide1 {
passthrough {
//<arguments omitted for brevity...>
}
}
}
//<arguments omitted for brevity...>
}
}
The disks.sata
block is used to configure disks of type sata. It may only be specified once. It has the options sata0
through sata5
. Each disk can have only one of the following mutually exclusive sub types cdrom
, disk
, passthrough
. Configuration for these sub types can be found in their respective chapters:
cdrom
: Disks.x.Cdrom Block.disk
: Disks.x.Disk Block.passthrough
: Disks.x.Passthrough Block.
resource "proxmox_vm_qemu" "resource-name" {
//<arguments omitted for brevity...>
disks {
sata {
sata0 {
cdrom {
//<arguments omitted for brevity...>
}
}
sata1 {
disk {
//<arguments omitted for brevity...>
}
}
sata2 {
passthrough {
//<arguments omitted for brevity...>
}
}
//<arguments omitted for brevity...>
}
//<arguments omitted for brevity...>
}
}
The disks.scsi
block is used to configure disks of type scsi. It may only be specified once. It has the options scsi0
through scsi30
. Each disk can have only one of the following mutually exclusive sub types cdrom
, disk
, passthrough
. Configuration for these sub types can be found in their respective chapters:
cdrom
: Disks.x.Cdrom Block.disk
: Disks.x.Disk Block.passthrough
: Disks.x.Passthrough Block.
resource "proxmox_vm_qemu" "resource-name" {
//<arguments omitted for brevity...>
disks {
scsi {
scsi0 {
cdrom {
//<arguments omitted for brevity...>
}
}
scsi1 {
disk {
//<arguments omitted for brevity...>
}
}
scsi2 {
passthrough {
//<arguments omitted for brevity...>
}
}
//<arguments omitted for brevity...>
}
//<arguments omitted for brevity...>
}
}
The disks.scsi
block is used to configure disks of type scsi. It may only be specified once. It has the options virtio0
through virtio15
. Each disk can have only one of the following mutually exclusive sub types cdrom
, disk
, passthrough
. Configuration for these sub types can be found in their respective chapters:
cdrom
: Disks.x.Cdrom Block.disk
: Disks.x.Disk Block.passthrough
: Disks.x.Passthrough Block.
resource "proxmox_vm_qemu" "resource-name" {
//<arguments omitted for brevity...>
disks {
virtio {
virtio0 {
cdrom {
//<arguments omitted for brevity...>
}
}
virtio1 {
disk {
//<arguments omitted for brevity...>
}
}
virtio2 {
passthrough {
//<arguments omitted for brevity...>
}
}
//<arguments omitted for brevity...>
}
//<arguments omitted for brevity...>
}
}
Argument | Type | Default Value | Description |
---|---|---|---|
iso |
str |
The name of the ISO image to mount to the VM in the format: [storage pool]:iso/[name of iso file]. Note that iso is mutually exclusive with passthrough . |
|
passthrough |
bool |
false |
Wether the physical cdrom drive should be passed through. |
When iso
and passthrough
are omitted an empty cdrom drive will be created.
See the docs about disks for more details.
Argument | Type | Default Value | Disk Types | Description |
---|---|---|---|---|
asyncio |
str |
all |
The drive's asyncio setting. Options: io_uring , native , threads |
|
backup |
bool |
true |
all |
Whether the drive should be included when making backups. |
cache |
str |
all |
The drive’s cache mode. Options: directsync , none , unsafe , writeback , writethrough . |
|
discard |
bool |
false |
all |
Controls whether to pass discard/trim requests to the underlying storage. Only effective when the underlying storage supports thin provisioning. There are other caveats too, see the docs about disks for more info. |
emulatessd |
bool |
false |
ide , sata , scsi |
Whether to expose this drive as an SSD, rather than a rotational hard disk. |
format |
str |
raw |
all |
The drive’s backing file’s data format. |
id |
int |
all |
Computed Unique id of the disk. | |
iops_r_burst |
int |
0 |
all |
Maximum number of iops while reading in short bursts. 0 means unlimited. |
iops_r_burst_length |
int |
0 |
all |
Length of the read burst duration in seconds. 0 means the default duration dictated by proxmox. |
iops_r_concurrent |
int |
0 |
all |
Maximum number of iops while reading concurrently. 0 means unlimited. |
iops_wr_burst |
int |
0 |
all |
Maximum number of iops while writing in short bursts. 0 means unlimited. |
iops_wr_burst_length |
int |
0 |
all |
Length of the write burst duration in seconds. 0 means the default duration dictated by proxmox. |
iops_wr_concurrent |
int |
0 |
all |
Maximum number of iops while writing concurrently. 0 means unlimited. |
iothread |
bool |
false |
scsi , virtio |
Whether to use iothreads for this drive. Only effective when the the emulated controller type (scsihw top level block argument) is virtio-scsi-single . |
linked_disk_id |
int |
all |
Computed The vmid of the linked vm this disk was cloned from. |
|
mbps_r_burst |
float |
0.0 |
all |
Maximum read speed in megabytes per second. 0 means unlimited. |
mbps_r_concurrent |
float |
0.0 |
all |
Maximum read speed in megabytes per second. 0 means unlimited. |
mbps_wr_burst |
float |
0.0 |
all |
Maximum write speed in megabytes per second. 0 means unlimited. |
mbps_wr_concurrent |
float |
0.0 |
all |
Maximum throttled write pool in megabytes per second. 0 means unlimited. |
readonly |
bool |
false |
scsi , virtio |
Whether the drive should be readonly. |
replicate |
bool |
false |
all |
Whether the drive should considered for replication jobs. |
serial |
str |
all |
The serial number of the disk. | |
size |
int |
all |
Required The size of the created disk in Gigabytes. | |
storage |
str |
all |
Required The name of the storage pool on which to store the disk. |
See the docs about disks for more details.
Argument | Type | Default Value | Disk Types | Description |
---|---|---|---|---|
asyncio |
str |
all |
The drive's asyncio setting. Options: io_uring , native , threads |
|
backup |
bool |
true |
all |
Whether the drive should be included when making backups. |
cache |
str |
all |
The drive’s cache mode. Options: directsync , none , unsafe , writeback , writethrough . |
|
discard |
bool |
false |
all |
Controls whether to pass discard/trim requests to the underlying storage. Only effective when the underlying storage supports thin provisioning. There are other caveats too, see the docs about disks for more info. |
emulatessd |
bool |
false |
ide , sata , scsi |
Whether to expose this drive as an SSD, rather than a rotational hard disk. |
file |
str |
all |
Required The full unix file path to the disk. | |
iops_r_burst |
int |
0 |
all |
Maximum number of iops while reading in short bursts. 0 means unlimited. |
iops_r_burst_length |
int |
0 |
all |
Length of the read burst duration in seconds. 0 means the default duration dictated by proxmox. |
iops_r_concurrent |
int |
0 |
all |
Maximum number of iops while reading concurrently. 0 means unlimited. |
iops_wr_burst |
int |
0 |
all |
Maximum number of iops while writing in short bursts. 0 means unlimited. |
iops_wr_burst_length |
int |
0 |
all |
Length of the write burst duration in seconds. 0 means the default duration dictated by proxmox. |
iops_wr_concurrent |
int |
0 |
all |
Maximum number of iops while writing concurrently. 0 means unlimited. |
iothread |
bool |
false |
scsi , virtio |
Whether to use iothreads for this drive. Only effective when the the emulated controller type (scsihw top level block argument) is virtio-scsi-single . |
mbps_r_burst |
float |
0.0 |
all |
Maximum read speed in megabytes per second. 0 means unlimited. |
mbps_r_concurrent |
float |
0.0 |
all |
Maximum read speed in megabytes per second. 0 means unlimited. |
mbps_wr_burst |
float |
0.0 |
all |
Maximum write speed in megabytes per second. 0 means unlimited. |
mbps_wr_concurrent |
float |
0.0 |
all |
Maximum throttled write pool in megabytes per second. 0 means unlimited. |
readonly |
bool |
false |
scsi , virtio |
Whether the drive should be readonly. |
replicate |
bool |
false |
all |
Whether the drive should considered for replication jobs. |
serial |
str |
all |
The serial number of the disk. | |
size |
int |
all |
Computed Size of the disk. |
Create a serial device inside the VM (up to a maximum of 4 can be specified), and either pass through a host serial
device (i.e. /dev/ttyS0), or create a unix socket on the host side. The order in which serial
blocks are declared does
not matter.
WARNING: Use with caution, as the docs indicate this device is experimental and users have reported issues with it.
See the options for serial in the PVE docs for more details.
Argument | Type | Default Value | Description |
---|---|---|---|
id |
int |
Required The ID of the serial device. Must be unique, and between 0-3 . |
|
type |
str |
Required The type of serial device to create. Options: socket , or the path to a serial device like /dev/ttyS0 . |
The usb
block is used to configure USB devices. It may be specified multiple times. The order in which the
blocks are specified determines the ID for each net device. i.e. The first usb
block will become usb0
, the
second will be usb1
etc...
See the docs about USB passthrough for more details.
Argument | Type | Default Value | Description |
---|---|---|---|
host |
str |
Required USB device host. This can either be done via the vendor- and product-id, or via the host bus and port. | |
usb3 |
bool |
false |
Specifies whether if given host option is a USB3 device or port. |
In addition to the arguments above, the following attributes can be referenced from this resource.
Attribute | Type | Description |
---|---|---|
ssh_host |
str |
Read-only attribute. Only applies when define_connection_info is true. The hostname or IP to use to connect to the VM for preprovisioning. This can be overridden by defining ssh_forward_ip , but if you're using cloud-init and ipconfig0=dhcp , the IP reported by qemu-guest-agent is used, otherwise the IP defined in ipconfig0 is used. |
ssh_port |
str |
Read-only attribute. Only applies when define_connection_info is true. The port to connect to the VM over SSH for preprovisioning. If using cloud-init and a port is not specified in ssh_forward_ip , then 22 is used. If not using cloud-init, a port on the target_node will be forwarded to port 22 in the guest, and this attribute will be set to the forwarded port. |
default_ipv4_address |
str |
Read-only attribute. Only applies when agent is 1 and Proxmox can actually read the ip the vm has. |
The following arguments are deprecated, and should no longer be used.
disk
- (Optional; use disks instead)disk_gb
- (Optional; use disk.size instead)storage
- (Optional; use disk.storage instead)storage_type
- (Optional; use disk.type instead)nic
- (Optional; use network instead)bridge
- (Optional; use network.bridge instead)vlan
- (Optional; use network.tag instead)mac
- (Optional; use network.macaddr instead)clone_wait
- (do not use, api should manage timeouts)additional_wait
- (do not use, api should manage timeouts)preprovision
- (do not use, provider do not fully support preprovisioning anymore)
A VM Qemu Resource can be imported using its node, type and VM ID i.e.:
$ terraform import [options] [node]/[type]/[vmId]