packer-cn/website/pages/docs/builders/vmware/vsphere-iso.mdx

400 lines
7.9 KiB
Plaintext

---
modeline: |
vim: set ft=pandoc:
description: |
This VMware Packer builder starts from an ISO and creates a vm using the
vSphere API to build on a remote VMWare machine.
layout: docs
page_title: VSphere ISO - Builders
sidebar_title: VSphere ISO
---
# Packer Builder for VMware vSphere
Type: `vsphere-iso`
This builder uses the vSphere API, and creates virtual machines remotely. It
starts from an ISO file and creates new VMs from scratch.
- VMware Player is not required.
- It uses the official vCenter API, and does not require ESXi host [modification](/docs/builders/vmware-iso#building-on-a-remote-vsphere-hypervisor)
- This builder is supported for vSphere version 6.5 and greater. Builds on lower
versions may work, but some configuration options may throw errors because they
do not exist in the older versions of the vSphere API.
## Examples
See complete Ubuntu, Windows, and macOS templates in the [examples folder](https://github.com/hashicorp/packer/tree/master/builder/vsphere/examples/).
# Configuration Reference
There are many configuration options available for this builder. In addition to
the items listed here, you will want to look at the general configuration
references for [HTTP](#http-directory-configuration),
[Floppy](#floppy-configuration),
[Boot](#boot-configuration),
[Hardware](#hardware-configuration),
[Output](#output-configuration),
[Run](#run-configuration),
[Shutdown](#shutdown-configuration),
[Communicator](#communicator-configuration),
[Export](#export-configuration),
configuration references, which are
necessary for this build to succeed and can be found further down the page.
@include 'builder/vsphere/iso/Config-not-required.mdx'
### Boot Configuration
@include 'common/bootcommand/BootConfig.mdx'
We send each character to the VM with a default delay of 100ms between groups.
The delay alleviates possible issues with latency and CPU
contention. If you notice missing keys, you can tune this delay by specifying
"boot_keygroup_interval" in your Packer template, for example:
<Tabs>
<Tab heading="JSON">
```json
{
"builders": [
{
"type": "vsphere-iso",
"boot_keygroup_interval": "500ms"
...
}
]
}
```
</Tab>
<Tab heading="HCL2">
```hcl
source "vsphere-iso" "example" {
boot_keygroup_interval = "500ms"
# ...
}
```
</Tab>
</Tabs>
#### Optional:
@include 'common/bootcommand/BootConfig-not-required.mdx'
@include 'builder/vsphere/common/BootConfig-not-required.mdx'
### Http directory configuration
@include 'common/HTTPConfig.mdx'
#### Optional:
@include 'common/HTTPConfig-not-required.mdx'
### Floppy configuration
@include 'builder/vsphere/iso/FloppyConfig-not-required.mdx'
### Connection Configuration
@include 'builder/vsphere/common/ConnectConfig-not-required.mdx'
### Hardware Configuration
@include 'builder/vsphere/common/HardwareConfig-not-required.mdx'
### Location Configuration
@include 'builder/vsphere/common/LocationConfig-not-required.mdx'
### Run Configuration
@include 'builder/vsphere/common/RunConfig-not-required.mdx'
### Shutdown Configuration
@include 'builder/vsphere/common/ShutdownConfig-not-required.mdx'
### Wait Configuration
@include 'builder/vsphere/common/WaitIpConfig-not-required.mdx'
### ISO Configuration
@include 'common/ISOConfig.mdx'
#### Required:
@include 'common/ISOConfig-required.mdx'
#### Optional:
@include 'common/ISOConfig-not-required.mdx'
### CDRom Configuration
Each iso defined in the CDRom Configuration adds a new drive. If the "iso_url" is defined in
addition to the "iso_paths", the "iso_url" is added to the VM first. This keeps the "iso_url" first in
the boot order by default allowing the boot iso being defined by the iso_url and the vmware tools iso added
from the datastore. Example:
<Tabs>
<Tab heading="JSON">
```json
"iso_urls": [
"win10.iso",
"http://example.org/isos/win10.iso"
],
"iso_paths": [
"[] /usr/lib/vmware/isoimages/windows.iso"
],
```
</Tab>
<Tab heading="HCL2">
```hcl
iso_urls = [
"win10.iso",
"http://example.org/isos/win10.iso"
]
iso_paths = [
"[] /usr/lib/vmware/isoimages/windows.iso"
]
```
</Tab>
</Tabs>
@include 'builder/vsphere/iso/CDRomConfig-not-required.mdx'
### Create Configuration
@include 'builder/vsphere/iso/CreateConfig-not-required.mdx'
### Network Adapter Configuration
@include 'builder/vsphere/iso/NIC.mdx'
@include 'builder/vsphere/iso/NIC-required.mdx'
#### Optional
@include 'builder/vsphere/iso/NIC-not-required.mdx'
### Storage Configuration
@include 'builder/vsphere/iso/DiskConfig.mdx'
@include 'builder/vsphere/iso/DiskConfig-required.mdx'
#### Optional
@include 'builder/vsphere/iso/DiskConfig-not-required.mdx'
### Export Configuration
@include 'builder/vsphere/common/ExportConfig.mdx'
#### Optional:
@include 'builder/vsphere/common/ExportConfig-not-required.mdx'
#### Output Configuration:
@include 'builder/vsphere/common/OutputConfig-not-required.mdx'
### Content Library Import Configuration
@include 'builder/vsphere/common/ContentLibraryDestinationConfig.mdx'
@include 'builder/vsphere/common/ContentLibraryDestinationConfig-not-required.mdx'
Minimal example of usage to import a VM template:
<Tabs>
<Tab heading="JSON">
```json
"content_library_destination" : {
"library": "Packer Library Test"
}
```
</Tab>
<Tab heading="HCL2">
```hcl
content_library_destination {
library = "Packer Library Test"
}
```
</Tab>
</Tabs>
Minimal example of usage to import a OVF template:
<Tabs>
<Tab heading="JSON">
```json
"content_library_destination" : {
"library": "Packer Library Test",
"ovf": true
}
```
</Tab>
<Tab heading="HCL2">
```hcl
content_library_destination {
library = "Packer Library Test"
ovf = true
}
```
</Tab>
</Tabs>
### Extra Configuration Parameters
@include 'builder/vsphere/common/ConfigParamsConfig-not-required.mdx'
### Communicator configuration
#### Optional common fields:
@include 'helper/communicator/Config-not-required.mdx'
#### Optional SSH fields:
@include 'helper/communicator/SSH-not-required.mdx'
#### Optional WinRM fields:
@include 'helper/communicator/WinRM-not-required.mdx'
## Working with Clusters
#### Standalone Hosts
Only use the `host` option. Optionally specify a `resource_pool`:
<Tabs>
<Tab heading="JSON">
```json
"host": "esxi-1.vsphere65.test",
"resource_pool": "pool1",
```
</Tab>
<Tab heading="HCL2">
```hcl
host = ""esxi-1.vsphere65.test""
resource_pool = "pool1"
```
</Tab>
</Tabs>
#### Clusters Without DRS
Use the `cluster` and `host`parameters:
<Tabs>
<Tab heading="JSON">
```json
"cluster": "cluster1",
"host": "esxi-2.vsphere65.test",
```
</Tab>
<Tab heading="HCL2">
```hcl
cluster = "cluster1"
host = "esxi-2.vsphere65.test"
```
</Tab>
</Tabs>
#### Clusters With DRS
Only use the `cluster` option. Optionally specify a `resource_pool`:
<Tabs>
<Tab heading="JSON">
```json
"cluster": "cluster2",
"resource_pool": "pool1",
```
</Tab>
<Tab heading="HCL2">
```hcl
cluster = "cluster2"
resource_pool = "pool1"
```
</Tab>
</Tabs>
## Required vSphere Permissions
- VM folder (this object and children):
```text
Virtual machine -> Inventory
Virtual machine -> Configuration
Virtual machine -> Interaction
Virtual machine -> Snapshot management
Virtual machine -> Provisioning
```
Individual privileges are listed in https://github.com/jetbrains-infra/packer-builder-vsphere/issues/97#issuecomment-436063235.
- Resource pool, host, or cluster (this object):
```text
Resource -> Assign virtual machine to resource pool
```
- Host in clusters without DRS (this object):
```text
Read-only
```
- Datastore (this object):
```text
Datastore -> Allocate space
Datastore -> Browse datastore
Datastore -> Low level file operations
```
- Network (this object):
```text
Network -> Assign network
```
- Distributed switch (this object):
```text
Read-only
```
For floppy image upload:
- Datacenter (this object):
```text
Datastore -> Low level file operations
```
- Host (this object):
```text
Host -> Configuration -> System Management
```