Class: Google::Apis::ContainerV1beta1::UpdateNodePoolRequest
- Inherits:
-
Object
- Object
- Google::Apis::ContainerV1beta1::UpdateNodePoolRequest
- Defined in:
- generated/google/apis/container_v1beta1/classes.rb,
generated/google/apis/container_v1beta1/representations.rb,
generated/google/apis/container_v1beta1/representations.rb
Overview
SetNodePoolVersionRequest updates the version of a node pool.
Instance Attribute Summary collapse
-
#cluster_id ⇒ String
Required.
-
#image_type ⇒ String
Required.
-
#locations ⇒ Array<String>
The desired list of Google Compute Engine zones in which the node pool's nodes should be located.
-
#name ⇒ String
The name (project, location, cluster, node pool) of the node pool to update.
-
#node_pool_id ⇒ String
Required.
-
#node_version ⇒ String
Required.
-
#project_id ⇒ String
Required.
-
#upgrade_settings ⇒ Google::Apis::ContainerV1beta1::UpgradeSettings
These upgrade settings control the level of parallelism and the level of disruption caused by an upgrade.
-
#workload_metadata_config ⇒ Google::Apis::ContainerV1beta1::WorkloadMetadataConfig
WorkloadMetadataConfig defines the metadata configuration to expose to workloads on the node pool.
-
#zone ⇒ String
Required.
Instance Method Summary collapse
-
#initialize(**args) ⇒ UpdateNodePoolRequest
constructor
A new instance of UpdateNodePoolRequest.
-
#update!(**args) ⇒ Object
Update properties of this object.
Methods included from Google::Apis::Core::JsonObjectSupport
Methods included from Google::Apis::Core::Hashable
Constructor Details
#initialize(**args) ⇒ UpdateNodePoolRequest
Returns a new instance of UpdateNodePoolRequest.
4542 4543 4544 |
# File 'generated/google/apis/container_v1beta1/classes.rb', line 4542 def initialize(**args) update!(**args) end |
Instance Attribute Details
#cluster_id ⇒ String
Required. Deprecated. The name of the cluster to upgrade.
This field has been deprecated and replaced by the name field.
Corresponds to the JSON property clusterId
4457 4458 4459 |
# File 'generated/google/apis/container_v1beta1/classes.rb', line 4457 def cluster_id @cluster_id end |
#image_type ⇒ String
Required. The desired image type for the node pool.
Corresponds to the JSON property imageType
4462 4463 4464 |
# File 'generated/google/apis/container_v1beta1/classes.rb', line 4462 def image_type @image_type end |
#locations ⇒ Array<String>
The desired list of Google Compute Engine
zones in which the node pool's nodes
should be located. Changing the locations for a node pool will result
in nodes being either created or removed from the node pool, depending
on whether locations are being added or removed.
Corresponds to the JSON property locations
4471 4472 4473 |
# File 'generated/google/apis/container_v1beta1/classes.rb', line 4471 def locations @locations end |
#name ⇒ String
The name (project, location, cluster, node pool) of the node pool to
update. Specified in the format
'projects//locations//clusters//nodePools/'.
Corresponds to the JSON property name
4478 4479 4480 |
# File 'generated/google/apis/container_v1beta1/classes.rb', line 4478 def name @name end |
#node_pool_id ⇒ String
Required. Deprecated. The name of the node pool to upgrade.
This field has been deprecated and replaced by the name field.
Corresponds to the JSON property nodePoolId
4484 4485 4486 |
# File 'generated/google/apis/container_v1beta1/classes.rb', line 4484 def node_pool_id @node_pool_id end |
#node_version ⇒ String
Required. The Kubernetes version to change the nodes to (typically an upgrade). Users may specify either explicit versions offered by Kubernetes Engine or version aliases, which have the following behavior:
- "latest": picks the highest valid Kubernetes version
- "1.X": picks the highest valid patch+gke.N patch in the 1.X version
- "1.X.Y": picks the highest valid gke.N patch in the 1.X.Y version
- "1.X.Y-gke.N": picks an explicit Kubernetes version
- "-": picks the Kubernetes master version
Corresponds to the JSON property
nodeVersion
4497 4498 4499 |
# File 'generated/google/apis/container_v1beta1/classes.rb', line 4497 def node_version @node_version end |
#project_id ⇒ String
Required. Deprecated. The Google Developers Console project ID or project
number.
This field has been deprecated and replaced by the name field.
Corresponds to the JSON property projectId
4504 4505 4506 |
# File 'generated/google/apis/container_v1beta1/classes.rb', line 4504 def project_id @project_id end |
#upgrade_settings ⇒ Google::Apis::ContainerV1beta1::UpgradeSettings
These upgrade settings control the level of parallelism and the level of
disruption caused by an upgrade.
maxUnavailable controls the number of nodes that can be simultaneously
unavailable.
maxSurge controls the number of additional nodes that can be added to the
node pool temporarily for the time of the upgrade to increase the number of
available nodes.
(maxUnavailable + maxSurge) determines the level of parallelism (how many
nodes are being upgraded at the same time).
Note: upgrades inevitably introduce some disruption since workloads need to
be moved from old nodes to new, upgraded ones. Even if maxUnavailable=0,
this holds true. (Disruption stays within the limits of
PodDisruptionBudget, if it is configured.)
Consider a hypothetical node pool with 5 nodes having maxSurge=2,
maxUnavailable=1. This means the upgrade process upgrades 3 nodes
simultaneously. It creates 2 additional (upgraded) nodes, then it brings
down 3 old (not yet upgraded) nodes at the same time. This ensures that
there are always at least 4 nodes available.
Corresponds to the JSON property upgradeSettings
4526 4527 4528 |
# File 'generated/google/apis/container_v1beta1/classes.rb', line 4526 def upgrade_settings @upgrade_settings end |
#workload_metadata_config ⇒ Google::Apis::ContainerV1beta1::WorkloadMetadataConfig
WorkloadMetadataConfig defines the metadata configuration to expose to
workloads on the node pool.
Corresponds to the JSON property workloadMetadataConfig
4532 4533 4534 |
# File 'generated/google/apis/container_v1beta1/classes.rb', line 4532 def @workload_metadata_config end |
#zone ⇒ String
Required. Deprecated. The name of the Google Compute Engine
zone in which the cluster
resides.
This field has been deprecated and replaced by the name field.
Corresponds to the JSON property zone
4540 4541 4542 |
# File 'generated/google/apis/container_v1beta1/classes.rb', line 4540 def zone @zone end |
Instance Method Details
#update!(**args) ⇒ Object
Update properties of this object
4547 4548 4549 4550 4551 4552 4553 4554 4555 4556 4557 4558 |
# File 'generated/google/apis/container_v1beta1/classes.rb', line 4547 def update!(**args) @cluster_id = args[:cluster_id] if args.key?(:cluster_id) @image_type = args[:image_type] if args.key?(:image_type) @locations = args[:locations] if args.key?(:locations) @name = args[:name] if args.key?(:name) @node_pool_id = args[:node_pool_id] if args.key?(:node_pool_id) @node_version = args[:node_version] if args.key?(:node_version) @project_id = args[:project_id] if args.key?(:project_id) @upgrade_settings = args[:upgrade_settings] if args.key?(:upgrade_settings) @workload_metadata_config = args[:workload_metadata_config] if args.key?(:workload_metadata_config) @zone = args[:zone] if args.key?(:zone) end |