A consumer override is applied to the consumer on its own authority to limit its own quota usage. Consumer overrides cannot be used to grant more quota than would be allowed by admin overrides, producer overrides, or the default limit of the service.
To get more information about ConsumerQuotaOverride, see:
resource "google_project" "my_project" {
provider = google-beta
name = "tf-test-project"
project_id = "quota"
org_id = "123456789"
}
resource "google_service_usage_consumer_quota_override" "override" {
provider = google-beta
project = google_project.my_project.project_id
service = "servicemanagement.googleapis.com"
metric = urlencode("servicemanagement.googleapis.com/default_requests")
limit = urlencode("/min/project")
override_value = "95"
force = true
}
resource "google_project" "my_project" {
provider = google-beta
name = "tf-test-project"
project_id = "quota"
org_id = "123456789"
}
resource "google_service_usage_consumer_quota_override" "override" {
provider = google-beta
dimensions = {
region = "us-central1"
}
project = google_project.my_project.project_id
service = "compute.googleapis.com"
metric = urlencode("compute.googleapis.com/n2_cpus")
limit = urlencode("/project/region")
override_value = "8"
force = true
}
resource "google_project" "my_project" {
provider = google-beta
name = "tf-test-project"
project_id = "quota"
org_id = "123456789"
}
resource "google_service_usage_consumer_quota_override" "override" {
provider = google-beta
project = google_project.my_project.project_id
service = "libraryagent.googleapis.com"
metric = urlencode("libraryagent.googleapis.com/borrows")
limit = urlencode("/author/project")
override_value = "1"
force = true
dimensions = {
author = "larry"
}
}
The following arguments are supported:
override_value
-
(Required)
The overriding quota limit value. Can be any nonnegative integer, or -1 (unlimited quota).
service
-
(Required)
The service that the metrics belong to, e.g. compute.googleapis.com
.
metric
-
(Required)
The metric that should be limited, e.g. compute.googleapis.com/cpus
.
limit
-
(Required)
The limit on the metric, e.g. /project/region
.
~> Make sure that limit
is in a format that doesn't start with 1/
or contain curly braces.
E.g. use /project/user
instead of 1/{project}/{user}
.
dimensions
-
(Optional)
If this map is nonempty, then this override applies only to specific values for dimensions defined in the limit unit.
force
-
(Optional)
If the new quota would decrease the existing quota by more than 10%, the request is rejected.
If force
is true
, that safety check is ignored.
project
- (Optional) The ID of the project in which the resource belongs.
If it is not provided, the provider project is used.
In addition to the arguments listed above, the following computed attributes are exported:
id
- an identifier for the resource with format projects/{{project}}/services/{{service}}/consumerQuotaMetrics/{{metric}}/limits/{{limit}}/consumerOverrides/{{name}}
name
-
The server-generated name of the quota override.
This resource provides the following Timeouts configuration options:
create
- Default is 20 minutes.update
- Default is 20 minutes.delete
- Default is 20 minutes.ConsumerQuotaOverride can be imported using any of these accepted formats:
projects/{{project}}/services/{{service}}/consumerQuotaMetrics/{{metric}}/limits/{{limit}}/consumerOverrides/{{name}}
services/{{service}}/consumerQuotaMetrics/{{metric}}/limits/{{limit}}/consumerOverrides/{{name}}
{{service}}/{{metric}}/{{limit}}/{{name}}
In Terraform v1.5.0 and later, use an import
block to import ConsumerQuotaOverride using one of the formats above. For example:
import {
id = "projects/{{project}}/services/{{service}}/consumerQuotaMetrics/{{metric}}/limits/{{limit}}/consumerOverrides/{{name}}"
to = google_service_usage_consumer_quota_override.default
}
When using the terraform import
command, ConsumerQuotaOverride can be imported using one of the formats above. For example:
$ terraform import google_service_usage_consumer_quota_override.default projects/{{project}}/services/{{service}}/consumerQuotaMetrics/{{metric}}/limits/{{limit}}/consumerOverrides/{{name}}
$ terraform import google_service_usage_consumer_quota_override.default services/{{service}}/consumerQuotaMetrics/{{metric}}/limits/{{limit}}/consumerOverrides/{{name}}
$ terraform import google_service_usage_consumer_quota_override.default {{service}}/{{metric}}/{{limit}}/{{name}}
This resource supports User Project Overrides.