| --- |
| subcategory: "Compute Engine" |
| description: |- |
| Manages a VM instance template resource within GCE. |
| --- |
| |
| # google\_compute\_instance\_template |
| |
| -> **Note**: Global instance templates can be used in any region. To lower the impact of outages outside your region and gain data residency within your region, use [google_compute_region_instance_template](https://registry.terraform.io/providers/hashicorp/google/latest/docs/resources/compute_region_instance_template). |
| |
| Manages a VM instance template resource within GCE. For more information see |
| [the official documentation](https://cloud.google.com/compute/docs/instance-templates) |
| and |
| [API](https://cloud.google.com/compute/docs/reference/latest/instanceTemplates). |
| |
| |
| ## Example Usage |
| |
| ```hcl |
| resource "google_service_account" "default" { |
| account_id = "service-account-id" |
| display_name = "Service Account" |
| } |
| |
| resource "google_compute_instance_template" "default" { |
| name = "appserver-template" |
| description = "This template is used to create app server instances." |
| |
| tags = ["foo", "bar"] |
| |
| labels = { |
| environment = "dev" |
| } |
| |
| instance_description = "description assigned to instances" |
| machine_type = "e2-medium" |
| can_ip_forward = false |
| |
| scheduling { |
| automatic_restart = true |
| on_host_maintenance = "MIGRATE" |
| } |
| |
| // Create a new boot disk from an image |
| disk { |
| source_image = "debian-cloud/debian-11" |
| auto_delete = true |
| boot = true |
| // backup the disk every day |
| resource_policies = [google_compute_resource_policy.daily_backup.id] |
| } |
| |
| // Use an existing disk resource |
| disk { |
| // Instance Templates reference disks by name, not self link |
| source = google_compute_disk.foobar.name |
| auto_delete = false |
| boot = false |
| } |
| |
| network_interface { |
| network = "default" |
| } |
| |
| metadata = { |
| foo = "bar" |
| } |
| |
| service_account { |
| # Google recommends custom service accounts that have cloud-platform scope and permissions granted via IAM Roles. |
| email = google_service_account.default.email |
| scopes = ["cloud-platform"] |
| } |
| } |
| |
| data "google_compute_image" "my_image" { |
| family = "debian-11" |
| project = "debian-cloud" |
| } |
| |
| resource "google_compute_disk" "foobar" { |
| name = "existing-disk" |
| image = data.google_compute_image.my_image.self_link |
| size = 10 |
| type = "pd-ssd" |
| zone = "us-central1-a" |
| } |
| |
| resource "google_compute_resource_policy" "daily_backup" { |
| name = "every-day-4am" |
| region = "us-central1" |
| snapshot_schedule_policy { |
| schedule { |
| daily_schedule { |
| days_in_cycle = 1 |
| start_time = "04:00" |
| } |
| } |
| } |
| } |
| ``` |
| |
| ## Example Usage - Automatic Envoy deployment |
| |
| ```hcl |
| data "google_compute_default_service_account" "default" { |
| } |
| |
| data "google_compute_image" "my_image" { |
| family = "debian-11" |
| project = "debian-cloud" |
| } |
| |
| resource "google_compute_instance_template" "foobar" { |
| name = "appserver-template" |
| machine_type = "e2-medium" |
| can_ip_forward = false |
| tags = ["foo", "bar"] |
| |
| disk { |
| source_image = data.google_compute_image.my_image.self_link |
| auto_delete = true |
| boot = true |
| } |
| |
| network_interface { |
| network = "default" |
| } |
| |
| scheduling { |
| preemptible = false |
| automatic_restart = true |
| } |
| |
| metadata = { |
| gce-software-declaration = <<-EOF |
| { |
| "softwareRecipes": [{ |
| "name": "install-gce-service-proxy-agent", |
| "desired_state": "INSTALLED", |
| "installSteps": [{ |
| "scriptRun": { |
| "script": "#! /bin/bash\nZONE=$(curl --silent http://metadata.google.internal/computeMetadata/v1/instance/zone -H Metadata-Flavor:Google | cut -d/ -f4 )\nexport SERVICE_PROXY_AGENT_DIRECTORY=$(mktemp -d)\nsudo gsutil cp gs://gce-service-proxy-"$ZONE"/service-proxy-agent/releases/service-proxy-agent-0.2.tgz "$SERVICE_PROXY_AGENT_DIRECTORY" || sudo gsutil cp gs://gce-service-proxy/service-proxy-agent/releases/service-proxy-agent-0.2.tgz "$SERVICE_PROXY_AGENT_DIRECTORY"\nsudo tar -xzf "$SERVICE_PROXY_AGENT_DIRECTORY"/service-proxy-agent-0.2.tgz -C "$SERVICE_PROXY_AGENT_DIRECTORY"\n"$SERVICE_PROXY_AGENT_DIRECTORY"/service-proxy-agent/service-proxy-agent-bootstrap.sh" |
| } |
| }] |
| }] |
| } |
| EOF |
| gce-service-proxy = <<-EOF |
| { |
| "api-version": "0.2", |
| "proxy-spec": { |
| "proxy-port": 15001, |
| "network": "my-network", |
| "tracing": "ON", |
| "access-log": "/var/log/envoy/access.log" |
| } |
| "service": { |
| "serving-ports": [80, 81] |
| }, |
| "labels": { |
| "app_name": "bookserver_app", |
| "app_version": "STABLE" |
| } |
| } |
| EOF |
| enable-guest-attributes = "true" |
| enable-osconfig = "true" |
| |
| } |
| |
| service_account { |
| email = data.google_compute_default_service_account.default.email |
| scopes = ["cloud-platform"] |
| } |
| |
| labels = { |
| gce-service-proxy = "on" |
| } |
| } |
| ``` |
| |
| ## Using with Instance Group Manager |
| |
| Instance Templates cannot be updated after creation with the Google |
| Cloud Platform API. In order to update an Instance Template, Terraform will |
| destroy the existing resource and create a replacement. In order to effectively |
| use an Instance Template resource with an [Instance Group Manager resource][1], |
| it's recommended to specify `create_before_destroy` in a [lifecycle][2] block. |
| Either omit the Instance Template `name` attribute, or specify a partial name |
| with `name_prefix`. Example: |
| |
| ```hcl |
| resource "google_compute_instance_template" "instance_template" { |
| name_prefix = "instance-template-" |
| machine_type = "e2-medium" |
| region = "us-central1" |
| |
| // boot disk |
| disk { |
| # ... |
| } |
| |
| // networking |
| network_interface { |
| # ... |
| } |
| |
| lifecycle { |
| create_before_destroy = true |
| } |
| } |
| |
| resource "google_compute_instance_group_manager" "instance_group_manager" { |
| name = "instance-group-manager" |
| instance_template = google_compute_instance_template.instance_template.id |
| base_instance_name = "instance-group-manager" |
| zone = "us-central1-f" |
| target_size = "1" |
| } |
| ``` |
| |
| With this setup Terraform generates a unique name for your Instance |
| Template and can then update the Instance Group manager without conflict before |
| destroying the previous Instance Template. |
| |
| ## Deploying the Latest Image |
| |
| A common way to use instance templates and managed instance groups is to deploy the |
| latest image in a family, usually the latest build of your application. There are two |
| ways to do this in Terraform, and they have their pros and cons. The difference ends |
| up being in how "latest" is interpreted. You can either deploy the latest image available |
| when Terraform runs, or you can have each instance check what the latest image is when |
| it's being created, either as part of a scaling event or being rebuilt by the instance |
| group manager. |
| |
| If you're not sure, we recommend deploying the latest image available when Terraform runs, |
| because this means all the instances in your group will be based on the same image, always, |
| and means that no upgrades or changes to your instances happen outside of a `terraform apply`. |
| You can achieve this by using the [`google_compute_image`](../d/compute_image.html) |
| data source, which will retrieve the latest image on every `terraform apply`, and will update |
| the template to use that specific image: |
| |
| ```tf |
| data "google_compute_image" "my_image" { |
| family = "debian-11" |
| project = "debian-cloud" |
| } |
| |
| resource "google_compute_instance_template" "instance_template" { |
| name_prefix = "instance-template-" |
| machine_type = "e2-medium" |
| region = "us-central1" |
| |
| // boot disk |
| disk { |
| source_image = data.google_compute_image.my_image.self_link |
| } |
| } |
| ``` |
| |
| To have instances update to the latest on every scaling event or instance re-creation, |
| use the family as the image for the disk, and it will use GCP's default behavior, setting |
| the image for the template to the family: |
| |
| ```tf |
| resource "google_compute_instance_template" "instance_template" { |
| name_prefix = "instance-template-" |
| machine_type = "e2-medium" |
| region = "us-central1" |
| |
| // boot disk |
| disk { |
| source_image = "debian-cloud/debian-11" |
| } |
| } |
| ``` |
| |
| ## Argument Reference |
| |
| Note that changing any field for this resource forces a new resource to be created. |
| |
| The following arguments are supported: |
| |
| * `disk` - (Required) Disks to attach to instances created from this template. |
| This can be specified multiple times for multiple disks. Structure is |
| [documented below](#nested_disk). |
| |
| * `machine_type` - (Required) The machine type to create. |
| |
| To create a machine with a [custom type](https://cloud.google.com/dataproc/docs/concepts/compute/custom-machine-types) (such as extended memory), format the value like `custom-VCPUS-MEM_IN_MB` like `custom-6-20480` for 6 vCPU and 20GB of RAM. |
| |
| - - - |
| * `name` - (Optional) The name of the instance template. If you leave |
| this blank, Terraform will auto-generate a unique name. |
| |
| * `name_prefix` - (Optional) Creates a unique name beginning with the specified |
| prefix. Conflicts with `name`. |
| |
| * `can_ip_forward` - (Optional) Whether to allow sending and receiving of |
| packets with non-matching source or destination IPs. This defaults to false. |
| |
| * `description` - (Optional) A brief description of this resource. |
| |
| * `instance_description` - (Optional) A brief description to use for instances |
| created from this template. |
| |
| * `labels` - (Optional) A set of key/value label pairs to assign to instances |
| created from this template. |
| |
| **Note**: This field is non-authoritative, and will only manage the labels present in your configuration. |
| Please refer to the field 'effective_labels' for all of the labels present on the resource. |
| |
| * `terraform_labels` - |
| The combination of labels configured directly on the resource and default labels configured on the provider. |
| |
| * `effective_labels` - |
| All of labels (key/value pairs) present on the resource in GCP, including the labels configured through Terraform, other clients and services. |
| |
| * `metadata` - (Optional) Metadata key/value pairs to make available from |
| within instances created from this template. |
| |
| * `metadata_startup_script` - (Optional) An alternative to using the |
| startup-script metadata key, mostly to match the compute_instance resource. |
| This replaces the startup-script metadata key on the created instance and |
| thus the two mechanisms are not allowed to be used simultaneously. |
| |
| * `network_interface` - (Required) Networks to attach to instances created from |
| this template. This can be specified multiple times for multiple networks. |
| Structure is [documented below](#nested_network_interface). |
| |
| * `network_performance_config` (Optional, Configures network performance settings for the instance created from the |
| template. Structure is [documented below](#nested_network_performance_config). **Note**: [`machine_type`](#machine_type) |
| must be a [supported type](https://cloud.google.com/compute/docs/networking/configure-vm-with-high-bandwidth-configuration), |
| the [`image`](#image) used must include the [`GVNIC`](https://cloud.google.com/compute/docs/networking/using-gvnic#create-instance-gvnic-image) |
| in `guest-os-features`, and `network_interface.0.nic-type` must be `GVNIC` |
| in order for this setting to take effect. |
| |
| * `project` - (Optional) The ID of the project in which the resource belongs. If it |
| is not provided, the provider project is used. |
| |
| * `region` - (Optional) An instance template is a global resource that is not |
| bound to a zone or a region. However, you can still specify some regional |
| resources in an instance template, which restricts the template to the |
| region where that resource resides. For example, a custom `subnetwork` |
| resource is tied to a specific region. Defaults to the region of the |
| Provider if no value is given. |
| |
| * `resource_policies` (Optional) -- A list of self_links of resource policies to attach to the instance. Modifying this list will cause the instance to recreate. Currently a max of 1 resource policy is supported. |
| |
| * `reservation_affinity` - (Optional) Specifies the reservations that this instance can consume from. |
| Structure is [documented below](#nested_reservation_affinity). |
| |
| * `resource_manager_tags` - (Optional) A set of key/value resource manager tag pairs to bind to the instances. Keys must be in the format tagKeys/{tag_key_id}, and values are in the format tagValues/456. |
| |
| * `scheduling` - (Optional) The scheduling strategy to use. More details about |
| this configuration option are [detailed below](#nested_scheduling). |
| |
| * `service_account` - (Optional) Service account to attach to the instance. Structure is [documented below](#nested_service_account). |
| |
| * `tags` - (Optional) Tags to attach to the instance. |
| |
| * `guest_accelerator` - (Optional) List of the type and count of accelerator cards attached to the instance. Structure [documented below](#nested_guest_accelerator). |
| |
| * `min_cpu_platform` - (Optional) Specifies a minimum CPU platform. Applicable values are the friendly names of CPU platforms, such as |
| `Intel Haswell` or `Intel Skylake`. See the complete list [here](https://cloud.google.com/compute/docs/instances/specify-min-cpu-platform). |
| |
| * `shielded_instance_config` - (Optional) Enable [Shielded VM](https://cloud.google.com/security/shielded-cloud/shielded-vm) on this instance. Shielded VM provides verifiable integrity to prevent against malware and rootkits. Defaults to disabled. Structure is [documented below](#nested_shielded_instance_config). |
| **Note**: [`shielded_instance_config`](#shielded_instance_config) can only be used with boot images with shielded vm support. See the complete list [here](https://cloud.google.com/compute/docs/images#shielded-images). |
| |
| * `enable_display` - (Optional, [Beta](https://terraform.io/docs/providers/google/guides/provider_versions.html)) Enable [Virtual Displays](https://cloud.google.com/compute/docs/instances/enable-instance-virtual-display#verify_display_driver) on this instance. |
| **Note**: [`allow_stopping_for_update`](#allow_stopping_for_update) must be set to true in order to update this field. |
| |
| * `confidential_instance_config` (Optional) - Enable [Confidential Mode](https://cloud.google.com/compute/confidential-vm/docs/about-cvm) on this VM. Structure is [documented below](#nested_confidential_instance_config) |
| |
| * `advanced_machine_features` (Optional) - Configure Nested Virtualisation and Simultaneous Hyper Threading on this VM. Structure is [documented below](#nested_advanced_machine_features) |
| |
| <a name="nested_disk"></a>The `disk` block supports: |
| |
| * `auto_delete` - (Optional) Whether or not the disk should be auto-deleted. |
| This defaults to true. |
| |
| * `boot` - (Optional) Indicates that this is a boot disk. |
| |
| * `device_name` - (Optional) A unique device name that is reflected into the |
| /dev/ tree of a Linux operating system running within the instance. If not |
| specified, the server chooses a default device name to apply to this disk. |
| |
| * `disk_name` - (Optional) Name of the disk. When not provided, this defaults |
| to the name of the instance. |
| |
| * `provisioned_iops` - (Optional) Indicates how many IOPS to provision for the disk. This |
| sets the number of I/O operations per second that the disk can handle. |
| Values must be between 10,000 and 120,000. For more details, see the |
| [Extreme persistent disk documentation](https://cloud.google.com/compute/docs/disks/extreme-persistent-disk). |
| |
| * `resource_manager_tags` - (Optional) A set of key/value resource manager tag pairs to bind to this disk. Keys must be in the format tagKeys/{tag_key_id}, and values are in the format tagValues/456. |
| |
| * `source_image` - (Optional) The image from which to |
| initialize this disk. This can be one of: the image's `self_link`, |
| `projects/{project}/global/images/{image}`, |
| `projects/{project}/global/images/family/{family}`, `global/images/{image}`, |
| `global/images/family/{family}`, `family/{family}`, `{project}/{family}`, |
| `{project}/{image}`, `{family}`, or `{image}`. |
| ~> **Note:** Either `source`, `source_image`, or `source_snapshot` is **required** in a disk block unless the disk type is `local-ssd`. Check the API [docs](https://cloud.google.com/compute/docs/reference/rest/v1/instanceTemplates/insert) for details. |
| |
| * `source_image_encryption_key` - (Optional) The customer-supplied encryption |
| key of the source image. Required if the source image is protected by a |
| customer-supplied encryption key. |
| |
| Instance templates do not store customer-supplied encryption keys, so you |
| cannot create disks for instances in a managed instance group if the source |
| images are encrypted with your own keys. Structure |
| [documented below](#nested_source_image_encryption_key). |
| |
| * `source_snapshot` - (Optional) The source snapshot to create this disk. |
| ~> **Note:** Either `source`, `source_image`, or `source_snapshot` is **required** in a disk block unless the disk type is `local-ssd`. Check the API [docs](https://cloud.google.com/compute/docs/reference/rest/v1/instanceTemplates/insert) for details. |
| |
| * `source_snapshot_encryption_key` - (Optional) The customer-supplied encryption |
| key of the source snapshot. Structure |
| [documented below](#nested_source_snapshot_encryption_key). |
| |
| * `interface` - (Optional) Specifies the disk interface to use for attaching this disk, |
| which is either SCSI or NVME. The default is SCSI. Persistent disks must always use SCSI |
| and the request will fail if you attempt to attach a persistent disk in any other format |
| than SCSI. Local SSDs can use either NVME or SCSI. |
| |
| * `mode` - (Optional) The mode in which to attach this disk, either READ_WRITE |
| or READ_ONLY. If you are attaching or creating a boot disk, this must |
| read-write mode. |
| |
| * `source` - (Optional) The name (**not self_link**) |
| of the disk (such as those managed by `google_compute_disk`) to attach. |
| ~> **Note:** Either `source`, `source_image`, or `source_snapshot` is **required** in a disk block unless the disk type is `local-ssd`. Check the API [docs](https://cloud.google.com/compute/docs/reference/rest/v1/instanceTemplates/insert) for details. |
| |
| * `disk_type` - (Optional) The GCE disk type. Such as `"pd-ssd"`, `"local-ssd"`, |
| `"pd-balanced"` or `"pd-standard"`. |
| |
| * `disk_size_gb` - (Optional) The size of the image in gigabytes. If not |
| specified, it will inherit the size of its base image. For SCRATCH disks, |
| the size must be exactly 375GB. |
| |
| * `labels` - (Optional) A set of ket/value label pairs to assign to disk created from |
| this template |
| |
| * `type` - (Optional) The type of GCE disk, can be either `"SCRATCH"` or |
| `"PERSISTENT"`. |
| |
| * `disk_encryption_key` - (Optional) Encrypts or decrypts a disk using a customer-supplied encryption key. |
| |
| If you are creating a new disk, this field encrypts the new disk using an encryption key that you provide. If you are attaching an existing disk that is already encrypted, this field decrypts the disk using the customer-supplied encryption key. |
| |
| If you encrypt a disk using a customer-supplied key, you must provide the same key again when you attempt to use this resource at a later time. For example, you must provide the key when you create a snapshot or an image from the disk or when you attach the disk to a virtual machine instance. |
| |
| If you do not provide an encryption key, then the disk will be encrypted using an automatically generated key and you do not need to provide a key to use the disk later. |
| |
| Instance templates do not store customer-supplied encryption keys, so you cannot use your own keys to encrypt disks in a managed instance group. Structure [documented below](#nested_access_config). |
| |
| * `resource_policies` (Optional) -- A list (short name or id) of resource policies to attach to this disk for automatic snapshot creations. Currently a max of 1 resource policy is supported. |
| |
| <a name="nested_source_image_encryption_key"></a>The `source_image_encryption_key` block supports: |
| |
| * `kms_key_service_account` - (Optional) The service account being used for the |
| encryption request for the given KMS key. If absent, the Compute Engine |
| default service account is used. |
| |
| * `kms_key_self_link` - (Required) The self link of the encryption key that is |
| stored in Google Cloud KMS. |
| |
| <a name="nested_source_snapshot_encryption_key"></a>The `source_snapshot_encryption_key` block supports: |
| |
| * `kms_key_service_account` - (Optional) The service account being used for the |
| encryption request for the given KMS key. If absent, the Compute Engine |
| default service account is used. |
| |
| * `kms_key_self_link` - (Required) The self link of the encryption key that is |
| stored in Google Cloud KMS. |
| |
| <a name="nested_disk_encryption_key"></a>The `disk_encryption_key` block supports: |
| |
| * `kms_key_self_link` - (Required) The self link of the encryption key that is stored in Google Cloud KMS |
| |
| <a name="nested_network_interface"></a>The `network_interface` block supports: |
| |
| * `network` - (Optional) The name or self_link of the network to attach this interface to. |
| Use `network` attribute for Legacy or Auto subnetted networks and |
| `subnetwork` for custom subnetted networks. |
| |
| * `subnetwork` - (Optional) the name of the subnetwork to attach this interface |
| to. The subnetwork must exist in the same `region` this instance will be |
| created in. Either `network` or `subnetwork` must be provided. |
| |
| * `network_attachment` - (Optional, [Beta](https://terraform.io/docs/providers/google/guides/provider_versions.html)) The URL of the network attachment that this interface should connect to in the following format: projects/{projectNumber}/regions/{region_name}/networkAttachments/{network_attachment_name}. |
| |
| * `subnetwork_project` - (Optional) The ID of the project in which the subnetwork belongs. |
| If it is not provided, the provider project is used. |
| |
| * `network_ip` - (Optional) The private IP address to assign to the instance. If |
| empty, the address will be automatically assigned. |
| |
| * `access_config` - (Optional) Access configurations, i.e. IPs via which this |
| instance can be accessed via the Internet. Omit to ensure that the instance |
| is not accessible from the Internet (this means that ssh provisioners will |
| not work unless you are running Terraform can send traffic to the instance's |
| network (e.g. via tunnel or because it is running on another cloud instance |
| on that network). This block can be repeated multiple times. Structure [documented below](#nested_access_config). |
| |
| * `alias_ip_range` - (Optional) An |
| array of alias IP ranges for this network interface. Can only be specified for network |
| interfaces on subnet-mode networks. Structure [documented below](#nested_alias_ip_range). |
| |
| * `nic_type` - (Optional) The type of vNIC to be used on this interface. Possible values: GVNIC, VIRTIO_NET. |
| |
| * `stack_type` - (Optional) The stack type for this network interface to identify whether the IPv6 feature is enabled or not. Values are IPV4_IPV6 or IPV4_ONLY. If not specified, IPV4_ONLY will be used. |
| |
| * `ipv6_access_config` - (Optional) An array of IPv6 access configurations for this interface. |
| Currently, only one IPv6 access config, DIRECT_IPV6, is supported. If there is no ipv6AccessConfig |
| specified, then this instance will have no external IPv6 Internet access. Structure [documented below](#nested_ipv6_access_config). |
| |
| * `queue_count` - (Optional) The networking queue count that's specified by users for the network interface. Both Rx and Tx queues will be set to this number. It will be empty if not specified. |
| |
| <a name="nested_access_config"></a>The `access_config` block supports: |
| |
| * `nat_ip` - (Optional) The IP address that will be 1:1 mapped to the instance's |
| network ip. If not given, one will be generated. |
| |
| * `network_tier` - (Optional) The [networking tier](https://cloud.google.com/network-tiers/docs/overview) used for configuring |
| this instance template. This field can take the following values: PREMIUM, |
| STANDARD or FIXED_STANDARD. If this field is not specified, it is assumed to be PREMIUM. |
| |
| <a name="nested_ipv6_access_config"></a>The `ipv6_access_config` block supports: |
| |
| * `network_tier` - (Optional) The service-level to be provided for IPv6 traffic when the |
| subnet has an external subnet. Only PREMIUM and STANDARD tier is valid for IPv6. |
| |
| <a name="nested_alias_ip_range"></a>The `alias_ip_range` block supports: |
| |
| * `ip_cidr_range` - The IP CIDR range represented by this alias IP range. This IP CIDR range |
| must belong to the specified subnetwork and cannot contain IP addresses reserved by |
| system or used by other network interfaces. At the time of writing only a |
| netmask (e.g. /24) may be supplied, with a CIDR format resulting in an API |
| error. |
| |
| * `subnetwork_range_name` - (Optional) The subnetwork secondary range name specifying |
| the secondary range from which to allocate the IP CIDR range for this alias IP |
| range. If left unspecified, the primary range of the subnetwork will be used. |
| |
| <a name="nested_service_account"></a>The `service_account` block supports: |
| |
| * `email` - (Optional) The service account e-mail address. If not given, the |
| default Google Compute Engine service account is used. |
| |
| * `scopes` - (Required) A list of service scopes. Both OAuth2 URLs and gcloud |
| short names are supported. To allow full access to all Cloud APIs, use the |
| `cloud-platform` scope. See a complete list of scopes [here](https://cloud.google.com/sdk/gcloud/reference/alpha/compute/instances/set-scopes#--scopes). |
| |
| The [service accounts documentation](https://cloud.google.com/compute/docs/access/service-accounts#accesscopesiam) |
| explains that access scopes are the legacy method of specifying permissions for your instance. |
| To follow best practices you should create a dedicated service account with the minimum permissions the VM requires. |
| To use a dedicated service account this field should be configured as a list containing the `cloud-platform` scope. |
| See [Authenticate workloads using service accounts best practices](https://cloud.google.com/compute/docs/access/create-enable-service-accounts-for-instances#best_practices) |
| and [Best practices for using service accounts](https://cloud.google.com/iam/docs/best-practices-service-accounts#single-purpose). |
| |
| <a name="nested_scheduling"></a>The `scheduling` block supports: |
| |
| * `automatic_restart` - (Optional) Specifies whether the instance should be |
| automatically restarted if it is terminated by Compute Engine (not |
| terminated by a user). This defaults to true. |
| |
| * `on_host_maintenance` - (Optional) Defines the maintenance behavior for this |
| instance. |
| |
| * `preemptible` - (Optional) Allows instance to be preempted. This defaults to |
| false. Read more on this |
| [here](https://cloud.google.com/compute/docs/instances/preemptible). |
| |
| * `node_affinities` - (Optional) Specifies node affinities or anti-affinities |
| to determine which sole-tenant nodes your instances and managed instance |
| groups will use as host systems. Read more on sole-tenant node creation |
| [here](https://cloud.google.com/compute/docs/nodes/create-nodes). |
| Structure [documented below](#nested_node_affinities). |
| |
| * `provisioning_model` - (Optional) Describe the type of preemptible VM. This field accepts the value `STANDARD` or `SPOT`. If the value is `STANDARD`, there will be no discount. If this is set to `SPOT`, |
| `preemptible` should be `true` and `automatic_restart` should be |
| `false`. For more info about |
| `SPOT`, read [here](https://cloud.google.com/compute/docs/instances/spot) |
| |
| * `instance_termination_action` - (Optional) Describe the type of termination action for `SPOT` VM. Can be `STOP` or `DELETE`. Read more on [here](https://cloud.google.com/compute/docs/instances/create-use-spot) |
| |
| * `max_run_duration` - (Optional) [Beta](https://terraform.io/docs/providers/google/guides/provider_versions.html) The duration of the instance. Instance will run and be terminated after then, the termination action could be defined in `instance_termination_action`. Only support `DELETE` `instance_termination_action` at this point. Structure is [documented below](#nested_max_run_duration). |
| <a name="nested_max_run_duration"></a>The `max_run_duration` block supports: |
| |
| * `nanos` - (Optional) Span of time that's a fraction of a second at nanosecond |
| resolution. Durations less than one second are represented with a 0 |
| `seconds` field and a positive `nanos` field. Must be from 0 to |
| 999,999,999 inclusive. |
| |
| * `seconds` - (Required) Span of time at a resolution of a second. Must be from 0 to |
| 315,576,000,000 inclusive. Note: these bounds are computed from: 60 |
| sec/min * 60 min/hr * 24 hr/day * 365.25 days/year * 10000 years. |
| |
| * `maintenance_interval` - (Optional) [Beta](https://terraform.io/docs/providers/google/guides/provider_versions.html) Specifies the frequency of planned maintenance events. The accepted values are: `PERIODIC`. |
| |
| * `local_ssd_recovery_timeout` - (Optional) (https://terraform.io/docs/providers/google/guides/provider_versions.html) Specifies the maximum amount of time a Local Ssd Vm should wait while recovery of the Local Ssd state is attempted. Its value should be in between 0 and 168 hours with hour granularity and the default value being 1 hour. Structure is [documented below](#nested_local_ssd_recovery_timeout). |
| <a name="nested_local_ssd_recovery_timeout"></a>The `local_ssd_recovery_timeout` block supports: |
| |
| * `nanos` - (Optional) Span of time that's a fraction of a second at nanosecond |
| resolution. Durations less than one second are represented with a 0 |
| `seconds` field and a positive `nanos` field. Must be from 0 to |
| 999,999,999 inclusive. |
| |
| * `seconds` - (Required) Span of time at a resolution of a second. Must be from 0 to |
| 315,576,000,000 inclusive. Note: these bounds are computed from: 60 |
| sec/min * 60 min/hr * 24 hr/day * 365.25 days/year * 10000 years. |
| |
| <a name="nested_guest_accelerator"></a>The `guest_accelerator` block supports: |
| |
| * `type` (Required) - The accelerator type resource to expose to this instance. E.g. `nvidia-tesla-k80`. |
| |
| * `count` (Required) - The number of the guest accelerator cards exposed to this instance. |
| |
| <a name="nested_node_affinities"></a>The `node_affinities` block supports: |
| |
| * `key` (Required) - The key for the node affinity label. |
| |
| * `operator` (Required) - The operator. Can be `IN` for node-affinities |
| or `NOT_IN` for anti-affinities. |
| |
| * `value` (Required) - The values for the node affinity label. |
| |
| <a name="nested_reservation_affinity"></a>The `reservation_affinity` block supports: |
| |
| * `type` - (Required) The type of reservation from which this instance can consume resources. |
| |
| * `specific_reservation` - (Optional) Specifies the label selector for the reservation to use.. |
| Structure is documented below. |
| |
| The `specific_reservation` block supports: |
| |
| * `key` - (Required) Corresponds to the label key of a reservation resource. To target a SPECIFIC_RESERVATION by name, specify compute.googleapis.com/reservation-name as the key and specify the name of your reservation as the only value. |
| |
| * `values` - (Required) Corresponds to the label values of a reservation resource. |
| |
| <a name="nested_shielded_instance_config"></a>The `shielded_instance_config` block supports: |
| |
| * `enable_secure_boot` (Optional) -- Verify the digital signature of all boot components, and halt the boot process if signature verification fails. Defaults to false. |
| |
| * `enable_vtpm` (Optional) -- Use a virtualized trusted platform module, which is a specialized computer chip you can use to encrypt objects like keys and certificates. Defaults to true. |
| |
| * `enable_integrity_monitoring` (Optional) -- Compare the most recent boot measurements to the integrity policy baseline and return a pair of pass/fail results depending on whether they match or not. Defaults to true. |
| |
| <a name="nested_confidential_instance_config"></a>The `confidential_instance_config` block supports: |
| |
| * `enable_confidential_compute` (Optional) Defines whether the instance should have confidential compute enabled with AMD SEV. [`on_host_maintenance`](#on_host_maintenance) has to be set to TERMINATE or this will fail to create the VM. |
| |
| * `confidential_instance_type` (Optional) [Beta](https://terraform.io/docs/providers/google/guides/provider_versions.html) Defines the confidential computing technology the instance uses. SEV is an AMD feature. One of the following values: `SEV`, `SEV_SNP`. [`on_host_maintenance`](#on_host_maintenance) has to be set to TERMINATE or this will fail to create the VM. If `SEV_SNP`, currently [`min_cpu_platform`](#min_cpu_platform) has to be set to `"AMD Milan"` or this will fail to create the VM. |
| |
| <a name="nested_network_performance_config"></a>The `network_performance_config` block supports: |
| |
| * `total_egress_bandwidth_tier` - (Optional) The egress bandwidth tier to enable. Possible values: TIER_1, DEFAULT |
| |
| <a name="nested_advanced_machine_features"></a>The `advanced_machine_features` block supports: |
| |
| * `enable_nested_virtualization` (Optional) Defines whether the instance should have [nested virtualization](#on_host_maintenance) enabled. Defaults to false. |
| |
| * `threads_per_core` (Optional) The number of threads per physical core. To disable [simultaneous multithreading (SMT)](https://cloud.google.com/compute/docs/instances/disabling-smt) set this to 1. |
| |
| * `visible_core_count` (Optional, [Beta](https://terraform.io/docs/providers/google/guides/provider_versions.html)) The number of physical cores to expose to an instance. [visible cores info (VC)](https://cloud.google.com/compute/docs/instances/customize-visible-cores). |
| |
| ## Attributes Reference |
| |
| In addition to the arguments listed above, the following computed attributes are |
| exported: |
| |
| * `id` - an identifier for the resource with format `projects/{{project}}/global/instanceTemplates/{{name}}` |
| |
| * `metadata_fingerprint` - The unique fingerprint of the metadata. |
| |
| * `self_link` - The URI of the created resource. |
| |
| * `self_link_unique` - A special URI of the created resource that uniquely identifies this instance template with the following format: `projects/{{project}}/global/instanceTemplates/{{name}}?uniqueId={{uniqueId}}` |
| Referencing an instance template via this attribute prevents Time of Check to Time of Use attacks when the instance template resides in a shared/untrusted environment. |
| |
| * `tags_fingerprint` - The unique fingerprint of the tags. |
| |
| [1]: /docs/providers/google/r/compute_instance_group_manager.html |
| [2]: /docs/language/meta-arguments/lifecycle.html |
| |
| ## Timeouts |
| |
| This resource provides the following |
| [Timeouts](https://developer.hashicorp.com/terraform/plugin/sdkv2/resources/retries-and-customizable-timeouts) configuration options: configuration options: |
| |
| - `create` - Default is 4 minutes. |
| - `delete` - Default is 4 minutes. |
| |
| ## Import |
| |
| Instance templates can be imported using any of these accepted formats: |
| |
| * `projects/{{project}}/global/instanceTemplates/{{name}}` |
| * `{{project}}/{{name}}` |
| * `{{name}}` |
| |
| In Terraform v1.5.0 and later, use an [`import` block](https://developer.hashicorp.com/terraform/language/import) to import instance templates using one of the formats above. For example: |
| |
| ```tf |
| import { |
| id = "projects/{{project}}/global/instanceTemplates/{{name}}" |
| to = google_compute_instance_template.default |
| } |
| ``` |
| |
| When using the [`terraform import` command](https://developer.hashicorp.com/terraform/cli/commands/import), instance templates can be imported using one of the formats above. For example: |
| |
| ``` |
| $ terraform import google_compute_instance_template.default projects/{{project}}/global/instanceTemplates/{{name}} |
| $ terraform import google_compute_instance_template.default {{project}}/{{name}} |
| $ terraform import google_compute_instance_template.default {{name}} |
| ``` |