Reference documentation and code samples for the Kubernetes Engine V1 API class Google::Cloud::Container::V1::NodeConfig.
Parameters that describe the nodes in a cluster.
GKE Autopilot clusters do not
recognize parameters in NodeConfig
. Use
AutoprovisioningNodePoolDefaults
instead.
Inherits
- Object
Extended By
- Google::Protobuf::MessageExts::ClassMethods
Includes
- Google::Protobuf::MessageExts
Methods
#accelerators
def accelerators() -> ::Array<::Google::Cloud::Container::V1::AcceleratorConfig>
- (::Array<::Google::Cloud::Container::V1::AcceleratorConfig>) — A list of hardware accelerators to be attached to each node. See https://cloud.google.com/compute/docs/gpus for more information about support for GPUs.
#accelerators=
def accelerators=(value) -> ::Array<::Google::Cloud::Container::V1::AcceleratorConfig>
- value (::Array<::Google::Cloud::Container::V1::AcceleratorConfig>) — A list of hardware accelerators to be attached to each node. See https://cloud.google.com/compute/docs/gpus for more information about support for GPUs.
- (::Array<::Google::Cloud::Container::V1::AcceleratorConfig>) — A list of hardware accelerators to be attached to each node. See https://cloud.google.com/compute/docs/gpus for more information about support for GPUs.
#advanced_machine_features
def advanced_machine_features() -> ::Google::Cloud::Container::V1::AdvancedMachineFeatures
- (::Google::Cloud::Container::V1::AdvancedMachineFeatures) — Advanced features for the Compute Engine VM.
#advanced_machine_features=
def advanced_machine_features=(value) -> ::Google::Cloud::Container::V1::AdvancedMachineFeatures
- value (::Google::Cloud::Container::V1::AdvancedMachineFeatures) — Advanced features for the Compute Engine VM.
- (::Google::Cloud::Container::V1::AdvancedMachineFeatures) — Advanced features for the Compute Engine VM.
#boot_disk_kms_key
def boot_disk_kms_key() -> ::String
- (::String) — The Customer Managed Encryption Key used to encrypt the boot disk attached to each node in the node pool. This should be of the form projects/[KEY_PROJECT_ID]/locations/[LOCATION]/keyRings/[RING_NAME]/cryptoKeys/[KEY_NAME]. For more information about protecting resources with Cloud KMS Keys please see: https://cloud.google.com/compute/docs/disks/customer-managed-encryption
#boot_disk_kms_key=
def boot_disk_kms_key=(value) -> ::String
- value (::String) — The Customer Managed Encryption Key used to encrypt the boot disk attached to each node in the node pool. This should be of the form projects/[KEY_PROJECT_ID]/locations/[LOCATION]/keyRings/[RING_NAME]/cryptoKeys/[KEY_NAME]. For more information about protecting resources with Cloud KMS Keys please see: https://cloud.google.com/compute/docs/disks/customer-managed-encryption
- (::String) — The Customer Managed Encryption Key used to encrypt the boot disk attached to each node in the node pool. This should be of the form projects/[KEY_PROJECT_ID]/locations/[LOCATION]/keyRings/[RING_NAME]/cryptoKeys/[KEY_NAME]. For more information about protecting resources with Cloud KMS Keys please see: https://cloud.google.com/compute/docs/disks/customer-managed-encryption
#confidential_nodes
def confidential_nodes() -> ::Google::Cloud::Container::V1::ConfidentialNodes
- (::Google::Cloud::Container::V1::ConfidentialNodes) — Confidential nodes config. All the nodes in the node pool will be Confidential VM once enabled.
#confidential_nodes=
def confidential_nodes=(value) -> ::Google::Cloud::Container::V1::ConfidentialNodes
- value (::Google::Cloud::Container::V1::ConfidentialNodes) — Confidential nodes config. All the nodes in the node pool will be Confidential VM once enabled.
- (::Google::Cloud::Container::V1::ConfidentialNodes) — Confidential nodes config. All the nodes in the node pool will be Confidential VM once enabled.
#disk_size_gb
def disk_size_gb() -> ::Integer
-
(::Integer) — Size of the disk attached to each node, specified in GB.
The smallest allowed disk size is 10GB.
If unspecified, the default disk size is 100GB.
#disk_size_gb=
def disk_size_gb=(value) -> ::Integer
-
value (::Integer) — Size of the disk attached to each node, specified in GB.
The smallest allowed disk size is 10GB.
If unspecified, the default disk size is 100GB.
-
(::Integer) — Size of the disk attached to each node, specified in GB.
The smallest allowed disk size is 10GB.
If unspecified, the default disk size is 100GB.
#disk_type
def disk_type() -> ::String
-
(::String) — Type of the disk attached to each node (e.g. 'pd-standard', 'pd-ssd' or
'pd-balanced')
If unspecified, the default disk type is 'pd-standard'
#disk_type=
def disk_type=(value) -> ::String
-
value (::String) — Type of the disk attached to each node (e.g. 'pd-standard', 'pd-ssd' or
'pd-balanced')
If unspecified, the default disk type is 'pd-standard'
-
(::String) — Type of the disk attached to each node (e.g. 'pd-standard', 'pd-ssd' or
'pd-balanced')
If unspecified, the default disk type is 'pd-standard'
#fast_socket
def fast_socket() -> ::Google::Cloud::Container::V1::FastSocket
- (::Google::Cloud::Container::V1::FastSocket) — Enable or disable NCCL fast socket for the node pool.
#fast_socket=
def fast_socket=(value) -> ::Google::Cloud::Container::V1::FastSocket
- value (::Google::Cloud::Container::V1::FastSocket) — Enable or disable NCCL fast socket for the node pool.
- (::Google::Cloud::Container::V1::FastSocket) — Enable or disable NCCL fast socket for the node pool.
#gcfs_config
def gcfs_config() -> ::Google::Cloud::Container::V1::GcfsConfig
- (::Google::Cloud::Container::V1::GcfsConfig) — Google Container File System (image streaming) configs.
#gcfs_config=
def gcfs_config=(value) -> ::Google::Cloud::Container::V1::GcfsConfig
- value (::Google::Cloud::Container::V1::GcfsConfig) — Google Container File System (image streaming) configs.
- (::Google::Cloud::Container::V1::GcfsConfig) — Google Container File System (image streaming) configs.
#gvnic
def gvnic() -> ::Google::Cloud::Container::V1::VirtualNIC
- (::Google::Cloud::Container::V1::VirtualNIC) — Enable or disable gvnic in the node pool.
#gvnic=
def gvnic=(value) -> ::Google::Cloud::Container::V1::VirtualNIC
- value (::Google::Cloud::Container::V1::VirtualNIC) — Enable or disable gvnic in the node pool.
- (::Google::Cloud::Container::V1::VirtualNIC) — Enable or disable gvnic in the node pool.
#image_type
def image_type() -> ::String
- (::String) — The image type to use for this node. Note that for a given image type, the latest version of it will be used.
#image_type=
def image_type=(value) -> ::String
- value (::String) — The image type to use for this node. Note that for a given image type, the latest version of it will be used.
- (::String) — The image type to use for this node. Note that for a given image type, the latest version of it will be used.
#kubelet_config
def kubelet_config() -> ::Google::Cloud::Container::V1::NodeKubeletConfig
- (::Google::Cloud::Container::V1::NodeKubeletConfig) — Node kubelet configs.
#kubelet_config=
def kubelet_config=(value) -> ::Google::Cloud::Container::V1::NodeKubeletConfig
- value (::Google::Cloud::Container::V1::NodeKubeletConfig) — Node kubelet configs.
- (::Google::Cloud::Container::V1::NodeKubeletConfig) — Node kubelet configs.
#labels
def labels() -> ::Google::Protobuf::Map{::String => ::String}
- (::Google::Protobuf::Map{::String => ::String}) — The map of Kubernetes labels (key/value pairs) to be applied to each node. These will added in addition to any default label(s) that Kubernetes may apply to the node. In case of conflict in label keys, the applied set may differ depending on the Kubernetes version -- it's best to assume the behavior is undefined and conflicts should be avoided. For more information, including usage and the valid values, see: https://kubernetes.io/docs/concepts/overview/working-with-objects/labels/
#labels=
def labels=(value) -> ::Google::Protobuf::Map{::String => ::String}
- value (::Google::Protobuf::Map{::String => ::String}) — The map of Kubernetes labels (key/value pairs) to be applied to each node. These will added in addition to any default label(s) that Kubernetes may apply to the node. In case of conflict in label keys, the applied set may differ depending on the Kubernetes version -- it's best to assume the behavior is undefined and conflicts should be avoided. For more information, including usage and the valid values, see: https://kubernetes.io/docs/concepts/overview/working-with-objects/labels/
- (::Google::Protobuf::Map{::String => ::String}) — The map of Kubernetes labels (key/value pairs) to be applied to each node. These will added in addition to any default label(s) that Kubernetes may apply to the node. In case of conflict in label keys, the applied set may differ depending on the Kubernetes version -- it's best to assume the behavior is undefined and conflicts should be avoided. For more information, including usage and the valid values, see: https://kubernetes.io/docs/concepts/overview/working-with-objects/labels/
#linux_node_config
def linux_node_config() -> ::Google::Cloud::Container::V1::LinuxNodeConfig
- (::Google::Cloud::Container::V1::LinuxNodeConfig) — Parameters that can be configured on Linux nodes.
#linux_node_config=
def linux_node_config=(value) -> ::Google::Cloud::Container::V1::LinuxNodeConfig
- value (::Google::Cloud::Container::V1::LinuxNodeConfig) — Parameters that can be configured on Linux nodes.
- (::Google::Cloud::Container::V1::LinuxNodeConfig) — Parameters that can be configured on Linux nodes.
#local_ssd_count
def local_ssd_count() -> ::Integer
-
(::Integer) — The number of local SSD disks to be attached to the node.
The limit for this value is dependent upon the maximum number of disks available on a machine per zone. See: https://cloud.google.com/compute/docs/disks/local-ssd for more information.
#local_ssd_count=
def local_ssd_count=(value) -> ::Integer
-
value (::Integer) — The number of local SSD disks to be attached to the node.
The limit for this value is dependent upon the maximum number of disks available on a machine per zone. See: https://cloud.google.com/compute/docs/disks/local-ssd for more information.
-
(::Integer) — The number of local SSD disks to be attached to the node.
The limit for this value is dependent upon the maximum number of disks available on a machine per zone. See: https://cloud.google.com/compute/docs/disks/local-ssd for more information.
#logging_config
def logging_config() -> ::Google::Cloud::Container::V1::NodePoolLoggingConfig
- (::Google::Cloud::Container::V1::NodePoolLoggingConfig) — Logging configuration.
#logging_config=
def logging_config=(value) -> ::Google::Cloud::Container::V1::NodePoolLoggingConfig
- value (::Google::Cloud::Container::V1::NodePoolLoggingConfig) — Logging configuration.
- (::Google::Cloud::Container::V1::NodePoolLoggingConfig) — Logging configuration.
#machine_type
def machine_type() -> ::String
-
(::String) — The name of a Google Compute Engine machine
type
If unspecified, the default machine type is
e2-medium
.
#machine_type=
def machine_type=(value) -> ::String
-
value (::String) — The name of a Google Compute Engine machine
type
If unspecified, the default machine type is
e2-medium
.
-
(::String) — The name of a Google Compute Engine machine
type
If unspecified, the default machine type is
e2-medium
.
#metadata
def metadata() -> ::Google::Protobuf::Map{::String => ::String}
-
(::Google::Protobuf::Map{::String => ::String}) — The metadata key/value pairs assigned to instances in the cluster.
Keys must conform to the regexp
[a-zA-Z0-9-_]+
and be less than 128 bytes in length. These are reflected as part of a URL in the metadata server. Additionally, to avoid ambiguity, keys must not conflict with any other metadata keys for the project or be one of the reserved keys:- "cluster-location"
- "cluster-name"
- "cluster-uid"
- "configure-sh"
- "containerd-configure-sh"
- "enable-os-login"
- "gci-ensure-gke-docker"
- "gci-metrics-enabled"
- "gci-update-strategy"
- "instance-template"
- "kube-env"
- "startup-script"
- "user-data"
- "disable-address-manager"
- "windows-startup-script-ps1"
- "common-psm1"
- "k8s-node-setup-psm1"
- "install-ssh-psm1"
- "user-profile-psm1"
Values are free-form strings, and only have meaning as interpreted by the image running in the instance. The only restriction placed on them is that each value's size must be less than or equal to 32 KB.
The total size of all keys and values must be less than 512 KB.
#metadata=
def metadata=(value) -> ::Google::Protobuf::Map{::String => ::String}
-
value (::Google::Protobuf::Map{::String => ::String}) — The metadata key/value pairs assigned to instances in the cluster.
Keys must conform to the regexp
[a-zA-Z0-9-_]+
and be less than 128 bytes in length. These are reflected as part of a URL in the metadata server. Additionally, to avoid ambiguity, keys must not conflict with any other metadata keys for the project or be one of the reserved keys:- "cluster-location"
- "cluster-name"
- "cluster-uid"
- "configure-sh"
- "containerd-configure-sh"
- "enable-os-login"
- "gci-ensure-gke-docker"
- "gci-metrics-enabled"
- "gci-update-strategy"
- "instance-template"
- "kube-env"
- "startup-script"
- "user-data"
- "disable-address-manager"
- "windows-startup-script-ps1"
- "common-psm1"
- "k8s-node-setup-psm1"
- "install-ssh-psm1"
- "user-profile-psm1"
Values are free-form strings, and only have meaning as interpreted by the image running in the instance. The only restriction placed on them is that each value's size must be less than or equal to 32 KB.
The total size of all keys and values must be less than 512 KB.
-
(::Google::Protobuf::Map{::String => ::String}) — The metadata key/value pairs assigned to instances in the cluster.
Keys must conform to the regexp
[a-zA-Z0-9-_]+
and be less than 128 bytes in length. These are reflected as part of a URL in the metadata server. Additionally, to avoid ambiguity, keys must not conflict with any other metadata keys for the project or be one of the reserved keys:- "cluster-location"
- "cluster-name"
- "cluster-uid"
- "configure-sh"
- "containerd-configure-sh"
- "enable-os-login"
- "gci-ensure-gke-docker"
- "gci-metrics-enabled"
- "gci-update-strategy"
- "instance-template"
- "kube-env"
- "startup-script"
- "user-data"
- "disable-address-manager"
- "windows-startup-script-ps1"
- "common-psm1"
- "k8s-node-setup-psm1"
- "install-ssh-psm1"
- "user-profile-psm1"
Values are free-form strings, and only have meaning as interpreted by the image running in the instance. The only restriction placed on them is that each value's size must be less than or equal to 32 KB.
The total size of all keys and values must be less than 512 KB.
#min_cpu_platform
def min_cpu_platform() -> ::String
-
(::String) — Minimum CPU platform to be used by this instance. The instance may be
scheduled on the specified or newer CPU platform. Applicable values are the
friendly names of CPU platforms, such as
minCpuPlatform: "Intel Haswell"
orminCpuPlatform: "Intel Sandy Bridge"
. For more information, read how to specify min CPU platform
#min_cpu_platform=
def min_cpu_platform=(value) -> ::String
-
value (::String) — Minimum CPU platform to be used by this instance. The instance may be
scheduled on the specified or newer CPU platform. Applicable values are the
friendly names of CPU platforms, such as
minCpuPlatform: "Intel Haswell"
orminCpuPlatform: "Intel Sandy Bridge"
. For more information, read how to specify min CPU platform
-
(::String) — Minimum CPU platform to be used by this instance. The instance may be
scheduled on the specified or newer CPU platform. Applicable values are the
friendly names of CPU platforms, such as
minCpuPlatform: "Intel Haswell"
orminCpuPlatform: "Intel Sandy Bridge"
. For more information, read how to specify min CPU platform
#node_group
def node_group() -> ::String
- (::String) — Setting this field will assign instances of this pool to run on the specified node group. This is useful for running workloads on sole tenant nodes.
#node_group=
def node_group=(value) -> ::String
- value (::String) — Setting this field will assign instances of this pool to run on the specified node group. This is useful for running workloads on sole tenant nodes.
- (::String) — Setting this field will assign instances of this pool to run on the specified node group. This is useful for running workloads on sole tenant nodes.
#oauth_scopes
def oauth_scopes() -> ::Array<::String>
-
(::Array<::String>) — The set of Google API scopes to be made available on all of the
node VMs under the "default" service account.
The following scopes are recommended, but not required, and by default are not included:
https://www.googleapis.com/auth/compute
is required for mounting persistent storage on your nodes.https://www.googleapis.com/auth/devstorage.read_only
is required for communicating with gcr.io (the Google Container Registry).
If unspecified, no scopes are added, unless Cloud Logging or Cloud Monitoring are enabled, in which case their required scopes will be added.
#oauth_scopes=
def oauth_scopes=(value) -> ::Array<::String>
-
value (::Array<::String>) — The set of Google API scopes to be made available on all of the
node VMs under the "default" service account.
The following scopes are recommended, but not required, and by default are not included:
https://www.googleapis.com/auth/compute
is required for mounting persistent storage on your nodes.https://www.googleapis.com/auth/devstorage.read_only
is required for communicating with gcr.io (the Google Container Registry).
If unspecified, no scopes are added, unless Cloud Logging or Cloud Monitoring are enabled, in which case their required scopes will be added.
-
(::Array<::String>) — The set of Google API scopes to be made available on all of the
node VMs under the "default" service account.
The following scopes are recommended, but not required, and by default are not included:
https://www.googleapis.com/auth/compute
is required for mounting persistent storage on your nodes.https://www.googleapis.com/auth/devstorage.read_only
is required for communicating with gcr.io (the Google Container Registry).
If unspecified, no scopes are added, unless Cloud Logging or Cloud Monitoring are enabled, in which case their required scopes will be added.
#preemptible
def preemptible() -> ::Boolean
- (::Boolean) — Whether the nodes are created as preemptible VM instances. See: https://cloud.google.com/compute/docs/instances/preemptible for more information about preemptible VM instances.
#preemptible=
def preemptible=(value) -> ::Boolean
- value (::Boolean) — Whether the nodes are created as preemptible VM instances. See: https://cloud.google.com/compute/docs/instances/preemptible for more information about preemptible VM instances.
- (::Boolean) — Whether the nodes are created as preemptible VM instances. See: https://cloud.google.com/compute/docs/instances/preemptible for more information about preemptible VM instances.
#reservation_affinity
def reservation_affinity() -> ::Google::Cloud::Container::V1::ReservationAffinity
- (::Google::Cloud::Container::V1::ReservationAffinity) — The optional reservation affinity. Setting this field will apply the specified Zonal Compute Reservation to this node pool.
#reservation_affinity=
def reservation_affinity=(value) -> ::Google::Cloud::Container::V1::ReservationAffinity
- value (::Google::Cloud::Container::V1::ReservationAffinity) — The optional reservation affinity. Setting this field will apply the specified Zonal Compute Reservation to this node pool.
- (::Google::Cloud::Container::V1::ReservationAffinity) — The optional reservation affinity. Setting this field will apply the specified Zonal Compute Reservation to this node pool.
#resource_labels
def resource_labels() -> ::Google::Protobuf::Map{::String => ::String}
- (::Google::Protobuf::Map{::String => ::String}) — The resource labels for the node pool to use to annotate any related Google Compute Engine resources.
#resource_labels=
def resource_labels=(value) -> ::Google::Protobuf::Map{::String => ::String}
- value (::Google::Protobuf::Map{::String => ::String}) — The resource labels for the node pool to use to annotate any related Google Compute Engine resources.
- (::Google::Protobuf::Map{::String => ::String}) — The resource labels for the node pool to use to annotate any related Google Compute Engine resources.
#sandbox_config
def sandbox_config() -> ::Google::Cloud::Container::V1::SandboxConfig
- (::Google::Cloud::Container::V1::SandboxConfig) — Sandbox configuration for this node.
#sandbox_config=
def sandbox_config=(value) -> ::Google::Cloud::Container::V1::SandboxConfig
- value (::Google::Cloud::Container::V1::SandboxConfig) — Sandbox configuration for this node.
- (::Google::Cloud::Container::V1::SandboxConfig) — Sandbox configuration for this node.
#service_account
def service_account() -> ::String
- (::String) — The Google Cloud Platform Service Account to be used by the node VMs. Specify the email address of the Service Account; otherwise, if no Service Account is specified, the "default" service account is used.
#service_account=
def service_account=(value) -> ::String
- value (::String) — The Google Cloud Platform Service Account to be used by the node VMs. Specify the email address of the Service Account; otherwise, if no Service Account is specified, the "default" service account is used.
- (::String) — The Google Cloud Platform Service Account to be used by the node VMs. Specify the email address of the Service Account; otherwise, if no Service Account is specified, the "default" service account is used.
#shielded_instance_config
def shielded_instance_config() -> ::Google::Cloud::Container::V1::ShieldedInstanceConfig
- (::Google::Cloud::Container::V1::ShieldedInstanceConfig) — Shielded Instance options.
#shielded_instance_config=
def shielded_instance_config=(value) -> ::Google::Cloud::Container::V1::ShieldedInstanceConfig
- value (::Google::Cloud::Container::V1::ShieldedInstanceConfig) — Shielded Instance options.
- (::Google::Cloud::Container::V1::ShieldedInstanceConfig) — Shielded Instance options.
#spot
def spot() -> ::Boolean
- (::Boolean) — Spot flag for enabling Spot VM, which is a rebrand of the existing preemptible flag.
#spot=
def spot=(value) -> ::Boolean
- value (::Boolean) — Spot flag for enabling Spot VM, which is a rebrand of the existing preemptible flag.
- (::Boolean) — Spot flag for enabling Spot VM, which is a rebrand of the existing preemptible flag.
#tags
def tags() -> ::Array<::String>
- (::Array<::String>) — The list of instance tags applied to all nodes. Tags are used to identify valid sources or targets for network firewalls and are specified by the client during cluster or node pool creation. Each tag within the list must comply with RFC1035.
#tags=
def tags=(value) -> ::Array<::String>
- value (::Array<::String>) — The list of instance tags applied to all nodes. Tags are used to identify valid sources or targets for network firewalls and are specified by the client during cluster or node pool creation. Each tag within the list must comply with RFC1035.
- (::Array<::String>) — The list of instance tags applied to all nodes. Tags are used to identify valid sources or targets for network firewalls and are specified by the client during cluster or node pool creation. Each tag within the list must comply with RFC1035.
#taints
def taints() -> ::Array<::Google::Cloud::Container::V1::NodeTaint>
-
(::Array<::Google::Cloud::Container::V1::NodeTaint>) — List of kubernetes taints to be applied to each node.
For more information, including usage and the valid values, see: https://kubernetes.io/docs/concepts/configuration/taint-and-toleration/
#taints=
def taints=(value) -> ::Array<::Google::Cloud::Container::V1::NodeTaint>
-
value (::Array<::Google::Cloud::Container::V1::NodeTaint>) — List of kubernetes taints to be applied to each node.
For more information, including usage and the valid values, see: https://kubernetes.io/docs/concepts/configuration/taint-and-toleration/
-
(::Array<::Google::Cloud::Container::V1::NodeTaint>) — List of kubernetes taints to be applied to each node.
For more information, including usage and the valid values, see: https://kubernetes.io/docs/concepts/configuration/taint-and-toleration/
#workload_metadata_config
def workload_metadata_config() -> ::Google::Cloud::Container::V1::WorkloadMetadataConfig
- (::Google::Cloud::Container::V1::WorkloadMetadataConfig) — The workload metadata configuration for this node.
#workload_metadata_config=
def workload_metadata_config=(value) -> ::Google::Cloud::Container::V1::WorkloadMetadataConfig
- value (::Google::Cloud::Container::V1::WorkloadMetadataConfig) — The workload metadata configuration for this node.
- (::Google::Cloud::Container::V1::WorkloadMetadataConfig) — The workload metadata configuration for this node.