This document explains how to consume reservations in Compute Engine. To learn how to consume reservations in other Google Cloud products, see the following documentation:
- Batch
- Dataflow
- Dataproc
- Google Kubernetes Engine
- Cloud TPU
- Vertex AI:
After you create a reservation, or Compute Engine automatically creates a reservation for you to fulfill a future reservation, Compute Engine holds your reserved resources for you. You can then use those reserved resources to create Compute Engine instances that match the reservation's properties. This action is known as consuming a reservation. You can use your reserved capacity for creating instances until the reservation is fully consumed.
Limitations
You can't consume a reservation to create the following Compute Engine resources:
- Spot VMs or preemptible instances 
- Sole-tenant nodes 
Before you begin
- 
  
  If you haven't already, set up authentication.
  Authentication verifies your identity for access to Google Cloud services and APIs. To run
  code or samples from a local development environment, you can authenticate to
  Compute Engine by selecting one of the following options:
  
    
    
      
    
  
    
    
      
    
  
    
    
      
    
  
 
  
 
  
    
      Select the tab for how you plan to use the samples on this page: ConsoleWhen you use the Google Cloud console to access Google Cloud services and APIs, you don't need to set up authentication. gcloud- 
 
  
  
  
    
    
  
    
    
  
    
    
      
    
  
  
    
    
  
    
    
  
    
    
  
  
  
   
    
      Install the Google Cloud CLI. After installation, initialize the Google Cloud CLI by running the following command: gcloud initIf you're using an external identity provider (IdP), you must first sign in to the gcloud CLI with your federated identity. 
- Set a default region and zone.
 GoTo use the Go samples on this page in a local development environment, install and initialize the gcloud CLI, and then set up Application Default Credentials with your user credentials. Install the Google Cloud CLI. If you're using an external identity provider (IdP), you must first sign in to the gcloud CLI with your federated identity. If you're using a local shell, then create local authentication credentials for your user account: gcloud auth application-default login You don't need to do this if you're using Cloud Shell. If an authentication error is returned, and you are using an external identity provider (IdP), confirm that you have signed in to the gcloud CLI with your federated identity. For more information, see Set up authentication for a local development environment. JavaTo use the Java samples on this page in a local development environment, install and initialize the gcloud CLI, and then set up Application Default Credentials with your user credentials. Install the Google Cloud CLI. If you're using an external identity provider (IdP), you must first sign in to the gcloud CLI with your federated identity. If you're using a local shell, then create local authentication credentials for your user account: gcloud auth application-default login You don't need to do this if you're using Cloud Shell. If an authentication error is returned, and you are using an external identity provider (IdP), confirm that you have signed in to the gcloud CLI with your federated identity. For more information, see Set up authentication for a local development environment. Node.jsTo use the Node.js samples on this page in a local development environment, install and initialize the gcloud CLI, and then set up Application Default Credentials with your user credentials. Install the Google Cloud CLI. If you're using an external identity provider (IdP), you must first sign in to the gcloud CLI with your federated identity. If you're using a local shell, then create local authentication credentials for your user account: gcloud auth application-default login You don't need to do this if you're using Cloud Shell. If an authentication error is returned, and you are using an external identity provider (IdP), confirm that you have signed in to the gcloud CLI with your federated identity. For more information, see Set up authentication for a local development environment. PythonTo use the Python samples on this page in a local development environment, install and initialize the gcloud CLI, and then set up Application Default Credentials with your user credentials. Install the Google Cloud CLI. If you're using an external identity provider (IdP), you must first sign in to the gcloud CLI with your federated identity. If you're using a local shell, then create local authentication credentials for your user account: gcloud auth application-default login You don't need to do this if you're using Cloud Shell. If an authentication error is returned, and you are using an external identity provider (IdP), confirm that you have signed in to the gcloud CLI with your federated identity. For more information, see Set up authentication for a local development environment. RESTTo use the REST API samples on this page in a local development environment, you use the credentials you provide to the gcloud CLI. Install the Google Cloud CLI. If you're using an external identity provider (IdP), you must first sign in to the gcloud CLI with your federated identity. For more information, see Authenticate for using REST in the Google Cloud authentication documentation. 
- 
 
  
  
  
    
    
  
    
    
  
    
    
      
    
  
  
    
    
  
    
    
  
    
    
  
  
  
   
    
      
Required roles
    
      To get the permissions that
      you need to consume reservations,
    
      ask your administrator to grant you the
    
  
  
    
      Compute Instance Admin (v1)  (roles/compute.instanceAdmin.v1)
     IAM role on the project.
  
  
  
  
  For more information about granting roles, see Manage access to projects, folders, and organizations.
  
  
This predefined role contains the permissions required to consume reservations. To see the exact permissions that are required, expand the Required permissions section:
Required permissions
The following permissions are required to consume reservations:
- 
                To create reservations:
                   compute.reservations.createon the project
- 
                To create instances:
                   - compute.instances.createon the project
- To use a custom image to create the VM: compute.images.useReadOnlyon the image
- To use a snapshot to create the VM: compute.snapshots.useReadOnlyon the snapshot
- To use an instance template to create the VM:  compute.instanceTemplates.useReadOnlyon the instance template
- To assign a legacy network to the VM:  compute.networks.useon the project
- To specify a static IP address for the VM: compute.addresses.useon the project
- To assign an external IP address to the VM when using a legacy network:  compute.networks.useExternalIpon the project
- To specify a subnet for the VM: compute.subnetworks.useon the project or on the chosen subnet
- To assign an external IP address to the VM when using a VPC network:  compute.subnetworks.useExternalIpon the project or on the chosen subnet
- To set VM instance metadata for the VM: compute.instances.setMetadataon the project
- To set tags for the VM: compute.instances.setTagson the VM
- To set labels for the VM: compute.instances.setLabelson the VM
- To set a service account for the VM to use: compute.instances.setServiceAccounton the VM
- To create a new disk for the VM: compute.disks.createon the project
- To attach an existing disk in read-only or read-write mode: compute.disks.useon the disk
- To attach an existing disk in read-only mode: compute.disks.useReadOnlyon the disk
 
- 
                To create instance templates:
                   compute.instanceTemplates.createon the project
You might also be able to get these permissions with custom roles or other predefined roles.
Consume a reservation
The examples in the following sections show how to consume a reservation by creating a single compute instance. You can also consume reservations by creating instances that match the reservations' properties using a different deployment option, or by updating the properties of existing instances to match automatically consumed reservations.
To consume a reservation, use one of the following methods:
- To create an instance that consumes an automatic reservation, regardless of how that reservation was created, see Consume an automatically consumed reservation. 
- To create an instance that consumes a specific reservation that you created, see Consume a specifically targeted reservation. 
- To create an instance to consume a specific reservation that was automatically created by Compute Engine (in this case, to fulfill a future reservation in calendar mode), see Consume an auto-created reservation for a request in calendar mode. 
Consume an automatically consumed reservation
Automatically consumed reservations allow any compute instances that match the reservation's properties to automatically consume it. This consumption behavior applies to both new and existing, running instances. When you create reservations, or Compute Engine automatically creates a reservation to fulfill a future reservation, this reservation type is the default setting.
If the properties of a single-project, automatic reservation and a shared, automatic reservation match, then the instances in your project consume the single-project reservation first, and then they consume the shared reservation. For more information, see the consumption order for reservations.
To create and consume an example automatic reservation, select one of the following options:
Console
The following example shows how to create an automatic reservation in zone
us-central1-a for three N2 instances with 32 vCPUs, and Intel Cascade Lake
as the minimum CPU platform. It also shows how to create a single instance
to consume the reservation.
To create the example automatic reservation and consume it, do the following:
- To create an example reservation, complete the following steps: - In the Google Cloud console, go to the Reservations page. - The remaining steps automatically appear in the Google Cloud console. 
- On the On-demand reservation tab (default), click Create reservation. The Create a reservation page appears. 
- In the Name field, enter a name for the reservation. For example, enter - reservation-01.
- Select the Region and Zone where to reserve resources. For example, select us-central1 and us-central1-a respectively. 
- In the Share type section, do one of the following: - To create a single-project reservation, select Local. 
- To create a shared reservation, select Shared, and then specify the projects that you want to share the reservation with. 
 
- In the Use with VM instance section, select Use reservation automatically, if it isn't already selected. 
- In the Number of VM instances field, enter - 3.
- On the General purpose tab, select N2. 
- In the Machine type section, on the Preset tab (default), select n2-standard-32. 
- Expand CPU platform and GPU, and then, in the CPU platform field, select Intel Cascade Lake or later. 
- Click Create. 
 
- To create an instance that consumes the example reservation, complete the following steps: - In the Google Cloud console, go to the Create an instance page. - The Create an instance page appears and displays the Machine configuration pane. 
- In the Machine configuration pane, do the following: - In the Name field, enter a name for the instance. For this example, enter - instance-01.
- Specify the Region and Zone where to reserve resources. For this example, select us-central1 and us-central1-a respectively. 
- On the General purpose tab, select N2. 
- In the Machine type section, on the Preset tab (default), select n2-standard-32. 
- Expand the Advanced options section, and then, in the CPU platform field, select Intel Cascade Lake or later. 
 
- Optional: Automatically consuming a matching reservation is the default setting. However, if you want to specify this setting, do the following: - In the navigation menu, click Advanced. The Advanced pane appears. 
- In the Reservations section, select Use automatic selection. 
 
- Click Create. 
 
gcloud
The following example shows how to create an automatic reservation in zone
us-central1-a for three N2 instances with 32 vCPUs, and Intel Cascade Lake
as the minimum CPU platform. It also shows how to create a single instance
to consume the reservation.
To create the example automatic reservation and consume it, do the following:
- To create the example reservation, use the - gcloud compute reservations createcommand:- gcloud compute reservations create reservation-01 \ --machine-type=n2-standard-32 \ --min-cpu-platform="Intel Cascade Lake" \ --vm-count=3 \ --zone=us-central1-a
- To create an instance that consumes the example reservation, use the - gcloud compute instances createcommand with the- --reservation-affinityflag set to- any. Because- anyis the default configuration, you can also omit this flag.- gcloud compute instances create instance-01 \ --machine-type=n2-standard-32 \ --min-cpu-platform="Intel Cascade Lake" \ --reservation-affinity=any \ --zone=us-central1-a
Go
To create the example automatic reservation using an instance template, and create an instance to consume the reservation using the same template, use the following code sample:
Java
The following example shows how to create an N1 instance with four vCPUs,
and Intel Skylake as the minimum CPU platform in zone us-central1-a. The
instance automatically consumes a matching reservation.
To create the example instance, use the following code sample:
Node.js
The following example shows how to create an N1 instance with four vCPUs,
and Intel Skylake as the minimum CPU platform in zone us-central1-a. The
instance automatically consumes a matching reservation.
To create the example instance, use the following code sample:
Python
The following example shows how to create an automatic reservation in zone
us-central1-a for three N1 instances with one vCPU, and Intel Ivy as the
minimum CPU platform. It also shows how to create a single instance to
consume the reservation.
To create the example automatic reservation and consume it, do the following:
REST
The following example shows how to create an automatic reservation in zone
us-central1-a for three N2 instances with 32 vCPUs, and Intel Cascade Lake
as the minimum CPU platform. It also shows how to create a single instance
to consume the reservation.
To create the example automatic reservation and consume it, do the following:
- To create the example reservation, make a - POSTrequest to- reservations.insertmethod:- POST https://compute.googleapis.com/compute/v1/projects/example-project/zones/us-central1-a/reservations { "name": "reservation-01", "specificReservation": { "count": "3", "instanceProperties": { "machineType": "n2-standard-32", "minCpuPlatform": "Intel Cascade Lake", } } }
- To create an instance that consumes the example reservation, make a - POSTrequest to the- instances.insertmethod. In the request body, include the- consumeReservationTypefield set to- ANY_RESERVATION. However, because- ANY_RESERVATIONis the default configuration, you can also omit the field.- POST https://compute.googleapis.com/compute/v1/projects/example-project/zones/us-central1-a/instances { "name": "instance-01", "machineType": "zones/us-central1-a/machineTypes/n2-standard-32", "minCpuPlatform": "Intel Cascade Lake", "disks": [ { "boot": true, "initializeParams": { "sourceImage": "projects/debian-cloud/global/images/family/debian-12" } } ], "networkInterfaces": [ { "network": "global/networks/default" } ], "reservationAffinity": { "consumeReservationType": "ANY_RESERVATION" } }
Consume a specifically targeted reservation
Specifically targeted reservations allow new compute instances that match the reservation's properties and target the reservation to consume it. Instances are successfully created only if their properties match the reservation properties. Otherwise, you encounter errors.
Based on the creation method that you want to use, create specific reservations and instances that target them as follows:
| Creation method | When you create a reservation | When you create instances to consume the reservation | 
|---|---|---|
| Google Cloud console | In the Use with VM instance section, select Select specific reservation. | In the Advanced pane, in the Reservations section, select Choose a reservation. Then, follow the prompts to select a reservation. | 
| Google Cloud CLI | Include the --require-specific-reservationflag. | Include the following flags: 
 | 
| Go | Include the SpecificReservationRequiredfield set totrue. | In the ReservationAffinityfield, include the following
        fields:
 | 
| Java | Include the setSpecificReservationRequiredfield set totrue. | In the ReservationAffinityfield, include the following
        fields:
 | 
| Node.js and REST API | Include the specificReservationRequiredfield set totrue. | In the reservationAffinityfield, include the following
        fields:
 | 
| Python | Include the specific_reservation_requiredfield set totrue. | In the reservation_affinityfield, include the following
        fields:
 | 
| Terraform | Include the specific_reservation_requiredfield set totrue. | In the reservation_affinityfield, include the following
        fields:
 | 
To create an example specific reservation and an instance to consume it, select one of the following options:
Console
The following example shows how to create a specific reservation in zone
us-central1-a for three N2 instances with 32 vCPUs, and Intel Cascade Lake
as the minimum CPU platform. It also shows how to create a single instance
to consume the reservation.
To create the example specific reservation and consume it, do the following:
- To create an example reservation, complete the following steps: - In the Google Cloud console, go to the Reservations page. - The remaining steps automatically appear in the Google Cloud console. 
- On the On-demand reservation tab (default), click Create reservation. The Create a reservation page appears. 
- In the Name field, enter a name for the reservation. For example, enter - reservation-02.
- Specify the Region and Zone where to reserve resources. For this example, select us-central1 and us-central1-a respectively. 
- In the Share type section, do one of the following: - To create a single-project reservation, select Local. 
- To create a shared reservation, select Shared, and then specify the projects that you want to share the reservation with. 
 
- In the Use with VM instance section, select Select specific reservation. 
- In the Number of VM instances field, enter - 3.
- On the General purpose tab, select N2. 
- In the Machine type section, on the Preset tab (default), select n2-standard-32. 
- Expand CPU platform and GPU, and then, in the CPU platform field, select Intel Cascade Lake or later. 
- Click Create. 
 
- To create an instance that consumes the example reservation, complete the following steps: - In the Google Cloud console, go to the Create an instance page. - The Create an instance page appears and displays the Machine configuration pane. 
- In the Machine configuration pane, do the following: - In the Name field, enter a name for the instance. For this example, enter - instance-02.
- Specify the Region and Zone where to reserve resources. For this example, select us-central1 and us-central1-a respectively. 
- On the General purpose tab, select N2. 
- In the Machine type section, on the Preset tab (default), select n2-standard-32. 
- Expand the Advanced options section, and then, in the CPU platform field, select Intel Cascade Lake or later. 
 
- In the navigation menu, click Advanced. The Advanced pane appears. 
- In the Reservations section, select Choose a reservation, and then click Choose reservation. 
- On the Choose a reservation pane that appears, do the following: - Select the specific reservation that you created in the previous steps. If you want to consume a shared reservation that exists in a different project, then, in the Project list, select the project in which the reservation exists. 
- Click Choose. 
 
- Click Create. 
 
gcloud
The following example shows how to create a specific reservation in zone
us-central1-a for three N2 instances with 32 vCPUs, and Intel Cascade Lake
as the minimum CPU platform. It also shows how to create a single instance
to consume the reservation.
To create the example specific reservation and consume it, do the following:
- To create the example reservation, use the - gcloud compute reservations createcommand with the- --require-specific-reservationflag:- gcloud compute reservations create reservation-02 \ --machine-type=n2-standard-32 \ --min-cpu-platform="Intel Cascade Lake" \ --require-specific-reservation \ --vm-count=3 \ --zone=us-central1-a
- To create an instance that consumes the example reservation, use the - gcloud compute instances createcommand with the- --reservationand- --reservation-affinity=specificflags:- gcloud compute instances create instance-02 \ --machine-type=n2-standard-32 \ --min-cpu-platform="Intel Cascade Lake" \ --reservation-affinity=specific \ --reservation=RESERVATION_URL \ --zone=us-central1-a- Replace - RESERVATION_URLwith the URL of the reservation. Specify one of the following values:- If you created the reservation in the same project: - reservation-02
- If the reservation is in a different project: - projects/PROJECT_ID/reservations/reservation-02
 
Go
The following examples show how to create an N2 instance with 32 vCPUs, and
Intel Cascade Lake as the minimum CPU platform, in zone us-central1-a to
consume a specific, matching reservation:
- To create the example instance to consume a single-project, specific reservation, use the following code sample: 
- To create the example instance to consume a shared, specific reservation, use the following code sample: 
Java
The following examples show how to create an N1 instance with four vCPUs,
and Intel Skylake as the minimum CPU platform, in zone us-central1-a to
consume a specific, matching reservation:
- To create an example reservation as a single-project reservation, and create an instance to consume it, use the following code sample: 
- To create an example reservation as a shared reservation, and create an instance to consume it, use the following code sample: 
Node.js
The following examples show how to create an N1 instance with 4 vCPUs, and
Intel Skylake as the minimum CPU platform, in zone us-central1-a to
consume a specific, matching reservation:
Python
The following examples show how to create an N2 instance with 32 vCPUs, and
Intel Cascade Lake as the minimum CPU platform, in zone us-central1-a to
consume a specific, matching reservation:
To create the example specific reservation and consume it, do the following:
- To create and consume the example reservation as a single-project reservation, use the following code sample: 
- To create and consume the example reservation as a shared reservation, use the following code sample: 
REST
The following example shows how to create a specific reservation in zone
us-central1-a for three N2 instances with 32 vCPUs, and Intel Cascade Lake
as the minimum CPU platform. It also shows how to create a single instance
to consume the reservation.
To create the example specific reservation and consume it, do the following:
- To create the example reservation, make a - POSTrequest to the- instances.insertmethod. In the request body, include the- specificReservationRequiredfield set to- true:- POST https://compute.googleapis.com/compute/v1/projects/example-project/zones/us-central1-a/reservations { "name": "reservation-02", "specificReservation": { "count": "3", "instanceProperties": { "machineType": "n2-standard-32", "minCpuPlatform": "Intel Cascade Lake", } }, "specificReservationRequired": true }
- To create an instance that consumes the example reservation, make a - POSTrequest to the- instances.insertmethod. In the request body, in the- reservationAffinityfield, include the following:- The - consumeReservationTypefield set to- SPECIFIC_RESERVATION.
- The - keyfield set to- compute.googleapis.com/reservation-name.
- The - valuesfield set to the URL of the reservation.
 - The request is similar to the following: - POST https://compute.googleapis.com/compute/v1/projects/example-project/zones/us-central1-a/instances { "name": "instance-02", "machineType": "zones/us-central1-a/machineTypes/n2-standard-32", "minCpuPlatform": "Intel Cascade Lake", "disks": [ { "boot": true, "initializeParams": { "sourceImage": "projects/debian-cloud/global/images/family/debian-12" } } ], "networkInterfaces": [ { "network": "global/networks/default" } ], "reservationAffinity": { "consumeReservationType": "SPECIFIC_RESERVATION", "key": "compute.googleapis.com/reservation-name", "values": [ "RESERVATION_URL" ] } }- Replace - RESERVATION_URLwith the URL of the reservation. Specify one of the following values:- If you created the reservation in the same project: - reservation-02
- If the reservation is in a different project: - projects/PROJECT_ID/reservations/reservation-02
 
Consume an auto-created reservation for a request in calendar mode
This reservation type allows new compute instances to consume a reservation that Compute Engine automatically creates (auto-creates) to fulfill a future reservation in calendar mode.
To consume this type of reservation, you must create an instance as follows:
- The instance must specifically target the reservation. 
- The instance must be stopped or deleted at the reservation end time. 
- The instance must use the reservation-bound provisioning model. When you create an instance, you can specify this model as follows: - In the Google Cloud console, if you specify a supported machine type for future reservations in calendar mode, then the reservation-bound model is automatically selected. 
- In the gcloud CLI, include the - --provisioning-modelflag set to- reservation-bound.
- In the REST API, include the - provisioningModelfield set to- RESERVATION_BOUND.
 
The following example creates a future reservation request in calendar mode for A3 Ultra instances. The example also shows the fields to specify when you create a standalone A3 Ultra instance to consume the auto-created reservation for the request.
To consume the example auto-created reservation, select one of the following options:
Console
- Create an example request for five A3 Ultra instances and submit it for review: - In the Google Cloud console, go to the Reservations page. 
- Click the Future reservations tab. 
- Click Create future reservation. The Create a future reservation page appears. 
- In the Hardware configuration section, select Specify machine type, and then specify an A3 Ultra instance. 
- In the Obtainability method section, complete the following steps: - Select Search for capacity for up to 90 days. 
- In the Region and Zone lists, specify the region and zone where to reserve resources. For this example, select us-central1 and us-central1-a respectively. 
- In the Total capacity needed field, enter - 5.
- In the Reservation period section, specify the reservation period for the reservation. 
 
- Specify the remaining fields, and then click Submit. 
 
- At the request start time, to create an A3 Ultra instance to consume the example auto-created reservation, do the following: - In the Google Cloud console, go to the Create an instance page. 
- In the Name field, enter a name for the instance. For this example, enter - example-instance.
- Specify the Region and Zone where you want to reserve resources. For this example, select us-central1 and us-central1-a respectively. 
- Click the GPUs tab, and then, in the GPU type list, select NVIDIA H200 141GB. This action specifies an A3 Ultra instance and sets the provisioning model to Reservation-bound. 
- In the navigation menu, click Advanced. 
- In the Reservations section, select Choose a reservation, and then click Choose a reservation. 
- On the Choose a reservation pane, do the following: - Select a specific reservation. If you want to consume a shared reservation that exists in a different project, then, in the Project list, select the project in which the reservation exists. 
- Click Choose. 
 
- In the Provisioning model section, expand the VM provisioning model advanced settings section. 
- In the On VM termination list, select Stop (default) or Delete. 
- Click Create. 
 
gcloud
- To create an example request for five A3 Ultra VMs and submit it for review, use the - gcloud compute future-reservations createcommand:- gcloud compute future-reservations create example-fr \ --auto-delete-auto-created-reservations \ --deployment-type=DENSE \ --planning-status=SUBMITTED \ --require-specific-reservation \ --reservation-mode=CALENDAR \ --reservation-name=example-reservation \ --share-type=local \ --start-time=2025-10-05T00:00:00Z \ --end-time=2025-10-19T00:00:00Z \ --machine-type=a3-ultragpu-8g \ --total-count=5 \ --zone=us-central1-a- Assume that Google Cloud approves the request and Compute Engine automatically creates an empty reservation. At the request start time, on October 5, 2025, Compute Engine increases the number of reserved GPU VMs in the reservation. You can then consume the reservation. 
- At the request start time, to create an A3 Ultra instance to consume the example auto-created reservation, use the - gcloud compute instances createcommand with the following flags:- The - --instance-termination-actionflag.
- The - --provisioning-modelflag set to- RESERVATION_BOUND.
- The - --reservationflag.
- The - --reservation-affinityflag set to- specific.
 - The command is similar to the following. For the full requirements to create an A3 Ultra instance, see Create an A3 Ultra or A4 instance. - gcloud compute instance create example-instance \ --machine-type=a3-ultragpu-8g \ --instance-termination-action=TERMINATION_ACTION \ --provisioning-model=RESERVATION_BOUND \ --reservation-affinity=specific \ --reservation=RESERVATION_URL \ --zone=us-central1-a \ ...- The command includes the following values: - TERMINATION_ACTION: whether Compute Engine stops (- STOP) or deletes (- DELETE) the VM at the end of the reservation period.
- RESERVATION_URL: the URL of the reservation, which is formatted as follows:- If the auto-created reservation exists in your project: - example-reservation.
- If the auto-created reservation exists in a different project: - projects/PROJECT_ID/reservations/example-reservation.
 
 
REST
- To create an example request for five A3 Ultra instances and submit it for review, make a - POSTrequest to the- futureReservations.insertmethod:- POST https://compute.googleapis.com/compute/v1/projects/example-project/zones/us-central1-a/futureReservations { "name": "example-request-calendar-mode", "autoDeleteAutoCreatedReservations": true, "deploymentType": "DENSE", "planningStatus": "SUBMITTED", "reservationMode": "CALENDAR", "reservationName": "example-reservation", "shareSettings": { "shareType": "LOCAL" }, "specificReservationRequired": true, "specificSkuProperties": { "machineType": "a3-ultragpu-8g", "totalCount": 5 }, "timeWindow": { "startTime": "2025-10-05T00:00:00Z", "endTime": "2025-10-19T00:00:00Z" } }- Assume that Google Cloud approves the request and Compute Engine automatically creates an empty reservation. At the request start time, on October 5, 2025, Compute Engine increases the number of reserved GPU VMs in the reservation. You can then consume the reservation. 
- At the request start time, to create an A3 Ultra instance to consume the example auto-created reservation, make a - POSTrequest to- instances.insertmethod. In the request body, include the following fields:- The - reservationAffinity.consumeReservationTypefield set to- SPECIFIC_RESERVATION.
- The - reservationAffinity.keyfield set to- compute.googleapis.com/reservation-name.
- The - reservationAffinity.valuesfield set to the URL of the reservation.
- The - scheduling.instanceTerminationActionfield.
- The - scheduling.provisioningModelfield set to- RESERVATION_BOUND.
 - The request is similar to the following. For the full requirements to create an A3 Ultra instance, see Create an A3 Ultra or A4 instance. - POST https://compute.googleapis.com/compute/v1/projects/example-project/zones/us-central1-a/ { { "machineType": "projects/example-project/zones/us-central1-a/machineTypes/a3-ultragpu-8g", "name": "example-instance", "reservationAffinity": { "consumeReservationType": "SPECIFIC_RESERVATION", "key": "compute.googleapis.com/reservation-name", "values":[ "RESERVATION_URL" ], }, "scheduling": { "instanceTerminationAction": "TERMINATION_ACTION", "provisioningModel": "RESERVATION_BOUND" }, ... } }- The request body includes the following values: - RESERVATION_URL: the URL of the reservation, which is formatted as follows:- If the auto-created reservation exists in your project: - example-reservation.
- If the auto-created reservation exists in a different project: - projects/PROJECT_ID/reservations/example-reservation.
 
- TERMINATION_ACTION: whether Compute Engine stops (- STOP) or deletes (- DELETE) the VM at the end of the reservation period.
 
Test that instance properties match an automatically consumed reservation
To test if a compute instance's properties match an automatically consumed reservation, do the following:
- Create a copy of the reservation as a specifically targeted reservation for a single instance. 
- Create a test instance to consume the reservation. 
If you can create the test instance, then its properties match the properties of the test reservation. Otherwise, you encounter errors.
After you confirm that the properties of your test instance and test reservation match, delete the reservation and the test instance.
Verify reservations consumption
To verify reservations consumption, you can do one or more of the following:
- To view the current number of compute instances that are consuming your reservations, and how many more instances can consume them, view reservations. 
- To monitor reservations consumption data updated every 30 minutes, and receive alerts when reservations are consumed or unconsumed, monitor reservations consumption. 
- To view reservations consumption data updated every 24 hours, do one of the following: - To receive consumption reports in a Cloud Storage bucket to analyze consumption trends and identify unconsumed reservations, view reservations usage report.
 - To view past and forecasted reservations consumption to analyze consumption trends and plan for future capacity needs, use Capacity Planner.