packer-cn/website/pages/docs/builders/qemu.mdx

198 lines
5.4 KiB
Plaintext
Raw Normal View History

---
2018-04-13 22:48:19 -04:00
modeline: |
vim: set ft=pandoc:
2017-06-14 21:04:16 -04:00
description: |
2020-03-18 18:46:47 -04:00
The Qemu Packer builder is able to create KVM and Xen virtual machine images.
2015-07-22 22:31:00 -04:00
layout: docs
2020-03-18 18:46:47 -04:00
page_title: QEMU - Builders
sidebar_title: QEMU
---
2013-11-05 18:34:09 -05:00
# QEMU Builder
Type: `qemu`
2015-07-22 22:31:00 -04:00
The Qemu Packer builder is able to create [KVM](http://www.linux-kvm.org) and
[Xen](http://www.xenproject.org) virtual machine images.
2015-07-22 22:31:00 -04:00
The builder builds a virtual machine by creating a new virtual machine from
scratch, booting it, installing an OS, rebooting the machine with the boot media
as the virtual hard drive, provisioning software within the OS, then shutting it
down. The result of the Qemu builder is a directory containing the image file
necessary to run the virtual machine on KVM or Xen.
## Basic Example
2015-07-22 22:31:00 -04:00
Here is a basic example. This example is functional so long as you fixup paths
to files, URLS for ISOs and checksums.
2020-07-31 11:32:08 -04:00
<Tabs>
<Tab heading="JSON">
```json
{
2020-03-18 18:46:47 -04:00
"builders": [
{
"type": "qemu",
"iso_url": "http://mirror.raystedman.net/centos/6/isos/x86_64/CentOS-6.9-x86_64-minimal.iso",
2020-07-31 11:32:08 -04:00
"iso_checksum": "md5:af4a1640c0c6f348c6c41f1ea9e192a2",
"output_directory": "output_centos_tdhtest",
"shutdown_command": "echo 'packer' | sudo -S shutdown -P now",
"disk_size": "5000M",
"format": "qcow2",
"accelerator": "kvm",
"http_directory": "path/to/httpdir",
"ssh_username": "root",
"ssh_password": "s0m3password",
"ssh_timeout": "20m",
"vm_name": "tdhtest",
"net_device": "virtio-net",
"disk_interface": "virtio",
"boot_wait": "10s",
"boot_command": [
"<tab> text ks=http://{{ .HTTPIP }}:{{ .HTTPPort }}/centos6-ks.cfg<enter><wait>"
]
}
]
}
```
2020-07-31 11:32:08 -04:00
</Tab>
<Tab heading="HCL2">
```hcl
source "qemu" "example" {
iso_url = "http://mirror.raystedman.net/centos/6/isos/x86_64/CentOS-6.9-x86_64-minimal.iso"
iso_checksum = "md5:af4a1640c0c6f348c6c41f1ea9e192a2"
output_directory = "output_centos_tdhtest"
shutdown_command = "echo 'packer' | sudo -S shutdown -P now"
disk_size = "5000M"
format = "qcow2"
accelerator = "kvm"
http_directory = "path/to/httpdir"
ssh_username = "root"
ssh_password = "s0m3password"
ssh_timeout = "20m"
vm_name = "tdhtest"
net_device = "virtio-net"
disk_interface = "virtio"
boot_wait = "10s"
boot_command = ["<tab> text ks=http://{{ .HTTPIP }}:{{ .HTTPPort }}/centos6-ks.cfg<enter><wait>"]
}
build {
sources = ["source.qemu.example"]
}
```
</Tab>
</Tabs>
This is an example only, and will time out waiting for SSH because we have not
provided a kickstart file. You must add a valid kickstart file to the
"http_directory" and then provide the file in the "boot_command" in order for
this build to run. We recommend you check out the
2020-03-31 17:40:07 -04:00
[Community Templates](/community-tools#templates)
for a practical usage example.
Note that you will need to set `"headless": true` if you are running Packer
on a Linux server without X11; or if you are connected via ssh to a remote
Linux server and have not enabled X11 forwarding (`ssh -X`).
## Qemu Specific Configuration Reference
There are many configuration options available for the builder. In addition to
the items listed here, you will want to look at the general configuration
references for [ISO](#iso-configuration),
[HTTP](#http-directory-configuration),
[Floppy](#floppy-configuration),
[Boot](#boot-configuration),
[Shutdown](#shutdown-configuration),
[Communicator](#communicator-configuration)
configuration references, which are
necessary for this build to succeed and can be found further down the page.
### Optional:
2020-03-23 20:02:12 -04:00
@include 'builder/qemu/Config-not-required.mdx'
## ISO Configuration
2020-03-23 20:02:12 -04:00
@include 'common/ISOConfig.mdx'
### Required:
2020-03-23 20:02:12 -04:00
@include 'common/ISOConfig-required.mdx'
### Optional:
2020-03-23 20:02:12 -04:00
@include 'common/ISOConfig-not-required.mdx'
2018-01-31 15:45:38 -05:00
## Http directory configuration
2019-06-13 05:18:04 -04:00
2020-03-23 20:02:12 -04:00
@include 'common/HTTPConfig.mdx'
2020-03-18 18:46:47 -04:00
2019-06-13 05:18:04 -04:00
### Optional:
2020-03-23 20:02:12 -04:00
@include 'common/HTTPConfig-not-required.mdx'
2019-06-13 05:18:04 -04:00
## Floppy configuration
2020-03-23 20:02:12 -04:00
@include 'common/FloppyConfig.mdx'
### Optional:
2020-03-23 20:02:12 -04:00
@include 'common/FloppyConfig-not-required.mdx'
## Shutdown configuration
### Optional:
2020-03-23 20:02:12 -04:00
@include 'common/shutdowncommand/ShutdownConfig-not-required.mdx'
## Communicator configuration
### Optional common fields:
@include 'helper/communicator/Config-not-required.mdx'
@include 'builder/qemu/CommConfig-not-required.mdx'
### Optional SSH fields:
@include 'helper/communicator/SSH-not-required.mdx'
### Optional WinRM fields:
@include 'helper/communicator/WinRM-not-required.mdx'
## Boot Configuration
2015-07-22 23:25:58 -04:00
2020-03-23 20:02:12 -04:00
@include 'common/bootcommand/VNCConfig.mdx'
2020-03-24 19:48:37 -04:00
2020-03-23 20:02:12 -04:00
@include 'common/bootcommand/BootConfig.mdx'
2015-07-22 23:25:58 -04:00
### Optional:
2020-03-23 20:02:12 -04:00
@include 'common/bootcommand/VNCConfig-not-required.mdx'
2020-03-24 19:48:37 -04:00
2020-03-23 20:02:12 -04:00
@include 'common/bootcommand/BootConfig-not-required.mdx'
### Communicator Configuration
#### Optional:
2020-03-23 20:02:12 -04:00
@include 'helper/communicator/Config-not-required.mdx'
2017-10-12 01:58:03 -04:00
### Troubleshooting
Some users have experienced errors complaining about invalid keymaps. This
seems to be related to having a `common` directory or file in the directory
they've run Packer in, like the packer source directory. This appears to be an
upstream bug with qemu, and the best solution for now is to remove the
file/directory or run in another directory.
Some users have reported issues with incorrect keymaps using qemu version 2.11.
This is a bug with qemu, and the solution is to upgrade, or downgrade to 2.10.1
or earlier.