Class: Google::Apis::RunV2::GoogleCloudRunV2Service
- Inherits:
-
Object
- Object
- Google::Apis::RunV2::GoogleCloudRunV2Service
- Includes:
- Core::Hashable, Core::JsonObjectSupport
- Defined in:
- lib/google/apis/run_v2/classes.rb,
lib/google/apis/run_v2/representations.rb,
lib/google/apis/run_v2/representations.rb
Overview
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.
Instance Attribute Summary collapse
-
#annotations ⇒ Hash<String,String>
Unstructured key value map that may be set by external tools to store and arbitrary metadata.
-
#binary_authorization ⇒ Google::Apis::RunV2::GoogleCloudRunV2BinaryAuthorization
Settings for Binary Authorization feature.
-
#client ⇒ String
Arbitrary identifier for the API client.
-
#client_version ⇒ String
Arbitrary version identifier for the API client.
-
#conditions ⇒ Array<Google::Apis::RunV2::GoogleCloudRunV2Condition>
Output only.
-
#create_time ⇒ String
Output only.
-
#creator ⇒ String
Output only.
-
#delete_time ⇒ String
Output only.
-
#description ⇒ String
User-provided description of the Service.
-
#etag ⇒ String
Output only.
-
#expire_time ⇒ String
Output only.
-
#generation ⇒ Fixnum
Output only.
-
#ingress ⇒ String
Provides the ingress settings for this Service.
-
#labels ⇒ Hash<String,String>
Map of string keys and values that can be used to organize and categorize objects.
-
#last_modifier ⇒ String
Output only.
-
#latest_created_revision ⇒ String
Output only.
-
#latest_ready_revision ⇒ String
Output only.
-
#launch_stage ⇒ String
The launch stage as defined by Google Cloud Platform Launch Stages.
-
#name ⇒ String
The fully qualified name of this Service.
-
#observed_generation ⇒ Fixnum
Output only.
-
#reconciling ⇒ Boolean
(also: #reconciling?)
Output only.
-
#template ⇒ Google::Apis::RunV2::GoogleCloudRunV2RevisionTemplate
RevisionTemplate describes the data a revision should have when created from a template.
-
#terminal_condition ⇒ Google::Apis::RunV2::GoogleCloudRunV2Condition
Defines a status condition for a resource.
-
#traffic ⇒ Array<Google::Apis::RunV2::GoogleCloudRunV2TrafficTarget>
Specifies how to distribute traffic over a collection of Revisions belonging to the Service.
-
#traffic_statuses ⇒ Array<Google::Apis::RunV2::GoogleCloudRunV2TrafficTargetStatus>
Output only.
-
#uid ⇒ String
Output only.
-
#update_time ⇒ String
Output only.
-
#uri ⇒ String
Output only.
Instance Method Summary collapse
-
#initialize(**args) ⇒ GoogleCloudRunV2Service
constructor
A new instance of GoogleCloudRunV2Service.
-
#update!(**args) ⇒ Object
Update properties of this object.
Constructor Details
#initialize(**args) ⇒ GoogleCloudRunV2Service
Returns a new instance of GoogleCloudRunV2Service.
1773 1774 1775 |
# File 'lib/google/apis/run_v2/classes.rb', line 1773 def initialize(**args) update!(**args) end |
Instance Attribute Details
#annotations ⇒ Hash<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. All system
annotations in v1 now have a corresponding field in v2 Service. This field
follows Kubernetes annotations' namespacing, limits, and rules. More info:
https://kubernetes.io/docs/user-guide/annotations
Corresponds to the JSON property annotations
1582 1583 1584 |
# File 'lib/google/apis/run_v2/classes.rb', line 1582 def annotations @annotations end |
#binary_authorization ⇒ Google::Apis::RunV2::GoogleCloudRunV2BinaryAuthorization
Settings for Binary Authorization feature.
Corresponds to the JSON property binaryAuthorization
1587 1588 1589 |
# File 'lib/google/apis/run_v2/classes.rb', line 1587 def @binary_authorization end |
#client ⇒ String
Arbitrary identifier for the API client.
Corresponds to the JSON property client
1592 1593 1594 |
# File 'lib/google/apis/run_v2/classes.rb', line 1592 def client @client end |
#client_version ⇒ String
Arbitrary version identifier for the API client.
Corresponds to the JSON property clientVersion
1597 1598 1599 |
# File 'lib/google/apis/run_v2/classes.rb', line 1597 def client_version @client_version end |
#conditions ⇒ Array<Google::Apis::RunV2::GoogleCloudRunV2Condition>
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
1605 1606 1607 |
# File 'lib/google/apis/run_v2/classes.rb', line 1605 def conditions @conditions end |
#create_time ⇒ String
Output only. The creation time.
Corresponds to the JSON property createTime
1610 1611 1612 |
# File 'lib/google/apis/run_v2/classes.rb', line 1610 def create_time @create_time end |
#creator ⇒ String
Output only. Email address of the authenticated creator.
Corresponds to the JSON property creator
1615 1616 1617 |
# File 'lib/google/apis/run_v2/classes.rb', line 1615 def creator @creator end |
#delete_time ⇒ String
Output only. The deletion time.
Corresponds to the JSON property deleteTime
1620 1621 1622 |
# File 'lib/google/apis/run_v2/classes.rb', line 1620 def delete_time @delete_time end |
#description ⇒ String
User-provided description of the Service. This field currently has a 512-
character limit.
Corresponds to the JSON property description
1626 1627 1628 |
# File 'lib/google/apis/run_v2/classes.rb', line 1626 def description @description end |
#etag ⇒ String
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
1632 1633 1634 |
# File 'lib/google/apis/run_v2/classes.rb', line 1632 def etag @etag end |
#expire_time ⇒ String
Output only. For a deleted resource, the time after which it will be
permamently deleted.
Corresponds to the JSON property expireTime
1638 1639 1640 |
# File 'lib/google/apis/run_v2/classes.rb', line 1638 def expire_time @expire_time end |
#generation ⇒ Fixnum
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.
Corresponds to the JSON property generation
1646 1647 1648 |
# File 'lib/google/apis/run_v2/classes.rb', line 1646 def generation @generation end |
#ingress ⇒ String
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
1653 1654 1655 |
# File 'lib/google/apis/run_v2/classes.rb', line 1653 def ingress @ingress end |
#labels ⇒ Hash<String,String>
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 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.
Corresponds to the JSON property labels
1666 1667 1668 |
# File 'lib/google/apis/run_v2/classes.rb', line 1666 def labels @labels end |
#last_modifier ⇒ String
Output only. Email address of the last authenticated modifier.
Corresponds to the JSON property lastModifier
1671 1672 1673 |
# File 'lib/google/apis/run_v2/classes.rb', line 1671 def last_modifier @last_modifier end |
#latest_created_revision ⇒ String
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
1677 1678 1679 |
# File 'lib/google/apis/run_v2/classes.rb', line 1677 def latest_created_revision @latest_created_revision end |
#latest_ready_revision ⇒ 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.
Corresponds to the JSON property latestReadyRevision
1684 1685 1686 |
# File 'lib/google/apis/run_v2/classes.rb', line 1684 def latest_ready_revision @latest_ready_revision end |
#launch_stage ⇒ String
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.
Corresponds to the JSON property launchStage
1691 1692 1693 |
# File 'lib/google/apis/run_v2/classes.rb', line 1691 def launch_stage @launch_stage end |
#name ⇒ 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
Corresponds to the JSON property name
1699 1700 1701 |
# File 'lib/google/apis/run_v2/classes.rb', line 1699 def name @name end |
#observed_generation ⇒ Fixnum
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
.
Corresponds to the JSON property observedGeneration
1708 1709 1710 |
# File 'lib/google/apis/run_v2/classes.rb', line 1708 def observed_generation @observed_generation end |
#reconciling ⇒ Boolean Also known as: 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,
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
1729 1730 1731 |
# File 'lib/google/apis/run_v2/classes.rb', line 1729 def reconciling @reconciling end |
#template ⇒ Google::Apis::RunV2::GoogleCloudRunV2RevisionTemplate
RevisionTemplate describes the data a revision should have when created from a
template.
Corresponds to the JSON property template
1736 1737 1738 |
# File 'lib/google/apis/run_v2/classes.rb', line 1736 def template @template end |
#terminal_condition ⇒ Google::Apis::RunV2::GoogleCloudRunV2Condition
Defines a status condition for a resource.
Corresponds to the JSON property terminalCondition
1741 1742 1743 |
# File 'lib/google/apis/run_v2/classes.rb', line 1741 def terminal_condition @terminal_condition end |
#traffic ⇒ Array<Google::Apis::RunV2::GoogleCloudRunV2TrafficTarget>
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
1748 1749 1750 |
# File 'lib/google/apis/run_v2/classes.rb', line 1748 def traffic @traffic end |
#traffic_statuses ⇒ Array<Google::Apis::RunV2::GoogleCloudRunV2TrafficTargetStatus>
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
1755 1756 1757 |
# File 'lib/google/apis/run_v2/classes.rb', line 1755 def traffic_statuses @traffic_statuses end |
#uid ⇒ 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.
Corresponds to the JSON property uid
1761 1762 1763 |
# File 'lib/google/apis/run_v2/classes.rb', line 1761 def uid @uid end |
#update_time ⇒ String
Output only. The last-modified time.
Corresponds to the JSON property updateTime
1766 1767 1768 |
# File 'lib/google/apis/run_v2/classes.rb', line 1766 def update_time @update_time end |
#uri ⇒ String
Output only. The main URI in which this Service is serving traffic.
Corresponds to the JSON property uri
1771 1772 1773 |
# File 'lib/google/apis/run_v2/classes.rb', line 1771 def uri @uri end |
Instance Method Details
#update!(**args) ⇒ Object
Update properties of this object
1778 1779 1780 1781 1782 1783 1784 1785 1786 1787 1788 1789 1790 1791 1792 1793 1794 1795 1796 1797 1798 1799 1800 1801 1802 1803 1804 1805 1806 1807 |
# File 'lib/google/apis/run_v2/classes.rb', line 1778 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 |