To help you manage the resource requirements for your projects, Compute Engine lets you merge or split your existing commitments and redistribute your resources to match the granularity required for your projects.
This document describes the benefits and process of merging and splitting commitments, along with the limitations and requirements that apply.
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.
 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. 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. For more information, see Authenticate for using REST in the Google Cloud authentication documentation. 
- 
 
  
  
  
    
    
  
    
    
  
    
    
      
    
  
  
    
    
  
    
    
  
    
    
  
  
  
   
    
      
Merge commitments
You can merge multiple compatible commitments to create a new larger commitment. By merging commitments together, you can track and manage them as a single entity. Merging commitments helps you avoid staggered commitment end dates by co-terming the individual commitments to expire at the same time. Merging also lets you gradually ramp up your workloads. For example, you can purchase newer, smaller commitments when the need arises and choose to merge them together or with an existing commitment.
How merging works
When you merge individual commitments (source commitments) together, you create a new commitment (merged commitment) with the combined resources from all the source commitments. At 12 AM US and Canadian Pacific Time (UTC-8, or UTC-7 during daylight saving time) on the following day, the merged commitment becomes active and the source commitments get cancelled. This date of activation becomes the start date for the merged commitment and the merge operation ends.
Additionally, the newly created merged commitment inherits the following properties, regardless of whether the source commitments have the preset term length or a custom term length:
- The end date that is furthest in the future among the source commitments.
- The term extension eligibility window that ends the earliest among the source commitments.
Because the merged commitment gets created only after your source commitments are already active, the merged commitment might have a custom term length and not the preset 1 or 3 years. However, the merged commitment retains the 1- or 3-year commitment plan of the source commitments.
For example, consider two source commitments that start on January 1, 2020, and December 1, 2020, respectively. The commitments have their end dates as January 1, 2023, and December 1, 2023, respectively. The term extension eligibility window for the first commitment remains open until May 1, 2020, and for the second commitment until April 1, 2021. If you merge these commitments on March 1, 2022, then your merged commitment is a custom term commitment that has a start date of March 2, 2022 and an end date of December 1, 2023. The term extension eligibility window for the merged commitment would have already ended by May 1, 2020.
If any of the source commitments have reservations attached, then the reservations are preserved during the merge and are attached to the merged commitment after its creation. To learn more about commitments with attached reservations, see Attach reservations to resource-based commitments.
Example of a merged commitment
The following table shows the properties of source and merged commitments in a
scenario where two commitments (source-commitment-1 and source-commitment-2)
are merged into one single commitment (merged-commitment) on March 1, 2022:
| First source commitment (before merge) | Second source commitment (before merge) | Merged commitment | |
|---|---|---|---|
| Name | source-commitment-1 | source-commitment-2 | merged-commitment | 
| Type | N2 | N2 | N2 | 
| Region | us-central-1 | us-central-1 | us-central-1 | 
| Resources | 
 | 
 | 
 | 
| Term | 3 years | 3 years | 3 years | 
| Start date* | January 1, 2020 | December 1, 2020 | March 2, 2022 (the day after the merge) | 
| End date† | January 1, 2023 | December 1, 2023 | December 1, 2023 | 
| Term extension eligibility window open until | May 1, 2020 | April 1, 2021 | May 1, 2020 | 
*All commitments start at 12 AM US and Canadian Pacific Time (UTC-8 or UTC-7) on the specified start date. †All commitments expire at 12 AM US and Canadian Pacific Time (UTC-8 or UTC-7) on the specified end date.
Pricing implications
Your commitment fee is the sum of the discounted prices of all your committed resources. When you merge your commitment, the discounted prices of your merged commitment's resources might change on the day your merged commitment becomes active. This new discounted price for each resource stays the same until the end of your merged commitment's term, even if the on-demand prices change. However, if you merge or split this commitment again in the future, the discounted prices of the resources might change again.
Limitations
- You can't merge license commitments.
- At the time of creation of merged commitments, you can't create any new reservations and attach them to those commitments.
- You can't merge commitments that have expired or are cancelled.
- By default, when you create merged commitments, the auto-renew setting is disabled on the new commitments even if all the source commitments were set to renew automatically. If you want your merged commitments to renew automatically, you must manually enable the auto-renew setting on those commitments. You can do so either at the time of their creation or after their creation.
Requirements
When you merge individual source commitments to create a new merged commitment, your source and merged commitments must meet the following requirements:
- The source commitments must have the same project, region, commitment plan, commitment type, and commitment category.
- The new merged commitment must have the same project, region, commitment plan, commitment type, and commitment category as the source commitments. However, you can choose a new name for your merged commitment.
- The resource types you specify for your merged commitment must be the exact same resources types that are in the source commitments. Additionally, the amount of resources for each resource type in your new merged commitment must be equal to the sum of the amounts of resources for that resource type in all the source commitments. For example, if the first source commitment has 100 vCPUs and 100 GB memory and the second source commitment has 200 vCPUs and 300 GB memory, then you must create your merged commitment with 300 vCPUs and 400 GB memory.
- The source and merged commitments must be for hardware resources (vCPUs, memory, GPUs, and Local SSD disks).
Create merged commitments
Create a merged commitment by using the gcloud CLI or the REST. Before you merge commitments, review the limitations for merging.
Console
- In the Google Cloud console, select the project where you want to merge commitments and go to the Committed use discounts page. 
- To initiate the merge operation for a set of commitments, in the Hardware commitments tab of the Commitment list page, click Merge. - Alternatively, you can also select the commitments that you want to merge from the list and then click Merge. 
- On the Choose commitment tab of the Merge page that opens, do the following: - Under Choose commitments to merge, select the commitments that you want to merge from the list. If you already selected these commitments on the Commitment list page, then verify your selected commitments on this tab. - Optional: you can also specify the Plan, Region, and Commitment type values that you want for your merged commitment before you select the individual commitments for merging. Doing this filters the commitment list to display only those commitments that you can merge for the specified attributes. 
- Click Next. The Review tab opens. 
 
- On the Review tab of the Merge page, do the following: - Review and confirm the details of the merged commitment. To modify the list of individual commitments that you want to merge, select the Choose commitment tab on the left side of the window and repeat step 3.
- In the New commitment name field, enter a name for your merged commitment.
- Optional: To enable auto renew on your merged commitment, select the Enable auto renew checkbox.
- Read the Terms and conditions.
- To finish creating your merged commitment and return to the Commitment list page, click Merge.
 
gcloud
To merge existing commitments into a single commitment, use the
gcloud compute commitments create command
with the --merge-source-commitment flag.
gcloud compute commitments create COMMITMENT_NAME \
    --region=REGION \
    --project=PROJECT_ID \
    --plan=COMMITMENT_PLAN \
    --type=COMMITMENT_TYPE \
    --resources=vcpu=NUMBER_VCPUS,memory=MEMORY \
    --merge-source-commitments=SOURCE_COMMITMENT_URLS
Replace the following:
- COMMITMENT_NAME: the name of your new merged commitment.
- NUMBER_VCPUS: the sum of the numbers of vCPUs in the source commitments.
- COMMITMENT_TYPE: the same commitment type as your source commitments, one of the following:- For A2 machine types, use accelerator-optimized
- For A3 Edge and A3 High machine types, use accelerator-optimized-a3
- For A3 Mega machine types, use accelerator-optimized-a3-mega
- For G2 machine types, use graphics-optimized
- For G4 machine types, use graphics-optimized-g4
- For C2 machine types, use compute-optimized
- For C2D machine types, use compute-optimized-c2d
- For C3 machine types, use compute-optimized-c3
- For C3D machine types, use compute-optimized-c3d
- For H3 machine types, use compute-optimized-h3
- For N1 machine types, use general-purpose
- For C4 machine types, use general-purpose-c4
- For C4A machine types, use general-purpose-c4a
- For C4D machine types, use general-purpose-c4d
- For E2 machine types, use general-purpose-e2
- For N2 machine types, use general-purpose-n2
- For N2D machine types, use general-purpose-n2d
- For N4 machine types, use general-purpose-n4
- For Tau T2D machine types, use general-purpose-t2d
- For M1 or M2 machine types, use memory-optimized
- For M3 machine types, use memory-optimized-m3
- For M4 machine types, use memory-optimized-m4
- For M4 machine types with 6 TB of memory, use memory-optimized-m4-6tb
- For X4 machine types with 16 TB of memory, use memory-optimized-x4-16tb
- For X4 machine types with 24 TB of memory, use memory-optimized-x4-24tb
- For X4 machine types with 32 TB of memory, use memory-optimized-x4-32tb
- For Z3 machine types, use storage-optimized-z3
 
- For A2 machine types, use 
- REGION: the same region as your source commitments.
- PROJECT_ID: the project ID of the project for which you want to merge commitments.
- COMMITMENT_PLAN: the same commitment plan as your source commitments, either- 12-monthor- 36-month.
- MEMORY: the sum of the amounts, in MB or GB, of memory in the source commitments. For example, 1000 MB. If the units are not specified, the default unit used is GB.
- SOURCE_COMMITMENT_URLS: Specify a list of distinct source commitment URLs, separating each URL with a comma. Don't add a whitespace between the URLs. In the list, you must specify at least two source commitment URLs.
For example, consider two source commitments in the region us-east1 with
their resources specified as (4 N2 vCPUs and 2048 MB) and
(3 N2 vCPUs and 2048 MB) respectively. The commitment plan of each of
the source commitments is 12-month. The following gcloud CLI
command lets you merge the two commitments and create a new commitment
called merged-commitment. The merged commitment specifies its resources as
7 N2 vCPUs and '4096 MB and has a commitment plan of 12-month:
gcloud compute commitments create merged-commitment \
    --plan=12-month \
    --project=myproject \
    --region=us-east1 \
    --type=general-purpose-n2 \
    --resources=vcpu=7,memory=4096MB \
     --merge-source-commitments=projects/myproject/regions/us-central1/commitments/source-commitment-1,projects/myproject/regions/us-central1/commitments/source-commitment-2
REST
To merge existing commitments into a single commitment, use the
regionCommitments.insert method.
POST https://compute.googleapis.com/compute/v1/projects/PROJECT_ID/regions/REGION/commitments
{
  "name": COMMITMENT_NAME,
  "plan": COMMITMENT_PLAN,
  "type": COMMITMENT_TYPE,
  "region": REGION,
  "resources": [
    {
      "type": "vCPUs",
      "amount": NUMBER_VCPUS
    }
    {
      "type": "MEMORY",
      "amount": MEMORY
    }
  ],
  "mergeSourceCommitments": [SOURCE_COMMITMENT_URL ...]
}
Replace the following:
- PROJECT_ID: the project ID of the project for which you want to merge commitments.
- REGION: the same region as your source commitments.
- COMMITMENT_TYPE: the same commitment type as your source commitments, one of the following:- For A2 machine types, use ACCELERATOR_OPTIMIZED
- For A3 Edge and A3 High machine types, use ACCELERATOR_OPTIMIZED_A3
- For A3 Mega machine types, use ACCELERATOR_OPTIMIZED_A3_MEGA
- For G2 machine types, use GRAPHICS_OPTIMIZED
- For G4 machine types, use GRAPHICS_OPTIMIZED_G4
- For C2 machine types, use COMPUTE_OPTIMIZED
- For C2D machine types, use COMPUTE_OPTIMIZED_C2D
- For C3 machine types, use COMPUTE_OPTIMIZED_C3
- For C3D machine types, use COMPUTE_OPTIMIZED_C3D
- For H3 machine types, use COMPUTE_OPTIMIZED_H3
- For N1 machine types, use GENERAL_PURPOSE
- For C4 machine types, use GENERAL_PURPOSE_C4
- For C4A machine types, use GENERAL_PURPOSE_C4A
- For C4D machine types, use GENERAL_PURPOSE_C4D
- For E2 machine types, use GENERAL_PURPOSE_E2
- For N2 machine types, use GENERAL_PURPOSE_N2
- For N2D machine types, use GENERAL_PURPOSE_N2D
- For N4 machine types, use GENERAL_PURPOSE_N4
- For Tau T2D machine types, use GENERAL_PURPOSE_T2D
- For M1 or M2 machine types, use MEMORY_OPTIMIZED
- For M3 machine types, use MEMORY_OPTIMIZED_M3
- For M4 machine types, use MEMORY_OPTIMIZED_M4
- For M4 machine types with 6 TB of memory, use MEMORY_OPTIMIZED_M4_6TB
- For X4 machine types with 16 TB of memory, use MEMORY_OPTIMIZED_X4_16TB
- For X4 machine types with 24 TB of memory, use MEMORY_OPTIMIZED_X4_24TB
- For X4 machine types with 32 TB of memory, use MEMORY_OPTIMIZED_X4_32TB
- For Z3 machine types, use STORAGE_OPTIMIZED_Z3
 
- For A2 machine types, use 
- COMMITMENT_PLAN: the same commitment plan as your source commitments, either- TWELVE_MONTHor- THIRTY_SIX_MONTH.
- COMMITMENT_NAME: the name of your new merged commitment.
- NUMBER_VCPUS: the sum of the numbers of vCPUs in the source commitments.
- MEMORY: the sum of the amounts, in MB, of memory in the source commitments. For example, 1000 MB. If the units are not specified, the default unit used is MB.
- SOURCE_COMMITMENT_URL: the URL of the source commitment that you want to merge. You must specify a comma-separated list of distinct source commitment URLs.
For example, consider two source commitments (source-commitment-1 and
source-commitment-2) in the region us-east1 with their resources
specified as (4 N2 vCPUs and 2048 MB) and (3 N2 vCPUs and 2048 MB)
respectively. The commitment plan of each of the source commitments is
TWELVE_MONTH. The following POST request lets you merge the source
commitments and create a new commitment called merged-commitment. The
merged commitment specifies its resources as 7 N2 vCPUs and '4096 MB
and has a commitment plan of TWELVE_MONTH.
POST https://compute.googleapis.com/compute/v1/projects/myproject/regions/us-central1/commitments
{
  "name": "merged-commitment",
  "plan": "TWELVE_MONTH",
  "type": "GENERAL_PURPOSE_N2",
  "region": "us-east1",
   "resources": [
    {
      "type": "VCPU",
      "amount": "7"
    }
    {
      "type": "MEMORY",
      "amount": "4096"
    }
  ],
  "mergeSourceCommitments": [
         "projects/myproject/regions/us-central1/commitments/source-commitment-1",
         "projects/myproject/regions/us-central1/commitments/source-commitment-2",
         ...
    ]
}
Split commitments
You can transfer resources out of an existing commitment and split the commitment into smaller commitments. Splitting lets you closely monitor and manage portions of one large commitment in the form of smaller individual commitments. For example, you can set only a portion of a commitment to renew automatically by splitting it and enabling automatic renewal for only one of the child commitments. With splitting, you can also distribute your committed use discounts at a more granular level by using prioritized attribution for the split commitments.
How splitting works
When you split an existing commitment (source commitment), you transfer resources out of your source commitment, create one or more new commitments (split commitments), and redistribute the transferred resources among the new split commitments. Both the activation of the new split commitments and the resizing of the source commitment take place at 12 AM US and Canadian Pacific Time (UTC-8, or UTC-7 during daylight saving time) on the following day. Compute Engine sets this date of activation as the start date for the split commitments. At the completion of the split operation you have the following commitments:
- The resized source commitment with the resources that remain after the split.
- The newly created split commitments with the redistributed resources.
The source commitment, although resized, retains all of its other attributes, including its start and end dates, and continues to operate normally. The split commitments retain the same end date and term extension eligibility window as the source commitment.
Because the new split commitments get created only after your source commitment is already active, the split commitments might have a custom length and not the preset 1 or 3 years. However, the split commitments retain the 1- or 3-year commitment plan of the source commitment.
You can create only one new split commitment at a time by using the REST and the gcloud CLI. You can create multiple new split commitments in a single operation by using the Google Cloud console.
You can't split a commitment when it has attached reservations. To learn more about commitments with attached reservations, see Combining reservations with committed use discounts.
Example of a split commitment
The following table shows the commitment properties when an existing commitment
(source-commitment) gets split into two distinct commitments
(resized source-commitment and split-commitment) on March 1, 2022:
| Source commitment (before split) | Split commitment | Source commitment (after split) | |
|---|---|---|---|
| Name | source-commitment | split-commitment | source-commitment | 
| Type | N2 | N2 | N2 | 
| Region | us-central-1 | us-central-1 | us-central-1 | 
| Resources | 
 | 
 | 
 | 
| Term | 3 years | 3 years | 3 years | 
| Start date* | January 1, 2020 | March 2, 2022 (the day after the split) | January 1, 2020 | 
| End date† | January 1, 2023 | January 1, 2023 | January 1, 2023 | 
| Term extension eligibility window open until | January 1, 2021 | January 1, 2021 | January 1, 2021 | 
*All commitments start at 12 AM US and Canadian Pacific Time (UTC-8 or UTC-7) on the specified start date. †All commitments expire at 12 AM US and Canadian Pacific Time (UTC-8 or UTC-7) on the specified end date.
Pricing implications
Your commitment fee is the sum of the discounted prices of all your committed resources. Splitting a commitment affects your resource costs in the following way:
- Resized source commitment: The discounted prices of the resources from your resized source commitment remain the same.
- Split commitment: The discounted prices of your newly split commitment's resources might change on the day your split commitment becomes active. This new discounted price for each resource stays the same until the end of your new split commitment's term, even if the on-demand prices change.
However, if you merge or split either of these commitments again in the future, the discounted prices might change again.
Limitations
- You can't split license commitments.
- You can't split commitments that have attached reservations. Consequently, you can't split commitments that have GPUs, Local SSD disks, or both, as commitments with these resources always have attached reservations.
- At the time of creation of split commitments, you can't create any new reservations and attach them to those commitments.
- You can't split commitments that have expired or are cancelled.
- By default, when you create split commitments, the auto-renew setting is disabled on the new commitments even if all the source commitments were set to renew automatically. If you want your split commitments to renew automatically, you must manually enable the auto-renew setting on those commitments. You can do so either at the time of their creation or after their creation.
- You can create only one new split commitment at a time using the REST or the gcloud CLI. As a result, you can split your source commitment into a maximum of two commitments in a single operation when you use these interfaces. To split your source commitment into three or more commitments in a single operation, use the Google Cloud console.
- In the Google Cloud console, you can specify memory only in increments of 0.25 GB. To specify a custom memory value for your commitment, use gcloud CLI or REST instead.
Requirements
When you split a source commitment and create one or more split commitments, your source and split commitments must meet the following requirements:
- The new split commitments must have the same project, commitment type, region, and commitment plan as the source commitment. However, you must choose new names for your split commitments.
- The resource types you specify for the new split commitments must match some
or all of the resource types in the source commitment. Additionally, the
combined amount of resources that you specify for the new split commitments
must be a portion of the resources in the source commitment. You have to
retain a portion of the resources in your source commitment. For example,
suppose your source commitment is for 200 vCPUs and 300 GB memory,
the following resize and redistribution scenarios are applicable:
- You can redistribute a portion of the 200 vCPUs and a portion of the 300 GB memory among your new split commitments.
- You can redistribute all of the 200 vCPUs, but you must retain a portion of the memory in your source commitment.
- You can redistribute all of the 300 GB memory but you must retain a portion of the vCPUs in your source commitment.
- You can't redistribute all of the 200 vCPUs and all of the 300 GB memory among your new split commitments
 
- The source and split commitments must be for hardware resources that are vCPUs, memory, or a combination of both.
Additionally, to use the Google Cloud CLI to split a source commitment, update the Google Cloud CLI to version 423.0.0 or later. If you attempt to split a source commitment using an earlier gcloud CLI version, your split operation fails and Compute Engine throws an error.
Create split commitments
Create one new split commitment at a time by using the gcloud CLI or the Compute Engine API. Create multiple new split commitments at a time by using the Google Cloud console. Before you split a commitment, review the limitations for splitting.
Console
- In the Google Cloud console, select the project where you want to split a commitment and go to the Committed use discounts page. 
- To initiate the split operation for a commitment, do either of the following in the Hardware commitments tab of the Commitment list page: - Select the commitment that you want to split from the list and click Split.
- In the Name column, click the name of the commitment that you want to split. On the Hardware commitment details page that opens, click Split.
 
- On the Resize tab of the Split commitment page that opens, do the following: - In the vCPUs and Memory fields, specify the number of vCPUs and memory that you want to retain in your original commitment. The remaining resources are available for redistribution to your split commitment. The source commitment can't be empty after you resize it.
- Click Next. The Redistribute tab opens.
 
- On the Redistribute tab of the Split commitment page, do the following: - In the Name field, specify a name for your split commitment.
- In the vCPUs and Memory fields, specify the number of vCPUs
and memory that you want in your split commitment.
- If you want to create multiple split commitments, specify only a portion of the redistributed resources.
- Otherwise, specify all of your redistributed resources.
 
 - You can specify memory only in increments of 0.25 GB. To specify a custom memory value for your commitment, use gcloud CLI or REST instead. 1. Optional: To enable auto renew on your split commitment, select the Enable auto renew checkbox. 1. Click Done. 1. Optional: To create additional split commitments, click Add an item and repeat the preceding steps. 1. Click Next. The Review tab opens. 
- On the Review tab of the Split commitment page, do the following: - Review and confirm the details of the resized commitment and the split
commitments.
- To modify the resource allocation from your original commitment, select the Resize tab on the left side of the window and repeat step 3.
- To modify your resource redistribution among your split commitments, select the Redistribute tab on the left side of the window and repeat step 4.
 
- Read the Terms and conditions.
- To finish creating your split commitments and return to the Commitment list page, click Submit.
 
- Review and confirm the details of the resized commitment and the split
commitments.
gcloud
To split an existing commitment into two commitments, use the
gcloud compute commitments create command
with the --split-source-commitment flag.
gcloud compute commitments create COMMITMENT_NAME \
    --region=REGION \
    --project=PROJECT_ID \
    --plan=COMMITMENT_PLAN \
    --type=COMMITMENT_TYPE \
    --resources=vcpu=NUMBER_VCPUS,memory=MEMORY \
    --split-source-commitment=SOURCE_COMMITMENT_URL
Replace the following:
- COMMITMENT_NAME: the name of your new split commitment.
- COMMITMENT_TYPE: the same commitment type as your source commitment, one of the following:- For A2 machine types, use accelerator-optimized
- For A3 Edge and A3 High machine types, use accelerator-optimized-a3
- For A3 Mega machine types, use accelerator-optimized-a3-mega
- For G2 machine types, use graphics-optimized
- For G4 machine types, use graphics-optimized-g4
- For C2 machine types, use compute-optimized
- For C2D machine types, use compute-optimized-c2d
- For C3 machine types, use compute-optimized-c3
- For C3D machine types, use compute-optimized-c3d
- For H3 machine types, use compute-optimized-h3
- For N1 machine types, use general-purpose
- For C4 machine types, use general-purpose-c4
- For C4A machine types, use general-purpose-c4a
- For C4D machine types, use general-purpose-c4d
- For E2 machine types, use general-purpose-e2
- For N2 machine types, use general-purpose-n2
- For N2D machine types, use general-purpose-n2d
- For N4 machine types, use general-purpose-n4
- For Tau T2D machine types, use general-purpose-t2d
- For M1 or M2 machine types, use memory-optimized
- For M3 machine types, use memory-optimized-m3
- For M4 machine types, use memory-optimized-m4
- For M4 machine types with 6 TB of memory, use memory-optimized-m4-6tb
- For X4 machine types with 16 TB of memory, use memory-optimized-x4-16tb
- For X4 machine types with 24 TB of memory, use memory-optimized-x4-24tb
- For X4 machine types with 32 TB of memory, use memory-optimized-x4-32tb
- For Z3 machine types, use storage-optimized-z3
 
- For A2 machine types, use 
- REGION: the same region as your source commitment.
- PROJECT_ID: the project ID of the project for which you want to split the source commitment.
- COMMITMENT_PLAN: the same commitment plan as your source commitment, either- 12-monthor- 36-month.
- NUMBER_VCPUS: the number of vCPUs you want to transfer out of your source commitment to create your new split commitment. The number must be an integer less than the number of vCPUs in the source commitment.
- MEMORY: the amount, in MB or GB, of memory that you want to transfer out of your source commitment to create your new split commitment. The amount must be less than the amount of memory in the source commitment. For example, 1000 MB. If the units are not specified, the default unit used is GB.
- SOURCE_COMMITMENT_URL: the URL of the source commitment from which you want to carve out resources.
For example, consider a source commitment (source-commitment) in the
region us-east1 that has its resources specified as 3 N2 vCPUs and
2048 MB memory. The following gcloud CLI command lets you
split the commitment into two separate commitments:
gcloud compute commitments create split-commitment \
    --plan=12-month \
    --type=general-purpose-n2 \
    --region=us-east1 \
    --project=myproject \
    --resources vcpu=1,memory=1024MB \
    --split-source-commitment=projects/myproject/regions/us-central1/commitments/source-commitment
During the process of splitting source-commitment,
Compute Engine does the following:
- Takes resources from source-commitmentand creates a new commitmentsplit-commitmentwith 1 N2 vCPU and 1024 MB memory.
- Resizes source-commitmentto the remaining resources.
REST
To split an existing commitment into two commitments, use the
regionCommitments.insert method.
POST https://compute.googleapis.com/compute/v1/projects/PROJECT_ID/regions/REGION/commitments
{
  "name": COMMITMENT_NAME,
  "plan": COMMITMENT_PLAN,
  "type": COMMITMENT_TYPE,
  "region": REGION,
  "resources": [
    {
      "type": "vCPUs",
      "amount": NUMBER_VCPUS
    }
    {
      "type": "MEMORY",
      "amount": MEMORY
    }
  ],
  "splitSourceCommitment": SOURCE_COMMITMENT_URL
}
Replace the following:
- PROJECT_ID: the project ID of the project for which you want to split the source commitment.
- REGION: the same region as your source commitment.
- COMMITMENT_NAME: the name of your new split commitment.
- COMMITMENT_TYPE: the same commitment type as your source commitment, one of the following:- For A2 machine types, use ACCELERATOR_OPTIMIZED
- For A3 Edge and A3 High machine types, use ACCELERATOR_OPTIMIZED_A3
- For A3 Mega machine types, use ACCELERATOR_OPTIMIZED_A3_MEGA
- For G2 machine types, use GRAPHICS_OPTIMIZED
- For G4 machine types, use GRAPHICS_OPTIMIZED_G4
- For C2 machine types, use COMPUTE_OPTIMIZED
- For C2D machine types, use COMPUTE_OPTIMIZED_C2D
- For C3 machine types, use COMPUTE_OPTIMIZED_C3
- For C3D machine types, use COMPUTE_OPTIMIZED_C3D
- For H3 machine types, use COMPUTE_OPTIMIZED_H3
- For N1 machine types, use GENERAL_PURPOSE
- For C4 machine types, use GENERAL_PURPOSE_C4
- For C4A machine types, use GENERAL_PURPOSE_C4A
- For C4D machine types, use GENERAL_PURPOSE_C4D
- For E2 machine types, use GENERAL_PURPOSE_E2
- For N2 machine types, use GENERAL_PURPOSE_N2
- For N2D machine types, use GENERAL_PURPOSE_N2D
- For N4 machine types, use GENERAL_PURPOSE_N4
- For Tau T2D machine types, use GENERAL_PURPOSE_T2D
- For M1 or M2 machine types, use MEMORY_OPTIMIZED
- For M3 machine types, use MEMORY_OPTIMIZED_M3
- For M4 machine types, use MEMORY_OPTIMIZED_M4
- For M4 machine types with 6 TB of memory, use MEMORY_OPTIMIZED_M4_6TB
- For X4 machine types with 16 TB of memory, use MEMORY_OPTIMIZED_X4_16TB
- For X4 machine types with 24 TB of memory, use MEMORY_OPTIMIZED_X4_24TB
- For X4 machine types with 32 TB of memory, use MEMORY_OPTIMIZED_X4_32TB
- For Z3 machine types, use STORAGE_OPTIMIZED_Z3
 
- For A2 machine types, use 
- COMMITMENT_PLAN: the same commitment plan as your source commitment, either- TWELVE_MONTHor- THIRTY_SIX_MONTH.
- NUMBER_VCPUS: the number of vCPUs you want to transfer out of your source commitment to create your new split commitment. The number must be an integer less than the number of vCPUs in the source commitment.
- MEMORY: the amount, in MB, of memory that you want to transfer out of your source commitment to create your new split commitment. The amount must be less than the amount of memory in the source commitment. For example, 1000 MB. If the units are not specified, the default unit used is MB.
- SOURCE_COMMITMENT_URL: the URL of the source commitment from which you want to transfer resources.
For example, consider a source commitment (source-commitment) in the
region us-east1 that has its resources specified as 3 N2 vCPUs and
2048 MB memory. The following POST request lets you split the
commitment into two separate commitments:
POST https://compute.googleapis.com/compute/v1/projects/myproject/regions/us-central1/commitments
{
  "name": "split-commitment",
  "plan": "TWELVE_MONTH",
  "type": "GENERAL_PURPOSE_N2",
  "region": "us-east1",
  "resources": [
    {
      "type": "VCPU",
      "amount": "1"
    }
    {
      "type": "MEMORY",
      "amount": "1024"
    }
  ],
  "splitSourceCommitment": "projects/myproject/regions/us-central1/commitments/source-commitment"
}
During the process of splitting source-commitment,
Compute Engine does the following:
- Takes resources from source-commitmentand creates a new commitmentsplit-commitmentwith 1 N2 vCPU and 1024 MB memory.
- Resizes source-commitmentto the remaining resources.
What's next
- Learn how to renew resource-based commitments automatically.
- Learn how to extend the term length of resource-based commitments.
- Learn how to upgrade the term of resource-based commitments.
- Learn how to analyze the effectiveness of your CUDs.