ComputeNodeGroup
Property | Value |
---|---|
Google Cloud Service Name | Compute Engine |
Google Cloud Service Documentation | /compute/docs/ |
Google Cloud REST Resource Name | v1.nodeGroups |
Google Cloud REST Resource Documentation | /compute/docs/reference/rest/v1/nodeGroups |
Config Connector Resource Short Names | gcpcomputenodegroup gcpcomputenodegroups computenodegroup |
Config Connector Service Name | compute.googleapis.com |
Config Connector Resource Fully Qualified Name | computenodegroups.compute.cnrm.cloud.google.com |
Can Be Referenced by IAMPolicy/IAMPolicyMember | No |
Config Connector Default Average Reconcile Interval In Seconds | 600 |
Custom Resource Definition Properties
Annotations
Fields | |
---|---|
cnrm.cloud.google.com/project-id |
Spec
Schema
autoscalingPolicy:
maxNodes: integer
minNodes: integer
mode: string
description: string
initialSize: integer
maintenancePolicy: string
maintenanceWindow:
startTime: string
nodeTemplateRef:
external: string
name: string
namespace: string
resourceID: string
shareSettings:
projectMap:
- idRef:
external: string
name: string
namespace: string
projectIdRef:
external: string
name: string
namespace: string
shareType: string
size: integer
zone: string
Fields | |
---|---|
Optional |
Immutable. If you use sole-tenant nodes for your workloads, you can use the node group autoscaler to automatically manage the sizes of your node groups. |
Optional |
Immutable. Maximum size of the node group. Set to a value less than or equal to 100 and greater than or equal to min-nodes. |
Optional |
Immutable. Minimum size of the node group. Must be less than or equal to max-nodes. The default value is 0. |
Optional |
Immutable. The autoscaling mode. Set to one of the following: - OFF: Disables the autoscaler. - ON: Enables scaling in and scaling out. - ONLY_SCALE_OUT: Enables only scaling out. You must use this mode if your node groups are configured to restart their hosted VMs on minimal servers. Possible values: ["OFF", "ON", "ONLY_SCALE_OUT"]. |
Optional |
Immutable. An optional textual description of the resource. |
Optional |
Immutable. The initial number of nodes in the node group. One of 'initial_size' or 'size' must be specified. |
Optional |
Immutable. Specifies how to handle instances when a node in the group undergoes maintenance. Set to one of: DEFAULT, RESTART_IN_PLACE, or MIGRATE_WITHIN_NODE_GROUP. The default value is DEFAULT. |
Optional |
Immutable. contains properties for the timeframe of maintenance. |
Required* |
Immutable. instances.start time of the window. This must be in UTC format that resolves to one of 00:00, 04:00, 08:00, 12:00, 16:00, or 20:00. For example, both 13:00-5 and 08:00 are valid. |
Required |
The node template to which this node group belongs. |
Optional |
Allowed value: The `selfLink` field of a `ComputeNodeTemplate` resource. |
Optional |
Name of the referent. More info: https://kubernetes.io/docs/concepts/overview/working-with-objects/names/#names |
Optional |
Namespace of the referent. More info: https://kubernetes.io/docs/concepts/overview/working-with-objects/namespaces/ |
Optional |
Immutable. Optional. The name of the resource. Used for creation and acquisition. When unset, the value of `metadata.name` is used as the default. |
Optional |
Immutable. Share settings for the node group. |
Optional |
Immutable. A map of project id and project config. This is only valid when shareType's value is SPECIFIC_PROJECTS. |
Optional |
|
Required* |
The key of this project config in the parent map. |
Optional |
Allowed value: The `name` field of a `Project` resource. |
Optional |
Name of the referent. More info: https://kubernetes.io/docs/concepts/overview/working-with-objects/names/#names |
Optional |
Namespace of the referent. More info: https://kubernetes.io/docs/concepts/overview/working-with-objects/namespaces/ |
Required* |
The project id/number should be the same as the key of this project config in the project map. |
Optional |
Allowed value: The `name` field of a `Project` resource. |
Optional |
Name of the referent. More info: https://kubernetes.io/docs/concepts/overview/working-with-objects/names/#names |
Optional |
Namespace of the referent. More info: https://kubernetes.io/docs/concepts/overview/working-with-objects/namespaces/ |
Required* |
Immutable. Node group sharing type. Possible values: ["ORGANIZATION", "SPECIFIC_PROJECTS", "LOCAL"]. |
Optional |
Immutable. The total number of nodes in the node group. One of 'initial_size' or 'size' must be specified. |
Required |
Immutable. Zone where this node group is located. |
* Field is required when parent field is specified
Status
Schema
conditions:
- lastTransitionTime: string
message: string
reason: string
status: string
type: string
creationTimestamp: string
observedGeneration: integer
selfLink: string
Fields | |
---|---|
conditions |
Conditions represent the latest available observation of the resource's current state. |
conditions[] |
|
conditions[].lastTransitionTime |
Last time the condition transitioned from one status to another. |
conditions[].message |
Human-readable message indicating details about last transition. |
conditions[].reason |
Unique, one-word, CamelCase reason for the condition's last transition. |
conditions[].status |
Status is the status of the condition. Can be True, False, Unknown. |
conditions[].type |
Type is the type of the condition. |
creationTimestamp |
Creation timestamp in RFC3339 text format. |
observedGeneration |
ObservedGeneration is the generation of the resource that was most recently observed by the Config Connector controller. If this is equal to metadata.generation, then that means that the current reported status reflects the most recent desired state of the resource. |
selfLink |
|
Sample YAML(s)
Typical Use Case
# Copyright 2020 Google LLC
#
# Licensed under the Apache License, Version 2.0 (the "License");
# you may not use this file except in compliance with the License.
# You may obtain a copy of the License at
#
# http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS,
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
# See the License for the specific language governing permissions and
# limitations under the License.
apiVersion: compute.cnrm.cloud.google.com/v1beta1
kind: ComputeNodeGroup
metadata:
name: computenodegroup-sample
spec:
description: A single sole-tenant node in the us-central1-b zone.
size: 1
nodeTemplateRef:
name: computenodegroup-dep
zone: us-central1-b
---
apiVersion: compute.cnrm.cloud.google.com/v1beta1
kind: ComputeNodeTemplate
metadata:
name: computenodegroup-dep
spec:
region: us-central1
nodeType: n1-node-96-624