class Google::Apis::RunV2::GoogleCloudRunV2Service

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.

Attributes

annotations[RW]

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 will populate some annotations using ‘run. googleapis.com’ or ‘serving.knative.dev’ namespaces. This field follows Kubernetes annotations’ namespacing, limits, and rules. More info: https:// kubernetes.io/docs/user-guide/annotations Corresponds to the JSON property ‘annotations` @return [Hash<String,String>]

binary_authorization[RW]

Settings for Binary Authorization feature. Corresponds to the JSON property ‘binaryAuthorization` @return [Google::Apis::RunV2::GoogleCloudRunV2BinaryAuthorization]

client[RW]

Arbitrary identifier for the API client. Corresponds to the JSON property ‘client` @return [String]

client_version[RW]

Arbitrary version identifier for the API client. Corresponds to the JSON property ‘clientVersion` @return [String]

conditions[RW]

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. Corresponds to the JSON property `conditions` @return [Array<Google::Apis::RunV2::GoogleCloudRunV2Condition>]

create_time[RW]

Output only. The creation time. Corresponds to the JSON property ‘createTime` @return [String]

creator[RW]

Output only. Email address of the authenticated creator. Corresponds to the JSON property ‘creator` @return [String]

delete_time[RW]

Output only. The deletion time. Corresponds to the JSON property ‘deleteTime` @return [String]

description[RW]

User-provided description of the Service. This field currently has a 512- character limit. Corresponds to the JSON property ‘description` @return [String]

etag[RW]

Output only. A system-generated fingerprint for this version of the resource. May be used to detect modification conflict during updates. Corresponds to the JSON property ‘etag` @return [String]

expire_time[RW]

Output only. For a deleted resource, the time after which it will be permamently deleted. Corresponds to the JSON property ‘expireTime` @return [String]

generation[RW]

Output only. A number that monotonically increases every time the user modifies the desired state. Corresponds to the JSON property ‘generation` @return [Fixnum]

ingress[RW]

Provides the ingress settings for this Service. On output, returns the currently observed ingress settings, or INGRESS_TRAFFIC_UNSPECIFIED if no revision is active. Corresponds to the JSON property ‘ingress` @return [String]

labels[RW]

Map of string keys and values 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 cloud.google.com/ resource-manager/docs/creating-managing-labels or cloud.google.com/run/ docs/configuring/labels Cloud Run will populate some labels with ‘run. googleapis.com’ or ‘serving.knative.dev’ namespaces. Those labels are read- only, and user changes will not be preserved. Corresponds to the JSON property ‘labels` @return [Hash<String,String>]

last_modifier[RW]

Output only. Email address of the last authenticated modifier. Corresponds to the JSON property ‘lastModifier` @return [String]

latest_created_revision[RW]

Output only. Name of the last created revision. See comments in ‘reconciling` for additional information on reconciliation process in Cloud Run. Corresponds to the JSON property `latestCreatedRevision` @return [String]

latest_ready_revision[RW]

Output only. Name of the latest revision that is serving traffic. See comments in ‘reconciling` for additional information on reconciliation process in Cloud Run. Corresponds to the JSON property `latestReadyRevision` @return [String]

launch_stage[RW]

The launch stage as defined by [Google Cloud Platform Launch Stages](https:// cloud.google.com/terms/launch-stages). Cloud Run supports ‘ALPHA`, `BETA`, and `GA`. If no value is specified, GA is assumed. Corresponds to the JSON property `launchStage` @return [String]

name[RW]

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` Corresponds to the JSON property `name` @return [String]

observed_generation[RW]

Output only. The generation of this Service currently serving traffic. See comments in ‘reconciling` for additional information on reconciliation process in Cloud Run. Corresponds to the JSON property `observedGeneration` @return [Fixnum]

reconciling[RW]

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`. Corresponds to the JSON property `reconciling` @return [Boolean]

reconciling?[RW]

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`. Corresponds to the JSON property `reconciling` @return [Boolean]

template[RW]

RevisionTemplate describes the data a revision should have when created from a template. Corresponds to the JSON property ‘template` @return [Google::Apis::RunV2::GoogleCloudRunV2RevisionTemplate]

terminal_condition[RW]

Defines a status condition for a resource. Corresponds to the JSON property ‘terminalCondition` @return [Google::Apis::RunV2::GoogleCloudRunV2Condition]

traffic[RW]

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. Corresponds to the JSON property `traffic` @return [Array<Google::Apis::RunV2::GoogleCloudRunV2TrafficTarget>]

traffic_statuses[RW]

Output only. Detailed status information for corresponding traffic targets. See comments in ‘reconciling` for additional information on reconciliation process in Cloud Run. Corresponds to the JSON property `trafficStatuses` @return [Array<Google::Apis::RunV2::GoogleCloudRunV2TrafficTargetStatus>]

uid[RW]

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. Corresponds to the JSON property ‘uid` @return [String]

update_time[RW]

Output only. The last-modified time. Corresponds to the JSON property ‘updateTime` @return [String]

uri[RW]

Output only. The main URI in which this Service is serving traffic. Corresponds to the JSON property ‘uri` @return [String]

Public Class Methods

new(**args) click to toggle source
# File lib/google/apis/run_v2/classes.rb, line 1017
def initialize(**args)
   update!(**args)
end

Public Instance Methods

update!(**args) click to toggle source

Update properties of this object

# File lib/google/apis/run_v2/classes.rb, line 1022
def update!(**args)
  @annotations = args[:annotations] if args.key?(:annotations)
  @binary_authorization = args[:binary_authorization] if args.key?(:binary_authorization)
  @client = args[:client] if args.key?(:client)
  @client_version = args[:client_version] if args.key?(:client_version)
  @conditions = args[:conditions] if args.key?(:conditions)
  @create_time = args[:create_time] if args.key?(:create_time)
  @creator = args[:creator] if args.key?(:creator)
  @delete_time = args[:delete_time] if args.key?(:delete_time)
  @description = args[:description] if args.key?(:description)
  @etag = args[:etag] if args.key?(:etag)
  @expire_time = args[:expire_time] if args.key?(:expire_time)
  @generation = args[:generation] if args.key?(:generation)
  @ingress = args[:ingress] if args.key?(:ingress)
  @labels = args[:labels] if args.key?(:labels)
  @last_modifier = args[:last_modifier] if args.key?(:last_modifier)
  @latest_created_revision = args[:latest_created_revision] if args.key?(:latest_created_revision)
  @latest_ready_revision = args[:latest_ready_revision] if args.key?(:latest_ready_revision)
  @launch_stage = args[:launch_stage] if args.key?(:launch_stage)
  @name = args[:name] if args.key?(:name)
  @observed_generation = args[:observed_generation] if args.key?(:observed_generation)
  @reconciling = args[:reconciling] if args.key?(:reconciling)
  @template = args[:template] if args.key?(:template)
  @terminal_condition = args[:terminal_condition] if args.key?(:terminal_condition)
  @traffic = args[:traffic] if args.key?(:traffic)
  @traffic_statuses = args[:traffic_statuses] if args.key?(:traffic_statuses)
  @uid = args[:uid] if args.key?(:uid)
  @update_time = args[:update_time] if args.key?(:update_time)
  @uri = args[:uri] if args.key?(:uri)
end