244 lines
12 KiB
Plaintext
244 lines
12 KiB
Plaintext
<!-- Code generated from the comments of the Config struct in builder/googlecompute/config.go; DO NOT EDIT MANUALLY -->
|
|
|
|
- `account_file` (string) - The JSON file containing your account credentials. Not required if you
|
|
run Packer on a GCE instance with a service account. Instructions for
|
|
creating the file or using service accounts are above.
|
|
|
|
- `impersonate_service_account` (string) - This allows service account impersonation as per the [docs](https://cloud.google.com/iam/docs/impersonating-service-accounts).
|
|
|
|
- `accelerator_type` (string) - Full or partial URL of the guest accelerator type. GPU accelerators can
|
|
only be used with `"on_host_maintenance": "TERMINATE"` option set.
|
|
Example:
|
|
`"projects/project_id/zones/europe-west1-b/acceleratorTypes/nvidia-tesla-k80"`
|
|
|
|
- `accelerator_count` (int64) - Number of guest accelerator cards to add to the launched instance.
|
|
|
|
- `address` (string) - The name of a pre-allocated static external IP address. Note, must be
|
|
the name and not the actual IP address.
|
|
|
|
- `disable_default_service_account` (bool) - If true, the default service account will not be used if
|
|
service_account_email is not specified. Set this value to true and omit
|
|
service_account_email to provision a VM with no service account.
|
|
|
|
- `disk_name` (string) - The name of the disk, if unset the instance name will be used.
|
|
|
|
- `disk_size` (int64) - The size of the disk in GB. This defaults to 10, which is 10GB.
|
|
|
|
- `disk_type` (string) - Type of disk used to back your instance, like pd-ssd or pd-standard.
|
|
Defaults to pd-standard.
|
|
|
|
- `enable_secure_boot` (bool) - Create a Shielded VM image with Secure Boot enabled. It helps ensure that
|
|
the system only runs authentic software by verifying the digital signature
|
|
of all boot components, and halting the boot process if signature verification
|
|
fails. [Details](https://cloud.google.com/security/shielded-cloud/shielded-vm)
|
|
|
|
- `enable_vtpm` (bool) - Create a Shielded VM image with virtual trusted platform module
|
|
Measured Boot enabled. A vTPM is a virtualized trusted platform module,
|
|
which is a specialized computer chip you can use to protect objects,
|
|
like keys and certificates, that you use to authenticate access to your
|
|
system. [Details](https://cloud.google.com/security/shielded-cloud/shielded-vm)
|
|
|
|
- `enable_integrity_monitoring` (bool) - Integrity monitoring helps you understand and make decisions about the
|
|
state of your VM instances. Note: integrity monitoring relies on having
|
|
vTPM enabled. [Details](https://cloud.google.com/security/shielded-cloud/shielded-vm)
|
|
|
|
- `skip_create_image` (bool) - Skip creating the image. Useful for setting to `true` during a build test stage. Defaults to `false`.
|
|
|
|
- `image_name` (string) - The unique name of the resulting image. Defaults to
|
|
`packer-{{timestamp}}`.
|
|
|
|
- `image_description` (string) - The description of the resulting image.
|
|
|
|
- `image_encryption_key` (\*CustomerEncryptionKey) - Image encryption key to apply to the created image. Possible values:
|
|
* kmsKeyName - The name of the encryption key that is stored in Google Cloud KMS.
|
|
* RawKey: - A 256-bit customer-supplied encryption key, encodes in RFC 4648 base64.
|
|
|
|
examples:
|
|
|
|
```json
|
|
{
|
|
"kmsKeyName": "projects/${project}/locations/${region}/keyRings/computeEngine/cryptoKeys/computeEngine/cryptoKeyVersions/4"
|
|
}
|
|
```
|
|
|
|
```hcl
|
|
image_encryption_key {
|
|
kmsKeyName = "projects/${var.project}/locations/${var.region}/keyRings/computeEngine/cryptoKeys/computeEngine/cryptoKeyVersions/4"
|
|
}
|
|
```
|
|
|
|
- `image_family` (string) - The name of the image family to which the resulting image belongs. You
|
|
can create disks by specifying an image family instead of a specific
|
|
image name. The image family always returns its latest image that is not
|
|
deprecated.
|
|
|
|
- `image_labels` (map[string]string) - Key/value pair labels to apply to the created image.
|
|
|
|
- `image_licenses` ([]string) - Licenses to apply to the created image.
|
|
|
|
- `image_storage_locations` ([]string) - Storage location, either regional or multi-regional, where snapshot
|
|
content is to be stored and only accepts 1 value. Always defaults to a nearby regional or multi-regional
|
|
location.
|
|
|
|
multi-regional example:
|
|
|
|
```json
|
|
{
|
|
"image_storage_locations": ["us"]
|
|
}
|
|
```
|
|
regional example:
|
|
|
|
```json
|
|
{
|
|
"image_storage_locations": ["us-east1"]
|
|
}
|
|
```
|
|
|
|
- `instance_name` (string) - A name to give the launched instance. Beware that this must be unique.
|
|
Defaults to `packer-{{uuid}}`.
|
|
|
|
- `labels` (map[string]string) - Key/value pair labels to apply to the launched instance.
|
|
|
|
- `machine_type` (string) - The machine type. Defaults to "n1-standard-1".
|
|
|
|
- `metadata` (map[string]string) - Metadata applied to the launched instance.
|
|
All metadata configuration values are expected to be of type string.
|
|
Google metadata options that take a value of `TRUE` or `FALSE` should be
|
|
set as a string (i.e `"TRUE"` `"FALSE"` or `"true"` `"false"`).
|
|
|
|
- `metadata_files` (map[string]string) - Metadata applied to the launched instance. Values are files.
|
|
|
|
- `min_cpu_platform` (string) - A Minimum CPU Platform for VM Instance. Availability and default CPU
|
|
platforms vary across zones, based on the hardware available in each GCP
|
|
zone.
|
|
[Details](https://cloud.google.com/compute/docs/instances/specify-min-cpu-platform)
|
|
|
|
- `network` (string) - The Google Compute network id or URL to use for the launched instance.
|
|
Defaults to "default". If the value is not a URL, it will be
|
|
interpolated to
|
|
`projects/((network_project_id))/global/networks/((network))`. This value
|
|
is not required if a subnet is specified.
|
|
|
|
- `network_project_id` (string) - The project ID for the network and subnetwork to use for launched
|
|
instance. Defaults to project_id.
|
|
|
|
- `omit_external_ip` (bool) - If true, the instance will not have an external IP. use_internal_ip must
|
|
be true if this property is true.
|
|
|
|
- `on_host_maintenance` (string) - Sets Host Maintenance Option. Valid choices are `MIGRATE` and
|
|
`TERMINATE`. Please see [GCE Instance Scheduling
|
|
Options](https://cloud.google.com/compute/docs/instances/setting-instance-scheduling-options),
|
|
as not all machine\_types support `MIGRATE` (i.e. machines with GPUs).
|
|
If preemptible is true this can only be `TERMINATE`. If preemptible is
|
|
false, it defaults to `MIGRATE`
|
|
|
|
- `preemptible` (bool) - If true, launch a preemptible instance.
|
|
|
|
- `state_timeout` (duration string | ex: "1h5m2s") - The time to wait for instance state changes. Defaults to "5m".
|
|
|
|
- `region` (string) - The region in which to launch the instance. Defaults to the region
|
|
hosting the specified zone.
|
|
|
|
- `scopes` ([]string) - The service account scopes for launched
|
|
instance. Defaults to:
|
|
|
|
```json
|
|
[
|
|
"https://www.googleapis.com/auth/userinfo.email",
|
|
"https://www.googleapis.com/auth/compute",
|
|
"https://www.googleapis.com/auth/devstorage.full_control"
|
|
]
|
|
```
|
|
|
|
- `service_account_email` (string) - The service account to be used for launched instance. Defaults to the
|
|
project's default service account unless disable_default_service_account
|
|
is true.
|
|
|
|
- `source_image_project_id` ([]string) - A list of project IDs to search for the source image. Packer will search the first
|
|
project ID in the list first, and fall back to the next in the list, until it finds the source image.
|
|
|
|
- `startup_script_file` (string) - The path to a startup script to run on the launched instance from which the image will
|
|
be made. When set, the contents of the startup script file will be added to the instance metadata
|
|
under the `"startup_script"` metadata property. See [Providing startup script contents directly](https://cloud.google.com/compute/docs/startupscript#providing_startup_script_contents_directly) for more details.
|
|
|
|
When using `startup_script_file` the following rules apply:
|
|
- The contents of the script file will overwrite the value of the `"startup_script"` metadata property at runtime.
|
|
- The contents of the script file will be wrapped in Packer's startup script wrapper, unless `wrap_startup_script` is disabled. See `wrap_startup_script` for more details.
|
|
- Not supported by Windows instances. See [Startup Scripts for Windows](https://cloud.google.com/compute/docs/startupscript#providing_a_startup_script_for_windows_instances) for more details.
|
|
|
|
- `wrap_startup_script` (boolean) - For backwards compatibility this option defaults to `"true"` in the future it will default to `"false"`.
|
|
If "true", the contents of `startup_script_file` or `"startup_script"` in the instance metadata
|
|
is wrapped in a Packer specific script that tracks the execution and completion of the provided
|
|
startup script. The wrapper ensures that the builder will not continue until the startup script has been executed.
|
|
- The use of the wrapped script file requires that the user or service account
|
|
running the build has the compute.instance.Metadata role.
|
|
|
|
- `subnetwork` (string) - The Google Compute subnetwork id or URL to use for the launched
|
|
instance. Only required if the network has been created with custom
|
|
subnetting. Note, the region of the subnetwork must match the region or
|
|
zone in which the VM is launched. If the value is not a URL, it will be
|
|
interpolated to
|
|
`projects/((network_project_id))/regions/((region))/subnetworks/((subnetwork))`
|
|
|
|
- `tags` ([]string) - Assign network tags to apply firewall rules to VM instance.
|
|
|
|
- `use_internal_ip` (bool) - If true, use the instance's internal IP instead of its external IP
|
|
during building.
|
|
|
|
- `use_os_login` (bool) - If true, OSLogin will be used to manage SSH access to the compute instance by
|
|
dynamically importing a temporary SSH key to the Google account's login profile,
|
|
and setting the `enable-oslogin` to `TRUE` in the instance metadata.
|
|
Optionally, `use_os_login` can be used with an existing `ssh_username` and `ssh_private_key_file`
|
|
if a SSH key has already been added to the Google account's login profile - See [Adding SSH Keys](https://cloud.google.com/compute/docs/instances/managing-instance-access#add_oslogin_keys).
|
|
|
|
SSH keys can be added to an individual user account
|
|
|
|
```shell-session
|
|
$ gcloud compute os-login ssh-keys add --key-file=/home/user/.ssh/my-key.pub
|
|
|
|
$ gcloud compute os-login describe-profile
|
|
PosixAccounts:
|
|
- accountId: <project-id>
|
|
gid: '34567890754'
|
|
homeDirectory: /home/user_example_com
|
|
...
|
|
primary: true
|
|
uid: '2504818925'
|
|
username: /home/user_example_com
|
|
sshPublicKeys:
|
|
000000000000000000000000000000000000000000000000000000000000000a:
|
|
fingerprint: 000000000000000000000000000000000000000000000000000000000000000a
|
|
```
|
|
|
|
Or SSH keys can be added to an associated service account
|
|
```shell-session
|
|
$ gcloud auth activate-service-account --key-file=<path to service account credentials file (e.g account.json)>
|
|
$ gcloud compute os-login ssh-keys add --key-file=/home/user/.ssh/my-key.pub
|
|
|
|
$ gcloud compute os-login describe-profile
|
|
PosixAccounts:
|
|
- accountId: <project-id>
|
|
gid: '34567890754'
|
|
homeDirectory: /home/sa_000000000000000000000
|
|
...
|
|
primary: true
|
|
uid: '2504818925'
|
|
username: sa_000000000000000000000
|
|
sshPublicKeys:
|
|
000000000000000000000000000000000000000000000000000000000000000a:
|
|
fingerprint: 000000000000000000000000000000000000000000000000000000000000000a
|
|
```
|
|
|
|
- `vault_gcp_oauth_engine` (string) - Can be set instead of account_file. If set, this builder will use
|
|
HashiCorp Vault to generate an Oauth token for authenticating against
|
|
Google Cloud. The value should be the path of the token generator
|
|
within vault.
|
|
For information on how to configure your Vault + GCP engine to produce
|
|
Oauth tokens, see https://www.vaultproject.io/docs/auth/gcp
|
|
You must have the environment variables VAULT_ADDR and VAULT_TOKEN set,
|
|
along with any other relevant variables for accessing your vault
|
|
instance. For more information, see the Vault docs:
|
|
https://www.vaultproject.io/docs/commands/#environment-variables
|
|
Example:`"vault_gcp_oauth_engine": "gcp/token/my-project-editor",`
|