- Resource: WorkerPool
- WorkerPoolRevisionTemplate
- InstanceSplit
- InstanceSplitAllocationType
- WorkerPoolScaling
- ScalingMode
- InstanceSplitStatus
- Methods
Resource: WorkerPool
WorkerPool acts as a top-level container that manages a set of configurations and revision templates which implement a pull-based workload. WorkerPool exists to provide a singular abstraction which can be access controlled, reasoned about, and which encapsulates software lifecycle decisions such as rollout policy and team resource ownership.
JSON representation |
---|
{ "name": string, "description": string, "uid": string, "generation": string, "labels": { string: string, ... }, "annotations": { string: string, ... }, "createTime": string, "updateTime": string, "deleteTime": string, "expireTime": string, "creator": string, "lastModifier": string, "client": string, "clientVersion": string, "launchStage": enum ( |
Fields | |
---|---|
name |
The fully qualified name of this WorkerPool. In CreateWorkerPoolRequest, this field is ignored, and instead composed from CreateWorkerPoolRequest.parent and CreateWorkerPoolRequest.worker_id. Format: projects/{project}/locations/{location}/workerPools/{worker_id} |
description |
User-provided description of the WorkerPool. This field currently has a 512-character limit. |
uid |
Output only. Server assigned unique identifier for the trigger. The value is a UUID4 string and guaranteed to remain unchanged until the resource is deleted. |
generation |
Output only. A number that monotonically increases every time the user modifies the desired state. Please note that unlike v1, this is an int64 value. As with most Google APIs, its JSON representation will be a |
labels |
Optional. Unstructured key value map that can be used to organize and categorize objects. User-provided labels are shared with Google's billing system, so they can be used to filter, or break down billing charges by team, component, environment, state, etc. For more information, visit https://cloud.google.com/resource-manager/docs/creating-managing-labels or https://cloud.google.com/run/docs/configuring/labels. Cloud Run API v2 does not support labels with An object containing a list of |
annotations |
Optional. Unstructured key value map that may be set by external tools to store and arbitrary metadata. They are not queryable and should be preserved when modifying objects. Cloud Run API v2 does not support annotations with This field follows Kubernetes annotations' namespacing, limits, and rules. An object containing a list of |
create |
Output only. The creation time. Uses RFC 3339, where generated output will always be Z-normalized and uses 0, 3, 6 or 9 fractional digits. Offsets other than "Z" are also accepted. Examples: |
update |
Output only. The last-modified time. Uses RFC 3339, where generated output will always be Z-normalized and uses 0, 3, 6 or 9 fractional digits. Offsets other than "Z" are also accepted. Examples: |
delete |
Output only. The deletion time. It is only populated as a response to a Delete request. Uses RFC 3339, where generated output will always be Z-normalized and uses 0, 3, 6 or 9 fractional digits. Offsets other than "Z" are also accepted. Examples: |
expire |
Output only. For a deleted resource, the time after which it will be permamently deleted. Uses RFC 3339, where generated output will always be Z-normalized and uses 0, 3, 6 or 9 fractional digits. Offsets other than "Z" are also accepted. Examples: |
creator |
Output only. Email address of the authenticated creator. |
last |
Output only. Email address of the last authenticated modifier. |
client |
Arbitrary identifier for the API client. |
client |
Arbitrary version identifier for the API client. |
launch |
Optional. The launch stage as defined by Google Cloud Platform Launch Stages. Cloud Run supports For example, if ALPHA is provided as input, but only BETA and GA-level features are used, this field will be BETA on output. |
binary |
Optional. Settings for the Binary Authorization feature. |
template |
Required. The template used to create revisions for this WorkerPool. |
instance |
Optional. Specifies how to distribute instances over a collection of Revisions belonging to the WorkerPool. If instance split is empty or not provided, defaults to 100% instances assigned to the latest |
scaling |
Optional. Specifies worker-pool-level scaling settings |
observed |
Output only. The generation of this WorkerPool currently serving traffic. See comments in |
terminal |
Output only. The Condition of this WorkerPool, containing its readiness status, and detailed error information in case it did not reach a serving state. See comments in |
conditions[] |
Output only. The Conditions of all other associated sub-resources. They contain additional diagnostics information in case the WorkerPool does not reach its Serving state. See comments in |
latest |
Output only. Name of the latest revision that is serving traffic. See comments in |
latest |
Output only. Name of the last created revision. See comments in |
instance |
Output only. Detailed status information for corresponding instance splits. See comments in |
custom |
One or more custom audiences that you want this worker pool to support. Specify each custom audience as the full URL in a string. The custom audiences are encoded in the token and used to authenticate requests. For more information, see https://cloud.google.com/run/docs/configuring/custom-audiences. |
satisfies |
Output only. Reserved for future use. |
reconciling |
Output only. Returns true if the WorkerPool is currently being acted upon by the system to bring it into the desired state. When a new WorkerPool is created, or an existing one is updated, Cloud Run will asynchronously perform all necessary steps to bring the WorkerPool to the desired serving state. This process is called reconciliation. While reconciliation is in process, If reconciliation succeeded, the following fields will match: If reconciliation failed, |
etag |
Output only. A system-generated fingerprint for this version of the resource. May be used to detect modification conflict during updates. |
WorkerPoolRevisionTemplate
WorkerPoolRevisionTemplate describes the data a worker pool revision should have when created from a template.
JSON representation |
---|
{ "revision": string, "labels": { string: string, ... }, "annotations": { string: string, ... }, "vpcAccess": { object ( |
Fields | |
---|---|
revision |
Optional. The unique name for the revision. If this field is omitted, it will be automatically generated based on the WorkerPool name. |
labels |
Optional. Unstructured key value map that can be used to organize and categorize objects. User-provided labels are shared with Google's billing system, so they can be used to filter, or break down billing charges by team, component, environment, state, etc. For more information, visit https://cloud.google.com/resource-manager/docs/creating-managing-labels or https://cloud.google.com/run/docs/configuring/labels. Cloud Run API v2 does not support labels with An object containing a list of |
annotations |
Optional. Unstructured key value map that may be set by external tools to store and arbitrary metadata. They are not queryable and should be preserved when modifying objects. Cloud Run API v2 does not support annotations with This field follows Kubernetes annotations' namespacing, limits, and rules. An object containing a list of |
vpc |
Optional. VPC Access configuration to use for this Revision. For more information, visit https://cloud.google.com/run/docs/configuring/connecting-vpc. |
service |
Optional. Email address of the IAM service account associated with the revision of the service. The service account represents the identity of the running revision, and determines what permissions the revision has. If not provided, the revision will use the project's default service account. |
containers[] |
Holds list of the containers that defines the unit of execution for this Revision. |
volumes[] |
Optional. A list of Volumes to make available to containers. |
encryption |
A reference to a customer managed encryption key (CMEK) to use to encrypt this container image. For more information, go to https://cloud.google.com/run/docs/securing/using-cmek |
service |
Optional. Enables service mesh connectivity. |
encryption |
Optional. The action to take if the encryption key is revoked. |
encryption |
Optional. If encryptionKeyRevocationAction is SHUTDOWN, the duration before shutting down all instances. The minimum increment is 1 hour. A duration in seconds with up to nine fractional digits, ending with ' |
session |
Optional. Enable session affinity. |
node |
Optional. The node selector for the revision template. |
InstanceSplit
Holds a single instance split entry for the Worker. Allocations can be done to a specific Revision name, or pointing to the latest Ready Revision.
JSON representation |
---|
{
"type": enum ( |
Fields | |
---|---|
type |
The allocation type for this instance split. |
revision |
Revision to which to assign this portion of instances, if split allocation is by revision. |
percent |
Specifies percent of the instance split to this Revision. This defaults to zero if unspecified. |
InstanceSplitAllocationType
The type of instance split allocation.
Enums | |
---|---|
INSTANCE_SPLIT_ALLOCATION_TYPE_UNSPECIFIED |
Unspecified instance allocation type. |
INSTANCE_SPLIT_ALLOCATION_TYPE_LATEST |
Allocates instances to the Service's latest ready Revision. |
INSTANCE_SPLIT_ALLOCATION_TYPE_REVISION |
Allocates instances to a Revision by name. |
WorkerPoolScaling
Worker pool scaling settings.
JSON representation |
---|
{
"scalingMode": enum ( |
Fields | |
---|---|
scaling |
Optional. The scaling mode for the worker pool. |
max |
Optional. A maximum percentage of instances that will be moved in each step of traffic split changes. When set to a positive value, the server will bring up, at most, that percentage of new instances at a time before moving traffic to them. After moving traffic, the server will bring down instances of the old revision. This can reduce a spike of total active instances during changes from one revision to another but specifying how many extra instances can be brought up at a time. |
max |
Optional. A maximum percentage of instances that may be unavailable during changes from one revision to another. When set to a positive value, the server may bring down instances before bringing up new instances. This can prevent a spike of total active instances during changes from one revision by reducing the pool of instances before bringing up new ones. Some requests may be slow or fail to serve during the transition. |
min |
Optional. The minimum count of instances distributed among revisions based on the specified instance split percentages. |
max |
Optional. The maximum count of instances distributed among revisions based on the specified instance split percentages. |
manual |
Optional. The total number of instances in manual scaling mode. |
ScalingMode
The scaling mode for the worker pool. If not provided, it defaults to AUTOMATIC.
Enums | |
---|---|
SCALING_MODE_UNSPECIFIED |
Unspecified. |
AUTOMATIC |
Automatically scale between min and max instances. |
MANUAL |
Scale to exactly min instances and ignore the max instances. |
InstanceSplitStatus
Represents the observed state of a single InstanceSplit
entry.
JSON representation |
---|
{
"type": enum ( |
Fields | |
---|---|
type |
The allocation type for this instance split. |
revision |
Revision to which this instance split is assigned. |
percent |
Specifies percent of the instance split to this Revision. |
Methods |
|
---|---|
|
Creates a new WorkerPool in a given project and location. |
|
Deletes a WorkerPool. |
|
Gets information about a WorkerPool. |
|
Gets the IAM Access Control policy currently in effect for the given Cloud Run WorkerPool. |
|
Lists WorkerPools. |
|
Updates a WorkerPool. |
|
Sets the IAM Access control policy for the specified WorkerPool. |
|
Returns permissions that a caller has on the specified Project. |