- Resource: Service
- IngressTraffic
- RevisionTemplate
- TrafficTarget
- TrafficTargetAllocationType
- ServiceScaling
- TrafficTargetStatus
- Methods
Resource: Service
Service acts as a top-level container that manages a set of configurations and revision templates which implement a network service. Service 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, "ingress": enum ( |
Fields | |
---|---|
name |
The fully qualified name of this Service. In CreateServiceRequest, this field is ignored, and instead composed from CreateServiceRequest.parent and CreateServiceRequest.service_id. Format: projects/{project}/locations/{location}/services/{serviceId} |
description |
User-provided description of the Service. 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 |
createTime |
Output only. The creation time. A timestamp in RFC3339 UTC "Zulu" format, with nanosecond resolution and up to nine fractional digits. Examples: |
updateTime |
Output only. The last-modified time. A timestamp in RFC3339 UTC "Zulu" format, with nanosecond resolution and up to nine fractional digits. Examples: |
deleteTime |
Output only. The deletion time. It is only populated as a response to a Delete request. A timestamp in RFC3339 UTC "Zulu" format, with nanosecond resolution and up to nine fractional digits. Examples: |
expireTime |
Output only. For a deleted resource, the time after which it will be permamently deleted. A timestamp in RFC3339 UTC "Zulu" format, with nanosecond resolution and up to nine fractional digits. Examples: |
creator |
Output only. Email address of the authenticated creator. |
lastModifier |
Output only. Email address of the last authenticated modifier. |
client |
Arbitrary identifier for the API client. |
clientVersion |
Arbitrary version identifier for the API client. |
ingress |
Optional. Provides the ingress settings for this Service. On output, returns the currently observed ingress settings, or INGRESS_TRAFFIC_UNSPECIFIED if no revision is active. |
launchStage |
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. |
binaryAuthorization |
Optional. Settings for the Binary Authorization feature. |
template |
Required. The template used to create revisions for this Service. |
traffic[] |
Optional. Specifies how to distribute traffic over a collection of Revisions belonging to the Service. If traffic is empty or not provided, defaults to 100% traffic to the latest |
scaling |
Optional. Specifies service-level scaling settings |
defaultUriDisabled |
Optional. Disables public resolution of the default URI of this service. |
urls[] |
Output only. All URLs serving traffic for this Service. |
customAudiences[] |
One or more custom audiences that you want this service 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. |
observedGeneration |
Output only. The generation of this Service currently serving traffic. See comments in |
terminalCondition |
Output only. The Condition of this Service, 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 Service does not reach its Serving state. See comments in |
latestReadyRevision |
Output only. Name of the latest revision that is serving traffic. See comments in |
latestCreatedRevision |
Output only. Name of the last created revision. See comments in |
trafficStatuses[] |
Output only. Detailed status information for corresponding traffic targets. See comments in |
uri |
Output only. The main URI in which this Service is serving traffic. |
satisfiesPzs |
Output only. Reserved for future use. |
reconciling |
Output only. Returns true if the Service is currently being acted upon by the system to bring it into the desired state. When a new Service is created, or an existing one is updated, Cloud Run will asynchronously perform all necessary steps to bring the Service 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. |
IngressTraffic
Allowed ingress traffic for the Container.
Enums | |
---|---|
INGRESS_TRAFFIC_UNSPECIFIED |
Unspecified |
INGRESS_TRAFFIC_ALL |
All inbound traffic is allowed. |
INGRESS_TRAFFIC_INTERNAL_ONLY |
Only internal traffic is allowed. |
INGRESS_TRAFFIC_INTERNAL_LOAD_BALANCER |
Both internal and Google Cloud Load Balancer traffic is allowed. |
INGRESS_TRAFFIC_NONE |
No ingress traffic is allowed. |
RevisionTemplate
RevisionTemplate describes the data a revision should have when created from a template.
JSON representation |
---|
{ "revision": string, "labels": { string: string, ... }, "annotations": { string: string, ... }, "scaling": { object ( |
Fields | |
---|---|
revision |
Optional. The unique name for the revision. If this field is omitted, it will be automatically generated based on the Service 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 |
scaling |
Optional. Scaling settings for this Revision. |
vpcAccess |
Optional. VPC Access configuration to use for this Revision. For more information, visit https://cloud.google.com/run/docs/configuring/connecting-vpc. |
timeout |
Optional. Max allowed time for an instance to respond to a request. A duration in seconds with up to nine fractional digits, ending with ' |
serviceAccount |
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 the single container that defines the unit of execution for this Revision. |
volumes[] |
Optional. A list of Volumes to make available to containers. |
executionEnvironment |
Optional. The sandbox environment to host this Revision. |
encryptionKey |
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 |
maxInstanceRequestConcurrency |
Optional. Sets the maximum number of requests that each serving instance can receive. If not specified or 0, defaults to 80 when requested CPU >= 1 and defaults to 1 when requested CPU < 1. |
serviceMesh |
Optional. Enables service mesh connectivity. |
sessionAffinity |
Optional. Enable session affinity. |
healthCheckDisabled |
Optional. Disables health checking containers during deployment. |
nodeSelector |
Optional. The node selector for the revision template. |
TrafficTarget
Holds a single traffic routing entry for the Service. 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 traffic target. |
revision |
Revision to which to send this portion of traffic, if traffic allocation is by revision. |
percent |
Specifies percent of the traffic to this Revision. This defaults to zero if unspecified. |
tag |
Indicates a string to be part of the URI to exclusively reference this target. |
TrafficTargetAllocationType
The type of instance allocation.
Enums | |
---|---|
TRAFFIC_TARGET_ALLOCATION_TYPE_UNSPECIFIED |
Unspecified instance allocation type. |
TRAFFIC_TARGET_ALLOCATION_TYPE_LATEST |
Allocates instances to the Service's latest ready Revision. |
TRAFFIC_TARGET_ALLOCATION_TYPE_REVISION |
Allocates instances to a Revision by name. |
ServiceScaling
Scaling settings applied at the service level rather than at the revision level.
JSON representation |
---|
{ "minInstanceCount": integer } |
Fields | |
---|---|
minInstanceCount |
Optional. total min instances for the service. This number of instances is divided among all revisions with specified traffic based on the percent of traffic they are receiving. (BETA) |
TrafficTargetStatus
Represents the observed state of a single TrafficTarget
entry.
JSON representation |
---|
{
"type": enum ( |
Fields | |
---|---|
type |
The allocation type for this traffic target. |
revision |
Revision to which this traffic is sent. |
percent |
Specifies percent of the traffic to this Revision. |
tag |
Indicates the string used in the URI to exclusively reference this target. |
uri |
Displays the target URI. |
Methods |
|
---|---|
|
Creates a new Service in a given project and location. |
|
Deletes a Service. |
|
Gets information about a Service. |
|
Gets the IAM Access Control policy currently in effect for the given Cloud Run Service. |
|
Lists Services. |
|
Updates a Service. |
|
Sets the IAM Access control policy for the specified Service. |
|
Returns permissions that a caller has on the specified Project. |