This document explains how you can share resource-based committed use discounts (CUDs) across projects in your Cloud Billing account.
By default, resource-based CUDs from a commitment are limited to the project in which that commitment was purchased. You can change the commitment scope for your Cloud Billing and share these CUDs across projects that are linked to that Cloud Billing.
How CUD sharing works
By default, resource-based CUDs apply at the project level and you receive the applicable CUDs only for the project in which you purchase the commitment. If you move the project for which you purchased your commitment to a different Cloud Billing account, then you continue to receive the applicable CUDs for that project under the new Cloud Billing account.
However, Compute Engine lets you share discounts for resource-based commitments across multiple projects that share the same Cloud Billing account. Sharing your resource-based CUDs for commitments across all your projects reduces the overhead of managing discounts on a per-project basis, and maximizes your savings by pooling all your discounts across your projects' resource usage.
If you have multiple projects that share the same Cloud Billing account, then you can enable CUD sharing so that all of your projects within that Cloud Billing account share CUDs from all of your resource-based commitments.
For example, you purchase two resource-based commitments for 80 cores each (a total of 160 cores) and you run 200 cores during the month across different projects in your Cloud Billing account. If you've enabled CUD sharing for your Cloud Billing account, then you receive the applicable resource-based CUDs for 160 of those 200 cores that are used across the projects in that Cloud Billing account. The additional 40 cores are billed at on-demand, non-committed use rates. After you purchase your commitments, you're billed for your committed resources monthly, throughout the commitment time period, even if you don't use the resources. See Understand discount sharing for cost-saving utilization recommendations.
Attribution for shared CUDs
Attribution refers to how Google Cloud allocates your CUDs across projects after you enable CUD sharing. These allocations are reflected in Cloud Billing cost management interfaces, such as the usage cost export or the Google Cloud console.
You can choose one of the following types of attribution:
- Proportional attribution. Your CUDs are shared across projects based on each project's proportion of the total eligible usage. This is the default attribution type.
- Prioritized attribution. You specify the order in which projects receive CUDs.
Proportionally attributed commitments are applied to usage from projects
based on each project's share of the total eligible usage. For example, suppose
project A consumes US$75 worth of usage and project B consumes US$25 worth
of usage, then project A gets covered by up to 75% of the available CUDs and
project B gets covered by up to 25%.
Prioritized attribution applies your commitments to usage based on the distribution settings that you specify. You can choose the projects, along with the amount of usage within each project, that get covered by the commitments. After your prioritized commitments are applied to eligible usage, any remaining unprioritized commitments are applied proportionally to the eligible usage in your remaining projects. The total amount of the allotments cannot exceed the commitment amount purchased.
You can update attribution preferences anytime during the commitment's lifetime. However, any attribution preferences that you configure are applied only after you enable CUD sharing. To choose proportional or prioritized attribution for your Compute Engine commitments, see choose attribution for resource-based commitments.
Limitations
- If you have a shared reservation and also enabled CUD sharing for your commitment's Cloud Billing account, then, to make sure that usage from your consumed shared reservation is eligible for resource-based CUDs, you must share your reservation only with projects that are linked to the commitment's Cloud Billing account. Doing so helps you avoid being charged at on-demand rates for usage that is eligible for CUDs.
- When you enable CUD sharing for a Cloud Billing account, if any portion of a commitment is unutilized, then the remaining commitment charge remains in the project where you purchased that commitment.
Enable CUD sharing
To share the CUDs from your resource-based commitments across eligible usage in all projects linked to your Cloud Billing account, enable CUD sharing by changing the commitment scope from Project to Billing account in the Google Cloud console.
CUD sharing works in conjunction with your attribution configuration. Unless you configure your attribution preferences first, when you enable CUD sharing, it defaults to using proportional attribution for your Compute Engine resource-based commitments.
If you want to configure your attribution configuration before you enable CUD sharing, see choose attribution for resource-based commitments for more information and how to enable each type of attribution.
To enable CUD sharing, complete the following steps:
- In the Google Cloud console, go to the CUD analysis page. 
- At the prompt, choose the Cloud Billing account that you want to view. The Committed use discount analysis page appears. 
- In the Commitment type menu, verify that the selected commitment type is a value under Resource-based commitments. If the selected commitment type value is under Spend-based commitments, then select Resource-based commitments. - The page displays analysis information for Resource based commitments for the specified time period. 
- Navigate to the Commitment scope field. The field is located in the main area of the page and precedes the summary cards. You see one of the following values for the field: - Project: This scope value indicates that CUD sharing isn't enabled for resource-based commitments. Project-scoped CUDs only apply to eligible usage in the project in which the commitments are purchased.
- Billing account: This scope value indicates that CUD sharing is enabled for resource-based commitments. Billing-account-scoped commitments share their CUDs across all eligible usage in all projects associated with the Cloud Billing account.
 
- To change the commitment scope setting, click Edit and then follow these steps: - If the current scope is Project: In the text entry box, type Enable and then click Enable Billing Account Scope. This enables CUD sharing across the Cloud Billing account. 
- If the current scope is Billing account: CUD sharing is already enabled and no action is required. To disable CUD sharing and revert to Project-scoped commitments, click Contact support. 
 
You only need to enable CUD sharing on one project-scoped resource-based commitment to affect the scope of all resource-based commitments in the same Cloud Billing account. When you enable CUD sharing, your commitment scope changes as follows:
- All of your current and active resource-based CUDs in all of the projects under the same Cloud Billing account, including those you previously purchased and new ones you purchase in the future, are shared across your Cloud Billing account.
- When you change your commitment scope configuration, such as creating a new project linked to the Cloud Billing account, or linking an existing project to the Cloud Billing account, the change takes effect on the following day at 12 AM (midnight) US and Canadian Pacific Time (UTC-8 or UTC-7).
- If you move the project that had the original commitment to a new Cloud Billing account, your CUD sharing settings change. For information on the effects of changing the Cloud Billing account for a project, see Change the Cloud Billing account linked to a project.
To get a better understanding of how CUDs impact and appear on your bill, see Understand your bill with committed use discounts.
What's next
- Learn about attribution for resource-based commitments.
- Learn how to analyze the effectiveness of your CUDs.