Cloud Run V2 API - Class Google::Cloud::Run::V2::Service (v0.14.0)

Reference documentation and code samples for the Cloud Run V2 API class Google::Cloud::Run::V2::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.

Inherits

  • Object

Extended By

  • Google::Protobuf::MessageExts::ClassMethods

Includes

  • Google::Protobuf::MessageExts

Methods

#annotations

def annotations() -> ::Google::Protobuf::Map{::String => ::String}
Returns
  • (::Google::Protobuf::Map{::String => ::String}) — 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 run.googleapis.com, cloud.googleapis.com, serving.knative.dev, or autoscaling.knative.dev namespaces, and they will be rejected in new resources. All system annotations in v1 now have a corresponding field in v2 Service.

    This field follows Kubernetes annotations' namespacing, limits, and rules.

#annotations=

def annotations=(value) -> ::Google::Protobuf::Map{::String => ::String}
Parameter
  • value (::Google::Protobuf::Map{::String => ::String}) — 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 run.googleapis.com, cloud.googleapis.com, serving.knative.dev, or autoscaling.knative.dev namespaces, and they will be rejected in new resources. All system annotations in v1 now have a corresponding field in v2 Service.

    This field follows Kubernetes annotations' namespacing, limits, and rules.

Returns
  • (::Google::Protobuf::Map{::String => ::String}) — 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 run.googleapis.com, cloud.googleapis.com, serving.knative.dev, or autoscaling.knative.dev namespaces, and they will be rejected in new resources. All system annotations in v1 now have a corresponding field in v2 Service.

    This field follows Kubernetes annotations' namespacing, limits, and rules.

#binary_authorization

def binary_authorization() -> ::Google::Cloud::Run::V2::BinaryAuthorization
Returns

#binary_authorization=

def binary_authorization=(value) -> ::Google::Cloud::Run::V2::BinaryAuthorization
Parameter
Returns

#client

def client() -> ::String
Returns
  • (::String) — Arbitrary identifier for the API client.

#client=

def client=(value) -> ::String
Parameter
  • value (::String) — Arbitrary identifier for the API client.
Returns
  • (::String) — Arbitrary identifier for the API client.

#client_version

def client_version() -> ::String
Returns
  • (::String) — Arbitrary version identifier for the API client.

#client_version=

def client_version=(value) -> ::String
Parameter
  • value (::String) — Arbitrary version identifier for the API client.
Returns
  • (::String) — Arbitrary version identifier for the API client.

#conditions

def conditions() -> ::Array<::Google::Cloud::Run::V2::Condition>
Returns
  • (::Array<::Google::Cloud::Run::V2::Condition>) — 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 reconciling for additional information on reconciliation process in Cloud Run.

#create_time

def create_time() -> ::Google::Protobuf::Timestamp
Returns

#creator

def creator() -> ::String
Returns
  • (::String) — Output only. Email address of the authenticated creator.

#custom_audiences

def custom_audiences() -> ::Array<::String>
Returns
  • (::Array<::String>) — 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.

#custom_audiences=

def custom_audiences=(value) -> ::Array<::String>
Parameter
  • value (::Array<::String>) — 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.
Returns
  • (::Array<::String>) — 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.

#delete_time

def delete_time() -> ::Google::Protobuf::Timestamp
Returns

#description

def description() -> ::String
Returns
  • (::String) — User-provided description of the Service. This field currently has a 512-character limit.

#description=

def description=(value) -> ::String
Parameter
  • value (::String) — User-provided description of the Service. This field currently has a 512-character limit.
Returns
  • (::String) — User-provided description of the Service. This field currently has a 512-character limit.

#etag

def etag() -> ::String
Returns
  • (::String) — Output only. A system-generated fingerprint for this version of the resource. May be used to detect modification conflict during updates.

#expire_time

def expire_time() -> ::Google::Protobuf::Timestamp
Returns

#generation

def generation() -> ::Integer
Returns
  • (::Integer) — 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 string instead of an integer.

#ingress

def ingress() -> ::Google::Cloud::Run::V2::IngressTraffic
Returns
  • (::Google::Cloud::Run::V2::IngressTraffic) — Provides the ingress settings for this Service. On output, returns the currently observed ingress settings, or INGRESS_TRAFFIC_UNSPECIFIED if no revision is active.

#ingress=

def ingress=(value) -> ::Google::Cloud::Run::V2::IngressTraffic
Parameter
  • value (::Google::Cloud::Run::V2::IngressTraffic) — Provides the ingress settings for this Service. On output, returns the currently observed ingress settings, or INGRESS_TRAFFIC_UNSPECIFIED if no revision is active.
Returns
  • (::Google::Cloud::Run::V2::IngressTraffic) — Provides the ingress settings for this Service. On output, returns the currently observed ingress settings, or INGRESS_TRAFFIC_UNSPECIFIED if no revision is active.

#labels

def labels() -> ::Google::Protobuf::Map{::String => ::String}
Returns
  • (::Google::Protobuf::Map{::String => ::String}) — 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 run.googleapis.com, cloud.googleapis.com, serving.knative.dev, or autoscaling.knative.dev namespaces, and they will be rejected. All system labels in v1 now have a corresponding field in v2 Service.

#labels=

def labels=(value) -> ::Google::Protobuf::Map{::String => ::String}
Parameter
  • value (::Google::Protobuf::Map{::String => ::String}) — 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 run.googleapis.com, cloud.googleapis.com, serving.knative.dev, or autoscaling.knative.dev namespaces, and they will be rejected. All system labels in v1 now have a corresponding field in v2 Service.

Returns
  • (::Google::Protobuf::Map{::String => ::String}) — 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 run.googleapis.com, cloud.googleapis.com, serving.knative.dev, or autoscaling.knative.dev namespaces, and they will be rejected. All system labels in v1 now have a corresponding field in v2 Service.

#last_modifier

def last_modifier() -> ::String
Returns
  • (::String) — Output only. Email address of the last authenticated modifier.

#latest_created_revision

def latest_created_revision() -> ::String
Returns
  • (::String) — Output only. Name of the last created revision. See comments in reconciling for additional information on reconciliation process in Cloud Run.

#latest_ready_revision

def latest_ready_revision() -> ::String
Returns
  • (::String) — Output only. Name of the latest revision that is serving traffic. See comments in reconciling for additional information on reconciliation process in Cloud Run.

#launch_stage

def launch_stage() -> ::Google::Api::LaunchStage
Returns
  • (::Google::Api::LaunchStage) — The launch stage as defined by Google Cloud Platform Launch Stages. Cloud Run supports ALPHA, BETA, and GA. If no value is specified, GA is assumed. Set the launch stage to a preview stage on input to allow use of preview features in that stage. On read (or output), describes whether the resource uses preview features.

    For example, if ALPHA is provided as input, but only BETA and GA-level features are used, this field will be BETA on output.

#launch_stage=

def launch_stage=(value) -> ::Google::Api::LaunchStage
Parameter
  • value (::Google::Api::LaunchStage) — The launch stage as defined by Google Cloud Platform Launch Stages. Cloud Run supports ALPHA, BETA, and GA. If no value is specified, GA is assumed. Set the launch stage to a preview stage on input to allow use of preview features in that stage. On read (or output), describes whether the resource uses preview features.

    For example, if ALPHA is provided as input, but only BETA and GA-level features are used, this field will be BETA on output.

Returns
  • (::Google::Api::LaunchStage) — The launch stage as defined by Google Cloud Platform Launch Stages. Cloud Run supports ALPHA, BETA, and GA. If no value is specified, GA is assumed. Set the launch stage to a preview stage on input to allow use of preview features in that stage. On read (or output), describes whether the resource uses preview features.

    For example, if ALPHA is provided as input, but only BETA and GA-level features are used, this field will be BETA on output.

#name

def name() -> ::String
Returns
  • (::String) — 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/{service_id}

#name=

def name=(value) -> ::String
Parameter
  • value (::String) — 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/{service_id}

Returns
  • (::String) — 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/{service_id}

#observed_generation

def observed_generation() -> ::Integer
Returns
  • (::Integer) — Output only. The generation of this Service currently serving traffic. See comments in reconciling for additional information on reconciliation process in Cloud Run. Please note that unlike v1, this is an int64 value. As with most Google APIs, its JSON representation will be a string instead of an integer.

#reconciling

def reconciling() -> ::Boolean
Returns
  • (::Boolean) — 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, observed_generation, latest_ready_revison, traffic_statuses, and uri will have transient values that might mismatch the intended state: Once reconciliation is over (and this field is false), there are two possible outcomes: reconciliation succeeded and the serving state matches the Service, or there was an error, and reconciliation failed. This state can be found in terminal_condition.state.

    If reconciliation succeeded, the following fields will match: traffic and traffic_statuses, observed_generation and generation, latest_ready_revision and latest_created_revision.

    If reconciliation failed, traffic_statuses, observed_generation, and latest_ready_revision will have the state of the last serving revision, or empty for newly created Services. Additional information on the failure can be found in terminal_condition and conditions.

#satisfies_pzs

def satisfies_pzs() -> ::Boolean
Returns
  • (::Boolean) — Output only. Reserved for future use.

#template

def template() -> ::Google::Cloud::Run::V2::RevisionTemplate
Returns

#template=

def template=(value) -> ::Google::Cloud::Run::V2::RevisionTemplate
Parameter
Returns

#terminal_condition

def terminal_condition() -> ::Google::Cloud::Run::V2::Condition
Returns
  • (::Google::Cloud::Run::V2::Condition) — 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 reconciling for additional information on reconciliation process in Cloud Run.

#traffic

def traffic() -> ::Array<::Google::Cloud::Run::V2::TrafficTarget>
Returns
  • (::Array<::Google::Cloud::Run::V2::TrafficTarget>) — 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 Ready Revision.

#traffic=

def traffic=(value) -> ::Array<::Google::Cloud::Run::V2::TrafficTarget>
Parameter
  • value (::Array<::Google::Cloud::Run::V2::TrafficTarget>) — 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 Ready Revision.
Returns
  • (::Array<::Google::Cloud::Run::V2::TrafficTarget>) — 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 Ready Revision.

#traffic_statuses

def traffic_statuses() -> ::Array<::Google::Cloud::Run::V2::TrafficTargetStatus>
Returns
  • (::Array<::Google::Cloud::Run::V2::TrafficTargetStatus>) — Output only. Detailed status information for corresponding traffic targets. See comments in reconciling for additional information on reconciliation process in Cloud Run.

#uid

def uid() -> ::String
Returns
  • (::String) — 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.

#update_time

def update_time() -> ::Google::Protobuf::Timestamp
Returns

#uri

def uri() -> ::String
Returns
  • (::String) — Output only. The main URI in which this Service is serving traffic.