Add Cluster API controller
Change-Id: I4dc45689e5d4c1df5b1910122794b7b400044ede
This commit is contained in:
parent
cac75584d0
commit
d10ad53ef5
18
manifests/function/cluster-api/kustomization.yaml
Normal file
18
manifests/function/cluster-api/kustomization.yaml
Normal file
@ -0,0 +1,18 @@
|
||||
resources:
|
||||
- ../../global/crd/cluster-api
|
||||
- rbac
|
||||
- operator.yaml
|
||||
- namespace.yaml
|
||||
|
||||
commonLabels:
|
||||
# NOTE We can't use airshipit.org/clustertype
|
||||
# bacause a label can't consists of multiple values
|
||||
airshipit.org/ephemeral: "true"
|
||||
airshipit.org/target: "true"
|
||||
|
||||
namespace: capi
|
||||
|
||||
#vars:
|
||||
# $(IMAGE_PULL_POLICY)
|
||||
# The image pull policy by default should be "IfNotPresent",
|
||||
# it should be globally defined for all images
|
4
manifests/function/cluster-api/namespace.yaml
Normal file
4
manifests/function/cluster-api/namespace.yaml
Normal file
@ -0,0 +1,4 @@
|
||||
apiVersion: v1
|
||||
kind: Namespace
|
||||
metadata:
|
||||
name: capi
|
59
manifests/function/cluster-api/operator.yaml
Normal file
59
manifests/function/cluster-api/operator.yaml
Normal file
@ -0,0 +1,59 @@
|
||||
---
|
||||
apiVersion: v1
|
||||
kind: Service
|
||||
metadata:
|
||||
labels:
|
||||
control-plane: controller-manager
|
||||
controller-tools.k8s.io: "1.0"
|
||||
name: cluster-api-controller-manager-service
|
||||
spec:
|
||||
ports:
|
||||
- port: 443
|
||||
selector:
|
||||
control-plane: controller-manager
|
||||
controller-tools.k8s.io: "1.0"
|
||||
---
|
||||
apiVersion: apps/v1
|
||||
kind: StatefulSet
|
||||
metadata:
|
||||
labels:
|
||||
control-plane: controller-manager
|
||||
controller-tools.k8s.io: "1.0"
|
||||
name: cluster-api-controller-manager
|
||||
spec:
|
||||
selector:
|
||||
matchLabels:
|
||||
control-plane: controller-manager
|
||||
controller-tools.k8s.io: "1.0"
|
||||
serviceName: cluster-api-controller-manager-service
|
||||
template:
|
||||
metadata:
|
||||
labels:
|
||||
control-plane: controller-manager
|
||||
controller-tools.k8s.io: "1.0"
|
||||
spec:
|
||||
containers:
|
||||
- command:
|
||||
- /manager
|
||||
image: "gcr.io/k8s-staging-cluster-api/cluster-api-controller:release-0.2"
|
||||
imagePullPolicy: $(IMAGE_PULL_POLICY)
|
||||
name: manager
|
||||
resources:
|
||||
limits:
|
||||
cpu: 100m
|
||||
memory: 30Mi
|
||||
requests:
|
||||
cpu: 100m
|
||||
memory: 20Mi
|
||||
terminationGracePeriodSeconds: 10
|
||||
tolerations:
|
||||
- effect: NoSchedule
|
||||
key: node-role.kubernetes.io/master
|
||||
- key: CriticalAddonsOnly
|
||||
operator: Exists
|
||||
- effect: NoExecute
|
||||
key: node.alpha.kubernetes.io/notReady
|
||||
operator: Exists
|
||||
- effect: NoExecute
|
||||
key: node.alpha.kubernetes.io/unreachable
|
||||
operator: Exists
|
@ -0,0 +1,32 @@
|
||||
---
|
||||
apiVersion: rbac.authorization.k8s.io/v1
|
||||
kind: Role
|
||||
metadata:
|
||||
name: capi-leader-election-role
|
||||
rules:
|
||||
- apiGroups:
|
||||
- ""
|
||||
resources:
|
||||
- configmaps
|
||||
verbs:
|
||||
- get
|
||||
- list
|
||||
- watch
|
||||
- create
|
||||
- update
|
||||
- patch
|
||||
- delete
|
||||
- apiGroups:
|
||||
- ""
|
||||
resources:
|
||||
- configmaps/status
|
||||
verbs:
|
||||
- get
|
||||
- update
|
||||
- patch
|
||||
- apiGroups:
|
||||
- ""
|
||||
resources:
|
||||
- events
|
||||
verbs:
|
||||
- create
|
@ -0,0 +1,12 @@
|
||||
---
|
||||
apiVersion: rbac.authorization.k8s.io/v1
|
||||
kind: RoleBinding
|
||||
metadata:
|
||||
name: capi-leader-election-rolebinding
|
||||
roleRef:
|
||||
apiGroup: rbac.authorization.k8s.io
|
||||
kind: Role
|
||||
name: capi-leader-election-role
|
||||
subjects:
|
||||
- kind: ServiceAccount
|
||||
name: default
|
104
manifests/function/cluster-api/rbac/capi-manager-role.yaml
Normal file
104
manifests/function/cluster-api/rbac/capi-manager-role.yaml
Normal file
@ -0,0 +1,104 @@
|
||||
---
|
||||
apiVersion: rbac.authorization.k8s.io/v1
|
||||
kind: ClusterRole
|
||||
metadata:
|
||||
creationTimestamp: null
|
||||
name: capi-manager-role
|
||||
rules:
|
||||
- apiGroups:
|
||||
- bootstrap.cluster.x-k8s.io
|
||||
- infrastructure.cluster.x-k8s.io
|
||||
resources:
|
||||
- '*'
|
||||
verbs:
|
||||
- create
|
||||
- delete
|
||||
- get
|
||||
- list
|
||||
- patch
|
||||
- update
|
||||
- watch
|
||||
- apiGroups:
|
||||
- cluster.x-k8s.io
|
||||
resources:
|
||||
- clusters
|
||||
- clusters/status
|
||||
verbs:
|
||||
- create
|
||||
- delete
|
||||
- get
|
||||
- list
|
||||
- patch
|
||||
- update
|
||||
- watch
|
||||
- apiGroups:
|
||||
- cluster.x-k8s.io
|
||||
resources:
|
||||
- machinedeployments
|
||||
- machinedeployments/status
|
||||
verbs:
|
||||
- create
|
||||
- delete
|
||||
- get
|
||||
- list
|
||||
- patch
|
||||
- update
|
||||
- watch
|
||||
- apiGroups:
|
||||
- cluster.x-k8s.io
|
||||
resources:
|
||||
- machines
|
||||
- machines/status
|
||||
verbs:
|
||||
- create
|
||||
- delete
|
||||
- get
|
||||
- list
|
||||
- patch
|
||||
- update
|
||||
- watch
|
||||
- apiGroups:
|
||||
- cluster.x-k8s.io
|
||||
resources:
|
||||
- machinesets
|
||||
- machinesets/status
|
||||
verbs:
|
||||
- create
|
||||
- delete
|
||||
- get
|
||||
- list
|
||||
- patch
|
||||
- update
|
||||
- watch
|
||||
- apiGroups:
|
||||
- ""
|
||||
resources:
|
||||
- events
|
||||
verbs:
|
||||
- create
|
||||
- get
|
||||
- list
|
||||
- patch
|
||||
- watch
|
||||
- apiGroups:
|
||||
- ""
|
||||
resources:
|
||||
- nodes
|
||||
verbs:
|
||||
- create
|
||||
- delete
|
||||
- get
|
||||
- list
|
||||
- patch
|
||||
- update
|
||||
- watch
|
||||
- apiGroups:
|
||||
- ""
|
||||
resources:
|
||||
- secrets
|
||||
verbs:
|
||||
- create
|
||||
- get
|
||||
- list
|
||||
- patch
|
||||
- watch
|
@ -0,0 +1,13 @@
|
||||
---
|
||||
apiVersion: rbac.authorization.k8s.io/v1
|
||||
kind: ClusterRoleBinding
|
||||
metadata:
|
||||
creationTimestamp: null
|
||||
name: capi-manager-rolebinding
|
||||
roleRef:
|
||||
apiGroup: rbac.authorization.k8s.io
|
||||
kind: ClusterRole
|
||||
name: capi-manager-role
|
||||
subjects:
|
||||
- kind: ServiceAccount
|
||||
name: default
|
5
manifests/function/cluster-api/rbac/kustomization.yaml
Normal file
5
manifests/function/cluster-api/rbac/kustomization.yaml
Normal file
@ -0,0 +1,5 @@
|
||||
resources:
|
||||
- capi-leader-election-rolebinding.yaml
|
||||
- capi-leader-election-role.yaml
|
||||
- capi-manager-rolebinding.yaml
|
||||
- capi-manager-role.yaml
|
169
manifests/global/crd/cluster-api/clusters.cluster.x-k8s.io.yaml
Normal file
169
manifests/global/crd/cluster-api/clusters.cluster.x-k8s.io.yaml
Normal file
@ -0,0 +1,169 @@
|
||||
---
|
||||
apiVersion: apiextensions.k8s.io/v1beta1
|
||||
kind: CustomResourceDefinition
|
||||
metadata:
|
||||
creationTimestamp: null
|
||||
name: clusters.cluster.x-k8s.io
|
||||
spec:
|
||||
additionalPrinterColumns:
|
||||
- JSONPath: .status.phase
|
||||
description: Cluster status such as Pending/Provisioning/Provisioned/Deleting/Failed
|
||||
name: Phase
|
||||
type: string
|
||||
group: cluster.x-k8s.io
|
||||
names:
|
||||
categories:
|
||||
- cluster-api
|
||||
kind: Cluster
|
||||
listKind: ClusterList
|
||||
plural: clusters
|
||||
shortNames:
|
||||
- cl
|
||||
singular: cluster
|
||||
scope: Namespaced
|
||||
subresources:
|
||||
status: {}
|
||||
validation:
|
||||
openAPIV3Schema:
|
||||
description: Cluster is the Schema for the clusters API
|
||||
properties:
|
||||
apiVersion:
|
||||
description: 'APIVersion defines the versioned schema of this representation
|
||||
of an object. Servers should convert recognized schemas to the latest
|
||||
internal value, and may reject unrecognized values. More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#resources'
|
||||
type: string
|
||||
kind:
|
||||
description: 'Kind is a string value representing the REST resource this
|
||||
object represents. Servers may infer this from the endpoint the client
|
||||
submits requests to. Cannot be updated. In CamelCase. More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#types-kinds'
|
||||
type: string
|
||||
metadata:
|
||||
type: object
|
||||
spec:
|
||||
description: ClusterSpec defines the desired state of Cluster
|
||||
properties:
|
||||
clusterNetwork:
|
||||
description: Cluster network configuration
|
||||
properties:
|
||||
apiServerPort:
|
||||
description: APIServerPort specifies the port the API Server should
|
||||
bind to. Defaults to 6443.
|
||||
format: int32
|
||||
type: integer
|
||||
pods:
|
||||
description: The network ranges from which Pod networks are allocated.
|
||||
properties:
|
||||
cidrBlocks:
|
||||
items:
|
||||
type: string
|
||||
type: array
|
||||
required:
|
||||
- cidrBlocks
|
||||
type: object
|
||||
serviceDomain:
|
||||
description: Domain name for services.
|
||||
type: string
|
||||
services:
|
||||
description: The network ranges from which service VIPs are allocated.
|
||||
properties:
|
||||
cidrBlocks:
|
||||
items:
|
||||
type: string
|
||||
type: array
|
||||
required:
|
||||
- cidrBlocks
|
||||
type: object
|
||||
type: object
|
||||
infrastructureRef:
|
||||
description: InfrastructureRef is a reference to a provider-specific
|
||||
resource that holds the details for provisioning infrastructure for
|
||||
a cluster in said provider.
|
||||
properties:
|
||||
apiVersion:
|
||||
description: API version of the referent.
|
||||
type: string
|
||||
fieldPath:
|
||||
description: 'If referring to a piece of an object instead of an
|
||||
entire object, this string should contain a valid JSON/Go field
|
||||
access statement, such as desiredState.manifest.containers[2].
|
||||
For example, if the object reference is to a container within
|
||||
a pod, this would take on a value like: "spec.containers{name}"
|
||||
(where "name" refers to the name of the container that triggered
|
||||
the event) or if no container name is specified "spec.containers[2]"
|
||||
(container with index 2 in this pod). This syntax is chosen only
|
||||
to have some well-defined way of referencing a part of an object.
|
||||
TODO: this design is not final and this field is subject to change
|
||||
in the future.'
|
||||
type: string
|
||||
kind:
|
||||
description: 'Kind of the referent. More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#types-kinds'
|
||||
type: string
|
||||
name:
|
||||
description: 'Name of the referent. More info: https://kubernetes.io/docs/concepts/overview/working-with-objects/names/#names'
|
||||
type: string
|
||||
namespace:
|
||||
description: 'Namespace of the referent. More info: https://kubernetes.io/docs/concepts/overview/working-with-objects/namespaces/'
|
||||
type: string
|
||||
resourceVersion:
|
||||
description: 'Specific resourceVersion to which this reference is
|
||||
made, if any. More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#concurrency-control-and-consistency'
|
||||
type: string
|
||||
uid:
|
||||
description: 'UID of the referent. More info: https://kubernetes.io/docs/concepts/overview/working-with-objects/names/#uids'
|
||||
type: string
|
||||
type: object
|
||||
type: object
|
||||
status:
|
||||
description: ClusterStatus defines the observed state of Cluster
|
||||
properties:
|
||||
apiEndpoints:
|
||||
description: APIEndpoints represents the endpoints to communicate with
|
||||
the control plane.
|
||||
items:
|
||||
description: APIEndpoint represents a reachable Kubernetes API endpoint.
|
||||
properties:
|
||||
host:
|
||||
description: The hostname on which the API server is serving.
|
||||
type: string
|
||||
port:
|
||||
description: The port on which the API server is serving.
|
||||
type: integer
|
||||
required:
|
||||
- host
|
||||
- port
|
||||
type: object
|
||||
type: array
|
||||
controlPlaneInitialized:
|
||||
description: ControlPlaneInitialized defines if the control plane has
|
||||
been initialized.
|
||||
type: boolean
|
||||
errorMessage:
|
||||
description: ErrorMessage indicates that there is a problem reconciling
|
||||
the state, and will be set to a descriptive error message.
|
||||
type: string
|
||||
errorReason:
|
||||
description: ErrorReason indicates that there is a problem reconciling
|
||||
the state, and will be set to a token value suitable for programmatic
|
||||
interpretation.
|
||||
type: string
|
||||
infrastructureReady:
|
||||
description: InfrastructureReady is the state of the infrastructure
|
||||
provider.
|
||||
type: boolean
|
||||
phase:
|
||||
description: Phase represents the current phase of cluster actuation.
|
||||
E.g. Pending, Running, Terminating, Failed etc.
|
||||
type: string
|
||||
type: object
|
||||
type: object
|
||||
version: v1alpha2
|
||||
versions:
|
||||
- name: v1alpha2
|
||||
served: true
|
||||
storage: true
|
||||
status:
|
||||
acceptedNames:
|
||||
kind: ""
|
||||
plural: ""
|
||||
conditions: []
|
||||
storedVersions: []
|
5
manifests/global/crd/cluster-api/kustomization.yaml
Normal file
5
manifests/global/crd/cluster-api/kustomization.yaml
Normal file
@ -0,0 +1,5 @@
|
||||
resources:
|
||||
- clusters.cluster.x-k8s.io.yaml
|
||||
- machinedeployments.cluster.x-k8s.io.yaml
|
||||
- machines.cluster.x-k8s.io.yaml
|
||||
- machinesets.cluster.x-k8s.io.yaml
|
@ -0,0 +1,539 @@
|
||||
---
|
||||
apiVersion: apiextensions.k8s.io/v1beta1
|
||||
kind: CustomResourceDefinition
|
||||
metadata:
|
||||
creationTimestamp: null
|
||||
name: machinedeployments.cluster.x-k8s.io
|
||||
spec:
|
||||
group: cluster.x-k8s.io
|
||||
names:
|
||||
categories:
|
||||
- cluster-api
|
||||
kind: MachineDeployment
|
||||
listKind: MachineDeploymentList
|
||||
plural: machinedeployments
|
||||
shortNames:
|
||||
- md
|
||||
singular: machinedeployment
|
||||
scope: Namespaced
|
||||
subresources:
|
||||
scale:
|
||||
labelSelectorPath: .status.selector
|
||||
specReplicasPath: .spec.replicas
|
||||
statusReplicasPath: .status.replicas
|
||||
status: {}
|
||||
validation:
|
||||
openAPIV3Schema:
|
||||
description: MachineDeployment is the Schema for the machinedeployments API
|
||||
properties:
|
||||
apiVersion:
|
||||
description: 'APIVersion defines the versioned schema of this representation
|
||||
of an object. Servers should convert recognized schemas to the latest
|
||||
internal value, and may reject unrecognized values. More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#resources'
|
||||
type: string
|
||||
kind:
|
||||
description: 'Kind is a string value representing the REST resource this
|
||||
object represents. Servers may infer this from the endpoint the client
|
||||
submits requests to. Cannot be updated. In CamelCase. More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#types-kinds'
|
||||
type: string
|
||||
metadata:
|
||||
type: object
|
||||
spec:
|
||||
description: MachineDeploymentSpec defines the desired state of MachineDeployment
|
||||
properties:
|
||||
minReadySeconds:
|
||||
description: Minimum number of seconds for which a newly created machine
|
||||
should be ready. Defaults to 0 (machine will be considered available
|
||||
as soon as it is ready)
|
||||
format: int32
|
||||
type: integer
|
||||
paused:
|
||||
description: Indicates that the deployment is paused.
|
||||
type: boolean
|
||||
progressDeadlineSeconds:
|
||||
description: The maximum time in seconds for a deployment to make progress
|
||||
before it is considered to be failed. The deployment controller will
|
||||
continue to process failed deployments and a condition with a ProgressDeadlineExceeded
|
||||
reason will be surfaced in the deployment status. Note that progress
|
||||
will not be estimated during the time a deployment is paused. Defaults
|
||||
to 600s.
|
||||
format: int32
|
||||
type: integer
|
||||
replicas:
|
||||
description: Number of desired machines. Defaults to 1. This is a pointer
|
||||
to distinguish between explicit zero and not specified.
|
||||
format: int32
|
||||
type: integer
|
||||
revisionHistoryLimit:
|
||||
description: The number of old MachineSets to retain to allow rollback.
|
||||
This is a pointer to distinguish between explicit zero and not specified.
|
||||
Defaults to 1.
|
||||
format: int32
|
||||
type: integer
|
||||
selector:
|
||||
description: Label selector for machines. Existing MachineSets whose
|
||||
machines are selected by this will be the ones affected by this deployment.
|
||||
It must match the machine template's labels.
|
||||
properties:
|
||||
matchExpressions:
|
||||
description: matchExpressions is a list of label selector requirements.
|
||||
The requirements are ANDed.
|
||||
items:
|
||||
description: A label selector requirement is a selector that contains
|
||||
values, a key, and an operator that relates the key and values.
|
||||
properties:
|
||||
key:
|
||||
description: key is the label key that the selector applies
|
||||
to.
|
||||
type: string
|
||||
operator:
|
||||
description: operator represents a key's relationship to a
|
||||
set of values. Valid operators are In, NotIn, Exists and
|
||||
DoesNotExist.
|
||||
type: string
|
||||
values:
|
||||
description: values is an array of string values. If the operator
|
||||
is In or NotIn, the values array must be non-empty. If the
|
||||
operator is Exists or DoesNotExist, the values array must
|
||||
be empty. This array is replaced during a strategic merge
|
||||
patch.
|
||||
items:
|
||||
type: string
|
||||
type: array
|
||||
required:
|
||||
- key
|
||||
- operator
|
||||
type: object
|
||||
type: array
|
||||
matchLabels:
|
||||
additionalProperties:
|
||||
type: string
|
||||
description: matchLabels is a map of {key,value} pairs. A single
|
||||
{key,value} in the matchLabels map is equivalent to an element
|
||||
of matchExpressions, whose key field is "key", the operator is
|
||||
"In", and the values array contains only "value". The requirements
|
||||
are ANDed.
|
||||
type: object
|
||||
type: object
|
||||
strategy:
|
||||
description: The deployment strategy to use to replace existing machines
|
||||
with new ones.
|
||||
properties:
|
||||
rollingUpdate:
|
||||
description: Rolling update config params. Present only if MachineDeploymentStrategyType
|
||||
= RollingUpdate.
|
||||
properties:
|
||||
maxSurge:
|
||||
anyOf:
|
||||
- type: string
|
||||
- type: integer
|
||||
description: 'The maximum number of machines that can be scheduled
|
||||
above the desired number of machines. Value can be an absolute
|
||||
number (ex: 5) or a percentage of desired machines (ex: 10%).
|
||||
This can not be 0 if MaxUnavailable is 0. Absolute number
|
||||
is calculated from percentage by rounding up. Defaults to
|
||||
1. Example: when this is set to 30%, the new MachineSet can
|
||||
be scaled up immediately when the rolling update starts, such
|
||||
that the total number of old and new machines do not exceed
|
||||
130% of desired machines. Once old machines have been killed,
|
||||
new MachineSet can be scaled up further, ensuring that total
|
||||
number of machines running at any time during the update is
|
||||
at most 130% of desired machines.'
|
||||
maxUnavailable:
|
||||
anyOf:
|
||||
- type: string
|
||||
- type: integer
|
||||
description: 'The maximum number of machines that can be unavailable
|
||||
during the update. Value can be an absolute number (ex: 5)
|
||||
or a percentage of desired machines (ex: 10%). Absolute number
|
||||
is calculated from percentage by rounding down. This can not
|
||||
be 0 if MaxSurge is 0. Defaults to 0. Example: when this is
|
||||
set to 30%, the old MachineSet can be scaled down to 70% of
|
||||
desired machines immediately when the rolling update starts.
|
||||
Once new machines are ready, old MachineSet can be scaled
|
||||
down further, followed by scaling up the new MachineSet, ensuring
|
||||
that the total number of machines available at all times during
|
||||
the update is at least 70% of desired machines.'
|
||||
type: object
|
||||
type:
|
||||
description: Type of deployment. Currently the only supported strategy
|
||||
is "RollingUpdate". Default is RollingUpdate.
|
||||
type: string
|
||||
type: object
|
||||
template:
|
||||
description: Template describes the machines that will be created.
|
||||
properties:
|
||||
metadata:
|
||||
description: 'Standard object''s metadata. More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#metadata'
|
||||
properties:
|
||||
annotations:
|
||||
additionalProperties:
|
||||
type: string
|
||||
description: 'Annotations is an unstructured key value map stored
|
||||
with a resource that may be set by external tools to store
|
||||
and retrieve arbitrary metadata. They are not queryable and
|
||||
should be preserved when modifying objects. More info: http://kubernetes.io/docs/user-guide/annotations'
|
||||
type: object
|
||||
generateName:
|
||||
description: "GenerateName is an optional prefix, used by the
|
||||
server, to generate a unique name ONLY IF the Name field has
|
||||
not been provided. If this field is used, the name returned
|
||||
to the client will be different than the name passed. This
|
||||
value will also be combined with a unique suffix. The provided
|
||||
value has the same validation rules as the Name field, and
|
||||
may be truncated by the length of the suffix required to make
|
||||
the value unique on the server. \n If this field is specified
|
||||
and the generated name exists, the server will NOT return
|
||||
a 409 - instead, it will either return 201 Created or 500
|
||||
with Reason ServerTimeout indicating a unique name could not
|
||||
be found in the time allotted, and the client should retry
|
||||
(optionally after the time indicated in the Retry-After header).
|
||||
\n Applied only if Name is not specified. More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#idempotency"
|
||||
type: string
|
||||
labels:
|
||||
additionalProperties:
|
||||
type: string
|
||||
description: 'Map of string keys and values that can be used
|
||||
to organize and categorize (scope and select) objects. May
|
||||
match selectors of replication controllers and services. More
|
||||
info: http://kubernetes.io/docs/user-guide/labels'
|
||||
type: object
|
||||
name:
|
||||
description: 'Name must be unique within a namespace. Is required
|
||||
when creating resources, although some resources may allow
|
||||
a client to request the generation of an appropriate name
|
||||
automatically. Name is primarily intended for creation idempotence
|
||||
and configuration definition. Cannot be updated. More info:
|
||||
http://kubernetes.io/docs/user-guide/identifiers#names'
|
||||
type: string
|
||||
namespace:
|
||||
description: "Namespace defines the space within each name must
|
||||
be unique. An empty namespace is equivalent to the \"default\"
|
||||
namespace, but \"default\" is the canonical representation.
|
||||
Not all objects are required to be scoped to a namespace -
|
||||
the value of this field for those objects will be empty. \n
|
||||
Must be a DNS_LABEL. Cannot be updated. More info: http://kubernetes.io/docs/user-guide/namespaces"
|
||||
type: string
|
||||
ownerReferences:
|
||||
description: List of objects depended by this object. If ALL
|
||||
objects in the list have been deleted, this object will be
|
||||
garbage collected. If this object is managed by a controller,
|
||||
then an entry in this list will point to this controller,
|
||||
with the controller field set to true. There cannot be more
|
||||
than one managing controller.
|
||||
items:
|
||||
description: OwnerReference contains enough information to
|
||||
let you identify an owning object. An owning object must
|
||||
be in the same namespace as the dependent, or be cluster-scoped,
|
||||
so there is no namespace field.
|
||||
properties:
|
||||
apiVersion:
|
||||
description: API version of the referent.
|
||||
type: string
|
||||
blockOwnerDeletion:
|
||||
description: If true, AND if the owner has the "foregroundDeletion"
|
||||
finalizer, then the owner cannot be deleted from the
|
||||
key-value store until this reference is removed. Defaults
|
||||
to false. To set this field, a user needs "delete" permission
|
||||
of the owner, otherwise 422 (Unprocessable Entity) will
|
||||
be returned.
|
||||
type: boolean
|
||||
controller:
|
||||
description: If true, this reference points to the managing
|
||||
controller.
|
||||
type: boolean
|
||||
kind:
|
||||
description: 'Kind of the referent. More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#types-kinds'
|
||||
type: string
|
||||
name:
|
||||
description: 'Name of the referent. More info: http://kubernetes.io/docs/user-guide/identifiers#names'
|
||||
type: string
|
||||
uid:
|
||||
description: 'UID of the referent. More info: http://kubernetes.io/docs/user-guide/identifiers#uids'
|
||||
type: string
|
||||
required:
|
||||
- apiVersion
|
||||
- kind
|
||||
- name
|
||||
- uid
|
||||
type: object
|
||||
type: array
|
||||
type: object
|
||||
spec:
|
||||
description: 'Specification of the desired behavior of the machine.
|
||||
More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#spec-and-status'
|
||||
properties:
|
||||
bootstrap:
|
||||
description: Bootstrap is a reference to a local struct which
|
||||
encapsulates fields to configure the Machine’s bootstrapping
|
||||
mechanism.
|
||||
properties:
|
||||
configRef:
|
||||
description: ConfigRef is a reference to a bootstrap provider-specific
|
||||
resource that holds configuration details. The reference
|
||||
is optional to allow users/operators to specify Bootstrap.Data
|
||||
without the need of a controller.
|
||||
properties:
|
||||
apiVersion:
|
||||
description: API version of the referent.
|
||||
type: string
|
||||
fieldPath:
|
||||
description: 'If referring to a piece of an object instead
|
||||
of an entire object, this string should contain a
|
||||
valid JSON/Go field access statement, such as desiredState.manifest.containers[2].
|
||||
For example, if the object reference is to a container
|
||||
within a pod, this would take on a value like: "spec.containers{name}"
|
||||
(where "name" refers to the name of the container
|
||||
that triggered the event) or if no container name
|
||||
is specified "spec.containers[2]" (container with
|
||||
index 2 in this pod). This syntax is chosen only to
|
||||
have some well-defined way of referencing a part of
|
||||
an object. TODO: this design is not final and this
|
||||
field is subject to change in the future.'
|
||||
type: string
|
||||
kind:
|
||||
description: 'Kind of the referent. More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#types-kinds'
|
||||
type: string
|
||||
name:
|
||||
description: 'Name of the referent. More info: https://kubernetes.io/docs/concepts/overview/working-with-objects/names/#names'
|
||||
type: string
|
||||
namespace:
|
||||
description: 'Namespace of the referent. More info:
|
||||
https://kubernetes.io/docs/concepts/overview/working-with-objects/namespaces/'
|
||||
type: string
|
||||
resourceVersion:
|
||||
description: 'Specific resourceVersion to which this
|
||||
reference is made, if any. More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#concurrency-control-and-consistency'
|
||||
type: string
|
||||
uid:
|
||||
description: 'UID of the referent. More info: https://kubernetes.io/docs/concepts/overview/working-with-objects/names/#uids'
|
||||
type: string
|
||||
type: object
|
||||
data:
|
||||
description: Data contains the bootstrap data, such as cloud-init
|
||||
details scripts. If nil, the Machine should remain in
|
||||
the Pending state.
|
||||
type: string
|
||||
type: object
|
||||
infrastructureRef:
|
||||
description: InfrastructureRef is a required reference to a
|
||||
custom resource offered by an infrastructure provider.
|
||||
properties:
|
||||
apiVersion:
|
||||
description: API version of the referent.
|
||||
type: string
|
||||
fieldPath:
|
||||
description: 'If referring to a piece of an object instead
|
||||
of an entire object, this string should contain a valid
|
||||
JSON/Go field access statement, such as desiredState.manifest.containers[2].
|
||||
For example, if the object reference is to a container
|
||||
within a pod, this would take on a value like: "spec.containers{name}"
|
||||
(where "name" refers to the name of the container that
|
||||
triggered the event) or if no container name is specified
|
||||
"spec.containers[2]" (container with index 2 in this pod).
|
||||
This syntax is chosen only to have some well-defined way
|
||||
of referencing a part of an object. TODO: this design
|
||||
is not final and this field is subject to change in the
|
||||
future.'
|
||||
type: string
|
||||
kind:
|
||||
description: 'Kind of the referent. More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#types-kinds'
|
||||
type: string
|
||||
name:
|
||||
description: 'Name of the referent. More info: https://kubernetes.io/docs/concepts/overview/working-with-objects/names/#names'
|
||||
type: string
|
||||
namespace:
|
||||
description: 'Namespace of the referent. More info: https://kubernetes.io/docs/concepts/overview/working-with-objects/namespaces/'
|
||||
type: string
|
||||
resourceVersion:
|
||||
description: 'Specific resourceVersion to which this reference
|
||||
is made, if any. More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#concurrency-control-and-consistency'
|
||||
type: string
|
||||
uid:
|
||||
description: 'UID of the referent. More info: https://kubernetes.io/docs/concepts/overview/working-with-objects/names/#uids'
|
||||
type: string
|
||||
type: object
|
||||
metadata:
|
||||
description: 'DEPRECATED: ObjectMeta has no function and isn''t
|
||||
used anywhere.'
|
||||
properties:
|
||||
annotations:
|
||||
additionalProperties:
|
||||
type: string
|
||||
description: 'Annotations is an unstructured key value map
|
||||
stored with a resource that may be set by external tools
|
||||
to store and retrieve arbitrary metadata. They are not
|
||||
queryable and should be preserved when modifying objects.
|
||||
More info: http://kubernetes.io/docs/user-guide/annotations'
|
||||
type: object
|
||||
generateName:
|
||||
description: "GenerateName is an optional prefix, used by
|
||||
the server, to generate a unique name ONLY IF the Name
|
||||
field has not been provided. If this field is used, the
|
||||
name returned to the client will be different than the
|
||||
name passed. This value will also be combined with a unique
|
||||
suffix. The provided value has the same validation rules
|
||||
as the Name field, and may be truncated by the length
|
||||
of the suffix required to make the value unique on the
|
||||
server. \n If this field is specified and the generated
|
||||
name exists, the server will NOT return a 409 - instead,
|
||||
it will either return 201 Created or 500 with Reason ServerTimeout
|
||||
indicating a unique name could not be found in the time
|
||||
allotted, and the client should retry (optionally after
|
||||
the time indicated in the Retry-After header). \n Applied
|
||||
only if Name is not specified. More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#idempotency"
|
||||
type: string
|
||||
labels:
|
||||
additionalProperties:
|
||||
type: string
|
||||
description: 'Map of string keys and values that can be
|
||||
used to organize and categorize (scope and select) objects.
|
||||
May match selectors of replication controllers and services.
|
||||
More info: http://kubernetes.io/docs/user-guide/labels'
|
||||
type: object
|
||||
name:
|
||||
description: 'Name must be unique within a namespace. Is
|
||||
required when creating resources, although some resources
|
||||
may allow a client to request the generation of an appropriate
|
||||
name automatically. Name is primarily intended for creation
|
||||
idempotence and configuration definition. Cannot be updated.
|
||||
More info: http://kubernetes.io/docs/user-guide/identifiers#names'
|
||||
type: string
|
||||
namespace:
|
||||
description: "Namespace defines the space within each name
|
||||
must be unique. An empty namespace is equivalent to the
|
||||
\"default\" namespace, but \"default\" is the canonical
|
||||
representation. Not all objects are required to be scoped
|
||||
to a namespace - the value of this field for those objects
|
||||
will be empty. \n Must be a DNS_LABEL. Cannot be updated.
|
||||
More info: http://kubernetes.io/docs/user-guide/namespaces"
|
||||
type: string
|
||||
ownerReferences:
|
||||
description: List of objects depended by this object. If
|
||||
ALL objects in the list have been deleted, this object
|
||||
will be garbage collected. If this object is managed by
|
||||
a controller, then an entry in this list will point to
|
||||
this controller, with the controller field set to true.
|
||||
There cannot be more than one managing controller.
|
||||
items:
|
||||
description: OwnerReference contains enough information
|
||||
to let you identify an owning object. An owning object
|
||||
must be in the same namespace as the dependent, or be
|
||||
cluster-scoped, so there is no namespace field.
|
||||
properties:
|
||||
apiVersion:
|
||||
description: API version of the referent.
|
||||
type: string
|
||||
blockOwnerDeletion:
|
||||
description: If true, AND if the owner has the "foregroundDeletion"
|
||||
finalizer, then the owner cannot be deleted from
|
||||
the key-value store until this reference is removed.
|
||||
Defaults to false. To set this field, a user needs
|
||||
"delete" permission of the owner, otherwise 422
|
||||
(Unprocessable Entity) will be returned.
|
||||
type: boolean
|
||||
controller:
|
||||
description: If true, this reference points to the
|
||||
managing controller.
|
||||
type: boolean
|
||||
kind:
|
||||
description: 'Kind of the referent. More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#types-kinds'
|
||||
type: string
|
||||
name:
|
||||
description: 'Name of the referent. More info: http://kubernetes.io/docs/user-guide/identifiers#names'
|
||||
type: string
|
||||
uid:
|
||||
description: 'UID of the referent. More info: http://kubernetes.io/docs/user-guide/identifiers#uids'
|
||||
type: string
|
||||
required:
|
||||
- apiVersion
|
||||
- kind
|
||||
- name
|
||||
- uid
|
||||
type: object
|
||||
type: array
|
||||
type: object
|
||||
providerID:
|
||||
description: ProviderID is the identification ID of the machine
|
||||
provided by the provider. This field must match the provider
|
||||
ID as seen on the node object corresponding to this machine.
|
||||
This field is required by higher level consumers of cluster-api.
|
||||
Example use case is cluster autoscaler with cluster-api as
|
||||
provider. Clean-up logic in the autoscaler compares machines
|
||||
to nodes to find out machines at provider which could not
|
||||
get registered as Kubernetes nodes. With cluster-api as a
|
||||
generic out-of-tree provider for autoscaler, this field is
|
||||
required by autoscaler to be able to have a provider view
|
||||
of the list of machines. Another list of nodes is queried
|
||||
from the k8s apiserver and then a comparison is done to find
|
||||
out unregistered machines and are marked for delete. This
|
||||
field will be set by the actuators and consumed by higher
|
||||
level entities like autoscaler that will be interfacing with
|
||||
cluster-api as generic provider.
|
||||
type: string
|
||||
version:
|
||||
description: Version defines the desired Kubernetes version.
|
||||
This field is meant to be optionally used by bootstrap providers.
|
||||
type: string
|
||||
required:
|
||||
- bootstrap
|
||||
- infrastructureRef
|
||||
type: object
|
||||
type: object
|
||||
required:
|
||||
- selector
|
||||
- template
|
||||
type: object
|
||||
status:
|
||||
description: MachineDeploymentStatus defines the observed state of MachineDeployment
|
||||
properties:
|
||||
availableReplicas:
|
||||
description: Total number of available machines (ready for at least
|
||||
minReadySeconds) targeted by this deployment.
|
||||
format: int32
|
||||
type: integer
|
||||
observedGeneration:
|
||||
description: The generation observed by the deployment controller.
|
||||
format: int64
|
||||
type: integer
|
||||
readyReplicas:
|
||||
description: Total number of ready machines targeted by this deployment.
|
||||
format: int32
|
||||
type: integer
|
||||
replicas:
|
||||
description: Total number of non-terminated machines targeted by this
|
||||
deployment (their labels match the selector).
|
||||
format: int32
|
||||
type: integer
|
||||
selector:
|
||||
description: 'Selector is the same as the label selector but in the
|
||||
string format to avoid introspection by clients. The string will be
|
||||
in the same format as the query-param syntax. More info about label
|
||||
selectors: http://kubernetes.io/docs/user-guide/labels#label-selectors'
|
||||
type: string
|
||||
unavailableReplicas:
|
||||
description: Total number of unavailable machines targeted by this deployment.
|
||||
This is the total number of machines that are still required for the
|
||||
deployment to have 100% available capacity. They may either be machines
|
||||
that are running but not yet available or machines that still have
|
||||
not been created.
|
||||
format: int32
|
||||
type: integer
|
||||
updatedReplicas:
|
||||
description: Total number of non-terminated machines targeted by this
|
||||
deployment that have the desired template spec.
|
||||
format: int32
|
||||
type: integer
|
||||
type: object
|
||||
type: object
|
||||
version: v1alpha2
|
||||
versions:
|
||||
- name: v1alpha2
|
||||
served: true
|
||||
storage: true
|
||||
status:
|
||||
acceptedNames:
|
||||
kind: ""
|
||||
plural: ""
|
||||
conditions: []
|
||||
storedVersions: []
|
378
manifests/global/crd/cluster-api/machines.cluster.x-k8s.io.yaml
Normal file
378
manifests/global/crd/cluster-api/machines.cluster.x-k8s.io.yaml
Normal file
@ -0,0 +1,378 @@
|
||||
---
|
||||
apiVersion: apiextensions.k8s.io/v1beta1
|
||||
kind: CustomResourceDefinition
|
||||
metadata:
|
||||
creationTimestamp: null
|
||||
name: machines.cluster.x-k8s.io
|
||||
spec:
|
||||
additionalPrinterColumns:
|
||||
- JSONPath: .spec.providerID
|
||||
description: Provider ID
|
||||
name: ProviderID
|
||||
type: string
|
||||
- JSONPath: .status.phase
|
||||
description: Machine status such as Terminating/Pending/Running/Failed etc
|
||||
name: Phase
|
||||
type: string
|
||||
- JSONPath: .status.nodeRef.name
|
||||
description: Node name associated with this machine
|
||||
name: NodeName
|
||||
priority: 1
|
||||
type: string
|
||||
group: cluster.x-k8s.io
|
||||
names:
|
||||
categories:
|
||||
- cluster-api
|
||||
kind: Machine
|
||||
listKind: MachineList
|
||||
plural: machines
|
||||
shortNames:
|
||||
- ma
|
||||
singular: machine
|
||||
scope: Namespaced
|
||||
subresources:
|
||||
status: {}
|
||||
validation:
|
||||
openAPIV3Schema:
|
||||
description: Machine is the Schema for the machines API
|
||||
properties:
|
||||
apiVersion:
|
||||
description: 'APIVersion defines the versioned schema of this representation
|
||||
of an object. Servers should convert recognized schemas to the latest
|
||||
internal value, and may reject unrecognized values. More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#resources'
|
||||
type: string
|
||||
kind:
|
||||
description: 'Kind is a string value representing the REST resource this
|
||||
object represents. Servers may infer this from the endpoint the client
|
||||
submits requests to. Cannot be updated. In CamelCase. More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#types-kinds'
|
||||
type: string
|
||||
metadata:
|
||||
type: object
|
||||
spec:
|
||||
description: MachineSpec defines the desired state of Machine
|
||||
properties:
|
||||
bootstrap:
|
||||
description: Bootstrap is a reference to a local struct which encapsulates
|
||||
fields to configure the Machine’s bootstrapping mechanism.
|
||||
properties:
|
||||
configRef:
|
||||
description: ConfigRef is a reference to a bootstrap provider-specific
|
||||
resource that holds configuration details. The reference is optional
|
||||
to allow users/operators to specify Bootstrap.Data without the
|
||||
need of a controller.
|
||||
properties:
|
||||
apiVersion:
|
||||
description: API version of the referent.
|
||||
type: string
|
||||
fieldPath:
|
||||
description: 'If referring to a piece of an object instead of
|
||||
an entire object, this string should contain a valid JSON/Go
|
||||
field access statement, such as desiredState.manifest.containers[2].
|
||||
For example, if the object reference is to a container within
|
||||
a pod, this would take on a value like: "spec.containers{name}"
|
||||
(where "name" refers to the name of the container that triggered
|
||||
the event) or if no container name is specified "spec.containers[2]"
|
||||
(container with index 2 in this pod). This syntax is chosen
|
||||
only to have some well-defined way of referencing a part of
|
||||
an object. TODO: this design is not final and this field is
|
||||
subject to change in the future.'
|
||||
type: string
|
||||
kind:
|
||||
description: 'Kind of the referent. More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#types-kinds'
|
||||
type: string
|
||||
name:
|
||||
description: 'Name of the referent. More info: https://kubernetes.io/docs/concepts/overview/working-with-objects/names/#names'
|
||||
type: string
|
||||
namespace:
|
||||
description: 'Namespace of the referent. More info: https://kubernetes.io/docs/concepts/overview/working-with-objects/namespaces/'
|
||||
type: string
|
||||
resourceVersion:
|
||||
description: 'Specific resourceVersion to which this reference
|
||||
is made, if any. More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#concurrency-control-and-consistency'
|
||||
type: string
|
||||
uid:
|
||||
description: 'UID of the referent. More info: https://kubernetes.io/docs/concepts/overview/working-with-objects/names/#uids'
|
||||
type: string
|
||||
type: object
|
||||
data:
|
||||
description: Data contains the bootstrap data, such as cloud-init
|
||||
details scripts. If nil, the Machine should remain in the Pending
|
||||
state.
|
||||
type: string
|
||||
type: object
|
||||
infrastructureRef:
|
||||
description: InfrastructureRef is a required reference to a custom resource
|
||||
offered by an infrastructure provider.
|
||||
properties:
|
||||
apiVersion:
|
||||
description: API version of the referent.
|
||||
type: string
|
||||
fieldPath:
|
||||
description: 'If referring to a piece of an object instead of an
|
||||
entire object, this string should contain a valid JSON/Go field
|
||||
access statement, such as desiredState.manifest.containers[2].
|
||||
For example, if the object reference is to a container within
|
||||
a pod, this would take on a value like: "spec.containers{name}"
|
||||
(where "name" refers to the name of the container that triggered
|
||||
the event) or if no container name is specified "spec.containers[2]"
|
||||
(container with index 2 in this pod). This syntax is chosen only
|
||||
to have some well-defined way of referencing a part of an object.
|
||||
TODO: this design is not final and this field is subject to change
|
||||
in the future.'
|
||||
type: string
|
||||
kind:
|
||||
description: 'Kind of the referent. More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#types-kinds'
|
||||
type: string
|
||||
name:
|
||||
description: 'Name of the referent. More info: https://kubernetes.io/docs/concepts/overview/working-with-objects/names/#names'
|
||||
type: string
|
||||
namespace:
|
||||
description: 'Namespace of the referent. More info: https://kubernetes.io/docs/concepts/overview/working-with-objects/namespaces/'
|
||||
type: string
|
||||
resourceVersion:
|
||||
description: 'Specific resourceVersion to which this reference is
|
||||
made, if any. More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#concurrency-control-and-consistency'
|
||||
type: string
|
||||
uid:
|
||||
description: 'UID of the referent. More info: https://kubernetes.io/docs/concepts/overview/working-with-objects/names/#uids'
|
||||
type: string
|
||||
type: object
|
||||
metadata:
|
||||
description: 'DEPRECATED: ObjectMeta has no function and isn''t used
|
||||
anywhere.'
|
||||
properties:
|
||||
annotations:
|
||||
additionalProperties:
|
||||
type: string
|
||||
description: 'Annotations is an unstructured key value map stored
|
||||
with a resource that may be set by external tools to store and
|
||||
retrieve arbitrary metadata. They are not queryable and should
|
||||
be preserved when modifying objects. More info: http://kubernetes.io/docs/user-guide/annotations'
|
||||
type: object
|
||||
generateName:
|
||||
description: "GenerateName is an optional prefix, used by the server,
|
||||
to generate a unique name ONLY IF the Name field has not been
|
||||
provided. If this field is used, the name returned to the client
|
||||
will be different than the name passed. This value will also be
|
||||
combined with a unique suffix. The provided value has the same
|
||||
validation rules as the Name field, and may be truncated by the
|
||||
length of the suffix required to make the value unique on the
|
||||
server. \n If this field is specified and the generated name exists,
|
||||
the server will NOT return a 409 - instead, it will either return
|
||||
201 Created or 500 with Reason ServerTimeout indicating a unique
|
||||
name could not be found in the time allotted, and the client should
|
||||
retry (optionally after the time indicated in the Retry-After
|
||||
header). \n Applied only if Name is not specified. More info:
|
||||
https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#idempotency"
|
||||
type: string
|
||||
labels:
|
||||
additionalProperties:
|
||||
type: string
|
||||
description: 'Map of string keys and values that can be used to
|
||||
organize and categorize (scope and select) objects. May match
|
||||
selectors of replication controllers and services. More info:
|
||||
http://kubernetes.io/docs/user-guide/labels'
|
||||
type: object
|
||||
name:
|
||||
description: 'Name must be unique within a namespace. Is required
|
||||
when creating resources, although some resources may allow a client
|
||||
to request the generation of an appropriate name automatically.
|
||||
Name is primarily intended for creation idempotence and configuration
|
||||
definition. Cannot be updated. More info: http://kubernetes.io/docs/user-guide/identifiers#names'
|
||||
type: string
|
||||
namespace:
|
||||
description: "Namespace defines the space within each name must
|
||||
be unique. An empty namespace is equivalent to the \"default\"
|
||||
namespace, but \"default\" is the canonical representation. Not
|
||||
all objects are required to be scoped to a namespace - the value
|
||||
of this field for those objects will be empty. \n Must be a DNS_LABEL.
|
||||
Cannot be updated. More info: http://kubernetes.io/docs/user-guide/namespaces"
|
||||
type: string
|
||||
ownerReferences:
|
||||
description: List of objects depended by this object. If ALL objects
|
||||
in the list have been deleted, this object will be garbage collected.
|
||||
If this object is managed by a controller, then an entry in this
|
||||
list will point to this controller, with the controller field
|
||||
set to true. There cannot be more than one managing controller.
|
||||
items:
|
||||
description: OwnerReference contains enough information to let
|
||||
you identify an owning object. An owning object must be in the
|
||||
same namespace as the dependent, or be cluster-scoped, so there
|
||||
is no namespace field.
|
||||
properties:
|
||||
apiVersion:
|
||||
description: API version of the referent.
|
||||
type: string
|
||||
blockOwnerDeletion:
|
||||
description: If true, AND if the owner has the "foregroundDeletion"
|
||||
finalizer, then the owner cannot be deleted from the key-value
|
||||
store until this reference is removed. Defaults to false.
|
||||
To set this field, a user needs "delete" permission of the
|
||||
owner, otherwise 422 (Unprocessable Entity) will be returned.
|
||||
type: boolean
|
||||
controller:
|
||||
description: If true, this reference points to the managing
|
||||
controller.
|
||||
type: boolean
|
||||
kind:
|
||||
description: 'Kind of the referent. More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#types-kinds'
|
||||
type: string
|
||||
name:
|
||||
description: 'Name of the referent. More info: http://kubernetes.io/docs/user-guide/identifiers#names'
|
||||
type: string
|
||||
uid:
|
||||
description: 'UID of the referent. More info: http://kubernetes.io/docs/user-guide/identifiers#uids'
|
||||
type: string
|
||||
required:
|
||||
- apiVersion
|
||||
- kind
|
||||
- name
|
||||
- uid
|
||||
type: object
|
||||
type: array
|
||||
type: object
|
||||
providerID:
|
||||
description: ProviderID is the identification ID of the machine provided
|
||||
by the provider. This field must match the provider ID as seen on
|
||||
the node object corresponding to this machine. This field is required
|
||||
by higher level consumers of cluster-api. Example use case is cluster
|
||||
autoscaler with cluster-api as provider. Clean-up logic in the autoscaler
|
||||
compares machines to nodes to find out machines at provider which
|
||||
could not get registered as Kubernetes nodes. With cluster-api as
|
||||
a generic out-of-tree provider for autoscaler, this field is required
|
||||
by autoscaler to be able to have a provider view of the list of machines.
|
||||
Another list of nodes is queried from the k8s apiserver and then a
|
||||
comparison is done to find out unregistered machines and are marked
|
||||
for delete. This field will be set by the actuators and consumed by
|
||||
higher level entities like autoscaler that will be interfacing with
|
||||
cluster-api as generic provider.
|
||||
type: string
|
||||
version:
|
||||
description: Version defines the desired Kubernetes version. This field
|
||||
is meant to be optionally used by bootstrap providers.
|
||||
type: string
|
||||
required:
|
||||
- bootstrap
|
||||
- infrastructureRef
|
||||
type: object
|
||||
status:
|
||||
description: MachineStatus defines the observed state of Machine
|
||||
properties:
|
||||
addresses:
|
||||
description: Addresses is a list of addresses assigned to the machine.
|
||||
This field is copied from the infrastructure provider reference.
|
||||
items:
|
||||
description: MachineAddress contains information for the node's address.
|
||||
properties:
|
||||
address:
|
||||
description: The machine address.
|
||||
type: string
|
||||
type:
|
||||
description: Machine address type, one of Hostname, ExternalIP
|
||||
or InternalIP.
|
||||
type: string
|
||||
required:
|
||||
- address
|
||||
- type
|
||||
type: object
|
||||
type: array
|
||||
bootstrapReady:
|
||||
description: BootstrapReady is the state of the bootstrap provider.
|
||||
type: boolean
|
||||
errorMessage:
|
||||
description: "ErrorMessage will be set in the event that there is a
|
||||
terminal problem reconciling the Machine and will contain a more verbose
|
||||
string suitable for logging and human consumption. \n This field should
|
||||
not be set for transitive errors that a controller faces that are
|
||||
expected to be fixed automatically over time (like service outages),
|
||||
but instead indicate that something is fundamentally wrong with the
|
||||
Machine's spec or the configuration of the controller, and that manual
|
||||
intervention is required. Examples of terminal errors would be invalid
|
||||
combinations of settings in the spec, values that are unsupported
|
||||
by the controller, or the responsible controller itself being critically
|
||||
misconfigured. \n Any transient errors that occur during the reconciliation
|
||||
of Machines can be added as events to the Machine object and/or logged
|
||||
in the controller's output."
|
||||
type: string
|
||||
errorReason:
|
||||
description: "ErrorReason will be set in the event that there is a terminal
|
||||
problem reconciling the Machine and will contain a succinct value
|
||||
suitable for machine interpretation. \n This field should not be set
|
||||
for transitive errors that a controller faces that are expected to
|
||||
be fixed automatically over time (like service outages), but instead
|
||||
indicate that something is fundamentally wrong with the Machine's
|
||||
spec or the configuration of the controller, and that manual intervention
|
||||
is required. Examples of terminal errors would be invalid combinations
|
||||
of settings in the spec, values that are unsupported by the controller,
|
||||
or the responsible controller itself being critically misconfigured.
|
||||
\n Any transient errors that occur during the reconciliation of Machines
|
||||
can be added as events to the Machine object and/or logged in the
|
||||
controller's output."
|
||||
type: string
|
||||
infrastructureReady:
|
||||
description: InfrastructureReady is the state of the infrastructure
|
||||
provider.
|
||||
type: boolean
|
||||
lastUpdated:
|
||||
description: LastUpdated identifies when this status was last observed.
|
||||
format: date-time
|
||||
type: string
|
||||
nodeRef:
|
||||
description: NodeRef will point to the corresponding Node if it exists.
|
||||
properties:
|
||||
apiVersion:
|
||||
description: API version of the referent.
|
||||
type: string
|
||||
fieldPath:
|
||||
description: 'If referring to a piece of an object instead of an
|
||||
entire object, this string should contain a valid JSON/Go field
|
||||
access statement, such as desiredState.manifest.containers[2].
|
||||
For example, if the object reference is to a container within
|
||||
a pod, this would take on a value like: "spec.containers{name}"
|
||||
(where "name" refers to the name of the container that triggered
|
||||
the event) or if no container name is specified "spec.containers[2]"
|
||||
(container with index 2 in this pod). This syntax is chosen only
|
||||
to have some well-defined way of referencing a part of an object.
|
||||
TODO: this design is not final and this field is subject to change
|
||||
in the future.'
|
||||
type: string
|
||||
kind:
|
||||
description: 'Kind of the referent. More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#types-kinds'
|
||||
type: string
|
||||
name:
|
||||
description: 'Name of the referent. More info: https://kubernetes.io/docs/concepts/overview/working-with-objects/names/#names'
|
||||
type: string
|
||||
namespace:
|
||||
description: 'Namespace of the referent. More info: https://kubernetes.io/docs/concepts/overview/working-with-objects/namespaces/'
|
||||
type: string
|
||||
resourceVersion:
|
||||
description: 'Specific resourceVersion to which this reference is
|
||||
made, if any. More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#concurrency-control-and-consistency'
|
||||
type: string
|
||||
uid:
|
||||
description: 'UID of the referent. More info: https://kubernetes.io/docs/concepts/overview/working-with-objects/names/#uids'
|
||||
type: string
|
||||
type: object
|
||||
phase:
|
||||
description: Phase represents the current phase of machine actuation.
|
||||
E.g. Pending, Running, Terminating, Failed etc.
|
||||
type: string
|
||||
version:
|
||||
description: Version specifies the current version of Kubernetes running
|
||||
on the corresponding Node. This is meant to be a means of bubbling
|
||||
up status from the Node to the Machine. It is entirely optional, but
|
||||
useful for end-user UX if it’s present.
|
||||
type: string
|
||||
type: object
|
||||
type: object
|
||||
version: v1alpha2
|
||||
versions:
|
||||
- name: v1alpha2
|
||||
served: true
|
||||
storage: true
|
||||
status:
|
||||
acceptedNames:
|
||||
kind: ""
|
||||
plural: ""
|
||||
conditions: []
|
||||
storedVersions: []
|
@ -0,0 +1,502 @@
|
||||
---
|
||||
apiVersion: apiextensions.k8s.io/v1beta1
|
||||
kind: CustomResourceDefinition
|
||||
metadata:
|
||||
creationTimestamp: null
|
||||
name: machinesets.cluster.x-k8s.io
|
||||
spec:
|
||||
group: cluster.x-k8s.io
|
||||
names:
|
||||
categories:
|
||||
- cluster-api
|
||||
kind: MachineSet
|
||||
listKind: MachineSetList
|
||||
plural: machinesets
|
||||
shortNames:
|
||||
- ms
|
||||
singular: machineset
|
||||
scope: Namespaced
|
||||
subresources:
|
||||
scale:
|
||||
labelSelectorPath: .status.selector
|
||||
specReplicasPath: .spec.replicas
|
||||
statusReplicasPath: .status.replicas
|
||||
status: {}
|
||||
validation:
|
||||
openAPIV3Schema:
|
||||
description: MachineSet is the Schema for the machinesets API
|
||||
properties:
|
||||
apiVersion:
|
||||
description: 'APIVersion defines the versioned schema of this representation
|
||||
of an object. Servers should convert recognized schemas to the latest
|
||||
internal value, and may reject unrecognized values. More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#resources'
|
||||
type: string
|
||||
kind:
|
||||
description: 'Kind is a string value representing the REST resource this
|
||||
object represents. Servers may infer this from the endpoint the client
|
||||
submits requests to. Cannot be updated. In CamelCase. More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#types-kinds'
|
||||
type: string
|
||||
metadata:
|
||||
type: object
|
||||
spec:
|
||||
description: MachineSetSpec defines the desired state of MachineSet
|
||||
properties:
|
||||
deletePolicy:
|
||||
description: DeletePolicy defines the policy used to identify nodes
|
||||
to delete when downscaling. Defaults to "Random". Valid values are
|
||||
"Random, "Newest", "Oldest"
|
||||
enum:
|
||||
- Random
|
||||
- Newest
|
||||
- Oldest
|
||||
type: string
|
||||
minReadySeconds:
|
||||
description: MinReadySeconds is the minimum number of seconds for which
|
||||
a newly created machine should be ready. Defaults to 0 (machine will
|
||||
be considered available as soon as it is ready)
|
||||
format: int32
|
||||
type: integer
|
||||
replicas:
|
||||
description: Replicas is the number of desired replicas. This is a pointer
|
||||
to distinguish between explicit zero and unspecified. Defaults to
|
||||
1.
|
||||
format: int32
|
||||
type: integer
|
||||
selector:
|
||||
description: 'Selector is a label query over machines that should match
|
||||
the replica count. Label keys and values that must match in order
|
||||
to be controlled by this MachineSet. It must match the machine template''s
|
||||
labels. More info: https://kubernetes.io/docs/concepts/overview/working-with-objects/labels/#label-selectors'
|
||||
properties:
|
||||
matchExpressions:
|
||||
description: matchExpressions is a list of label selector requirements.
|
||||
The requirements are ANDed.
|
||||
items:
|
||||
description: A label selector requirement is a selector that contains
|
||||
values, a key, and an operator that relates the key and values.
|
||||
properties:
|
||||
key:
|
||||
description: key is the label key that the selector applies
|
||||
to.
|
||||
type: string
|
||||
operator:
|
||||
description: operator represents a key's relationship to a
|
||||
set of values. Valid operators are In, NotIn, Exists and
|
||||
DoesNotExist.
|
||||
type: string
|
||||
values:
|
||||
description: values is an array of string values. If the operator
|
||||
is In or NotIn, the values array must be non-empty. If the
|
||||
operator is Exists or DoesNotExist, the values array must
|
||||
be empty. This array is replaced during a strategic merge
|
||||
patch.
|
||||
items:
|
||||
type: string
|
||||
type: array
|
||||
required:
|
||||
- key
|
||||
- operator
|
||||
type: object
|
||||
type: array
|
||||
matchLabels:
|
||||
additionalProperties:
|
||||
type: string
|
||||
description: matchLabels is a map of {key,value} pairs. A single
|
||||
{key,value} in the matchLabels map is equivalent to an element
|
||||
of matchExpressions, whose key field is "key", the operator is
|
||||
"In", and the values array contains only "value". The requirements
|
||||
are ANDed.
|
||||
type: object
|
||||
type: object
|
||||
template:
|
||||
description: Template is the object that describes the machine that
|
||||
will be created if insufficient replicas are detected. Object references
|
||||
to custom resources resources are treated as templates.
|
||||
properties:
|
||||
metadata:
|
||||
description: 'Standard object''s metadata. More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#metadata'
|
||||
properties:
|
||||
annotations:
|
||||
additionalProperties:
|
||||
type: string
|
||||
description: 'Annotations is an unstructured key value map stored
|
||||
with a resource that may be set by external tools to store
|
||||
and retrieve arbitrary metadata. They are not queryable and
|
||||
should be preserved when modifying objects. More info: http://kubernetes.io/docs/user-guide/annotations'
|
||||
type: object
|
||||
generateName:
|
||||
description: "GenerateName is an optional prefix, used by the
|
||||
server, to generate a unique name ONLY IF the Name field has
|
||||
not been provided. If this field is used, the name returned
|
||||
to the client will be different than the name passed. This
|
||||
value will also be combined with a unique suffix. The provided
|
||||
value has the same validation rules as the Name field, and
|
||||
may be truncated by the length of the suffix required to make
|
||||
the value unique on the server. \n If this field is specified
|
||||
and the generated name exists, the server will NOT return
|
||||
a 409 - instead, it will either return 201 Created or 500
|
||||
with Reason ServerTimeout indicating a unique name could not
|
||||
be found in the time allotted, and the client should retry
|
||||
(optionally after the time indicated in the Retry-After header).
|
||||
\n Applied only if Name is not specified. More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#idempotency"
|
||||
type: string
|
||||
labels:
|
||||
additionalProperties:
|
||||
type: string
|
||||
description: 'Map of string keys and values that can be used
|
||||
to organize and categorize (scope and select) objects. May
|
||||
match selectors of replication controllers and services. More
|
||||
info: http://kubernetes.io/docs/user-guide/labels'
|
||||
type: object
|
||||
name:
|
||||
description: 'Name must be unique within a namespace. Is required
|
||||
when creating resources, although some resources may allow
|
||||
a client to request the generation of an appropriate name
|
||||
automatically. Name is primarily intended for creation idempotence
|
||||
and configuration definition. Cannot be updated. More info:
|
||||
http://kubernetes.io/docs/user-guide/identifiers#names'
|
||||
type: string
|
||||
namespace:
|
||||
description: "Namespace defines the space within each name must
|
||||
be unique. An empty namespace is equivalent to the \"default\"
|
||||
namespace, but \"default\" is the canonical representation.
|
||||
Not all objects are required to be scoped to a namespace -
|
||||
the value of this field for those objects will be empty. \n
|
||||
Must be a DNS_LABEL. Cannot be updated. More info: http://kubernetes.io/docs/user-guide/namespaces"
|
||||
type: string
|
||||
ownerReferences:
|
||||
description: List of objects depended by this object. If ALL
|
||||
objects in the list have been deleted, this object will be
|
||||
garbage collected. If this object is managed by a controller,
|
||||
then an entry in this list will point to this controller,
|
||||
with the controller field set to true. There cannot be more
|
||||
than one managing controller.
|
||||
items:
|
||||
description: OwnerReference contains enough information to
|
||||
let you identify an owning object. An owning object must
|
||||
be in the same namespace as the dependent, or be cluster-scoped,
|
||||
so there is no namespace field.
|
||||
properties:
|
||||
apiVersion:
|
||||
description: API version of the referent.
|
||||
type: string
|
||||
blockOwnerDeletion:
|
||||
description: If true, AND if the owner has the "foregroundDeletion"
|
||||
finalizer, then the owner cannot be deleted from the
|
||||
key-value store until this reference is removed. Defaults
|
||||
to false. To set this field, a user needs "delete" permission
|
||||
of the owner, otherwise 422 (Unprocessable Entity) will
|
||||
be returned.
|
||||
type: boolean
|
||||
controller:
|
||||
description: If true, this reference points to the managing
|
||||
controller.
|
||||
type: boolean
|
||||
kind:
|
||||
description: 'Kind of the referent. More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#types-kinds'
|
||||
type: string
|
||||
name:
|
||||
description: 'Name of the referent. More info: http://kubernetes.io/docs/user-guide/identifiers#names'
|
||||
type: string
|
||||
uid:
|
||||
description: 'UID of the referent. More info: http://kubernetes.io/docs/user-guide/identifiers#uids'
|
||||
type: string
|
||||
required:
|
||||
- apiVersion
|
||||
- kind
|
||||
- name
|
||||
- uid
|
||||
type: object
|
||||
type: array
|
||||
type: object
|
||||
spec:
|
||||
description: 'Specification of the desired behavior of the machine.
|
||||
More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#spec-and-status'
|
||||
properties:
|
||||
bootstrap:
|
||||
description: Bootstrap is a reference to a local struct which
|
||||
encapsulates fields to configure the Machine’s bootstrapping
|
||||
mechanism.
|
||||
properties:
|
||||
configRef:
|
||||
description: ConfigRef is a reference to a bootstrap provider-specific
|
||||
resource that holds configuration details. The reference
|
||||
is optional to allow users/operators to specify Bootstrap.Data
|
||||
without the need of a controller.
|
||||
properties:
|
||||
apiVersion:
|
||||
description: API version of the referent.
|
||||
type: string
|
||||
fieldPath:
|
||||
description: 'If referring to a piece of an object instead
|
||||
of an entire object, this string should contain a
|
||||
valid JSON/Go field access statement, such as desiredState.manifest.containers[2].
|
||||
For example, if the object reference is to a container
|
||||
within a pod, this would take on a value like: "spec.containers{name}"
|
||||
(where "name" refers to the name of the container
|
||||
that triggered the event) or if no container name
|
||||
is specified "spec.containers[2]" (container with
|
||||
index 2 in this pod). This syntax is chosen only to
|
||||
have some well-defined way of referencing a part of
|
||||
an object. TODO: this design is not final and this
|
||||
field is subject to change in the future.'
|
||||
type: string
|
||||
kind:
|
||||
description: 'Kind of the referent. More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#types-kinds'
|
||||
type: string
|
||||
name:
|
||||
description: 'Name of the referent. More info: https://kubernetes.io/docs/concepts/overview/working-with-objects/names/#names'
|
||||
type: string
|
||||
namespace:
|
||||
description: 'Namespace of the referent. More info:
|
||||
https://kubernetes.io/docs/concepts/overview/working-with-objects/namespaces/'
|
||||
type: string
|
||||
resourceVersion:
|
||||
description: 'Specific resourceVersion to which this
|
||||
reference is made, if any. More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#concurrency-control-and-consistency'
|
||||
type: string
|
||||
uid:
|
||||
description: 'UID of the referent. More info: https://kubernetes.io/docs/concepts/overview/working-with-objects/names/#uids'
|
||||
type: string
|
||||
type: object
|
||||
data:
|
||||
description: Data contains the bootstrap data, such as cloud-init
|
||||
details scripts. If nil, the Machine should remain in
|
||||
the Pending state.
|
||||
type: string
|
||||
type: object
|
||||
infrastructureRef:
|
||||
description: InfrastructureRef is a required reference to a
|
||||
custom resource offered by an infrastructure provider.
|
||||
properties:
|
||||
apiVersion:
|
||||
description: API version of the referent.
|
||||
type: string
|
||||
fieldPath:
|
||||
description: 'If referring to a piece of an object instead
|
||||
of an entire object, this string should contain a valid
|
||||
JSON/Go field access statement, such as desiredState.manifest.containers[2].
|
||||
For example, if the object reference is to a container
|
||||
within a pod, this would take on a value like: "spec.containers{name}"
|
||||
(where "name" refers to the name of the container that
|
||||
triggered the event) or if no container name is specified
|
||||
"spec.containers[2]" (container with index 2 in this pod).
|
||||
This syntax is chosen only to have some well-defined way
|
||||
of referencing a part of an object. TODO: this design
|
||||
is not final and this field is subject to change in the
|
||||
future.'
|
||||
type: string
|
||||
kind:
|
||||
description: 'Kind of the referent. More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#types-kinds'
|
||||
type: string
|
||||
name:
|
||||
description: 'Name of the referent. More info: https://kubernetes.io/docs/concepts/overview/working-with-objects/names/#names'
|
||||
type: string
|
||||
namespace:
|
||||
description: 'Namespace of the referent. More info: https://kubernetes.io/docs/concepts/overview/working-with-objects/namespaces/'
|
||||
type: string
|
||||
resourceVersion:
|
||||
description: 'Specific resourceVersion to which this reference
|
||||
is made, if any. More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#concurrency-control-and-consistency'
|
||||
type: string
|
||||
uid:
|
||||
description: 'UID of the referent. More info: https://kubernetes.io/docs/concepts/overview/working-with-objects/names/#uids'
|
||||
type: string
|
||||
type: object
|
||||
metadata:
|
||||
description: 'DEPRECATED: ObjectMeta has no function and isn''t
|
||||
used anywhere.'
|
||||
properties:
|
||||
annotations:
|
||||
additionalProperties:
|
||||
type: string
|
||||
description: 'Annotations is an unstructured key value map
|
||||
stored with a resource that may be set by external tools
|
||||
to store and retrieve arbitrary metadata. They are not
|
||||
queryable and should be preserved when modifying objects.
|
||||
More info: http://kubernetes.io/docs/user-guide/annotations'
|
||||
type: object
|
||||
generateName:
|
||||
description: "GenerateName is an optional prefix, used by
|
||||
the server, to generate a unique name ONLY IF the Name
|
||||
field has not been provided. If this field is used, the
|
||||
name returned to the client will be different than the
|
||||
name passed. This value will also be combined with a unique
|
||||
suffix. The provided value has the same validation rules
|
||||
as the Name field, and may be truncated by the length
|
||||
of the suffix required to make the value unique on the
|
||||
server. \n If this field is specified and the generated
|
||||
name exists, the server will NOT return a 409 - instead,
|
||||
it will either return 201 Created or 500 with Reason ServerTimeout
|
||||
indicating a unique name could not be found in the time
|
||||
allotted, and the client should retry (optionally after
|
||||
the time indicated in the Retry-After header). \n Applied
|
||||
only if Name is not specified. More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#idempotency"
|
||||
type: string
|
||||
labels:
|
||||
additionalProperties:
|
||||
type: string
|
||||
description: 'Map of string keys and values that can be
|
||||
used to organize and categorize (scope and select) objects.
|
||||
May match selectors of replication controllers and services.
|
||||
More info: http://kubernetes.io/docs/user-guide/labels'
|
||||
type: object
|
||||
name:
|
||||
description: 'Name must be unique within a namespace. Is
|
||||
required when creating resources, although some resources
|
||||
may allow a client to request the generation of an appropriate
|
||||
name automatically. Name is primarily intended for creation
|
||||
idempotence and configuration definition. Cannot be updated.
|
||||
More info: http://kubernetes.io/docs/user-guide/identifiers#names'
|
||||
type: string
|
||||
namespace:
|
||||
description: "Namespace defines the space within each name
|
||||
must be unique. An empty namespace is equivalent to the
|
||||
\"default\" namespace, but \"default\" is the canonical
|
||||
representation. Not all objects are required to be scoped
|
||||
to a namespace - the value of this field for those objects
|
||||
will be empty. \n Must be a DNS_LABEL. Cannot be updated.
|
||||
More info: http://kubernetes.io/docs/user-guide/namespaces"
|
||||
type: string
|
||||
ownerReferences:
|
||||
description: List of objects depended by this object. If
|
||||
ALL objects in the list have been deleted, this object
|
||||
will be garbage collected. If this object is managed by
|
||||
a controller, then an entry in this list will point to
|
||||
this controller, with the controller field set to true.
|
||||
There cannot be more than one managing controller.
|
||||
items:
|
||||
description: OwnerReference contains enough information
|
||||
to let you identify an owning object. An owning object
|
||||
must be in the same namespace as the dependent, or be
|
||||
cluster-scoped, so there is no namespace field.
|
||||
properties:
|
||||
apiVersion:
|
||||
description: API version of the referent.
|
||||
type: string
|
||||
blockOwnerDeletion:
|
||||
description: If true, AND if the owner has the "foregroundDeletion"
|
||||
finalizer, then the owner cannot be deleted from
|
||||
the key-value store until this reference is removed.
|
||||
Defaults to false. To set this field, a user needs
|
||||
"delete" permission of the owner, otherwise 422
|
||||
(Unprocessable Entity) will be returned.
|
||||
type: boolean
|
||||
controller:
|
||||
description: If true, this reference points to the
|
||||
managing controller.
|
||||
type: boolean
|
||||
kind:
|
||||
description: 'Kind of the referent. More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#types-kinds'
|
||||
type: string
|
||||
name:
|
||||
description: 'Name of the referent. More info: http://kubernetes.io/docs/user-guide/identifiers#names'
|
||||
type: string
|
||||
uid:
|
||||
description: 'UID of the referent. More info: http://kubernetes.io/docs/user-guide/identifiers#uids'
|
||||
type: string
|
||||
required:
|
||||
- apiVersion
|
||||
- kind
|
||||
- name
|
||||
- uid
|
||||
type: object
|
||||
type: array
|
||||
type: object
|
||||
providerID:
|
||||
description: ProviderID is the identification ID of the machine
|
||||
provided by the provider. This field must match the provider
|
||||
ID as seen on the node object corresponding to this machine.
|
||||
This field is required by higher level consumers of cluster-api.
|
||||
Example use case is cluster autoscaler with cluster-api as
|
||||
provider. Clean-up logic in the autoscaler compares machines
|
||||
to nodes to find out machines at provider which could not
|
||||
get registered as Kubernetes nodes. With cluster-api as a
|
||||
generic out-of-tree provider for autoscaler, this field is
|
||||
required by autoscaler to be able to have a provider view
|
||||
of the list of machines. Another list of nodes is queried
|
||||
from the k8s apiserver and then a comparison is done to find
|
||||
out unregistered machines and are marked for delete. This
|
||||
field will be set by the actuators and consumed by higher
|
||||
level entities like autoscaler that will be interfacing with
|
||||
cluster-api as generic provider.
|
||||
type: string
|
||||
version:
|
||||
description: Version defines the desired Kubernetes version.
|
||||
This field is meant to be optionally used by bootstrap providers.
|
||||
type: string
|
||||
required:
|
||||
- bootstrap
|
||||
- infrastructureRef
|
||||
type: object
|
||||
type: object
|
||||
required:
|
||||
- selector
|
||||
type: object
|
||||
status:
|
||||
description: MachineSetStatus defines the observed state of MachineSet
|
||||
properties:
|
||||
availableReplicas:
|
||||
description: The number of available replicas (ready for at least minReadySeconds)
|
||||
for this MachineSet.
|
||||
format: int32
|
||||
type: integer
|
||||
errorMessage:
|
||||
type: string
|
||||
errorReason:
|
||||
description: "In the event that there is a terminal problem reconciling
|
||||
the replicas, both ErrorReason and ErrorMessage will be set. ErrorReason
|
||||
will be populated with a succinct value suitable for machine interpretation,
|
||||
while ErrorMessage will contain a more verbose string suitable for
|
||||
logging and human consumption. \n These fields should not be set for
|
||||
transitive errors that a controller faces that are expected to be
|
||||
fixed automatically over time (like service outages), but instead
|
||||
indicate that something is fundamentally wrong with the MachineTemplate's
|
||||
spec or the configuration of the machine controller, and that manual
|
||||
intervention is required. Examples of terminal errors would be invalid
|
||||
combinations of settings in the spec, values that are unsupported
|
||||
by the machine controller, or the responsible machine controller itself
|
||||
being critically misconfigured. \n Any transient errors that occur
|
||||
during the reconciliation of Machines can be added as events to the
|
||||
MachineSet object and/or logged in the controller's output."
|
||||
type: string
|
||||
fullyLabeledReplicas:
|
||||
description: The number of replicas that have labels matching the labels
|
||||
of the machine template of the MachineSet.
|
||||
format: int32
|
||||
type: integer
|
||||
observedGeneration:
|
||||
description: ObservedGeneration reflects the generation of the most
|
||||
recently observed MachineSet.
|
||||
format: int64
|
||||
type: integer
|
||||
readyReplicas:
|
||||
description: The number of ready replicas for this MachineSet. A machine
|
||||
is considered ready when the node has been created and is "Ready".
|
||||
format: int32
|
||||
type: integer
|
||||
replicas:
|
||||
description: Replicas is the most recently observed number of replicas.
|
||||
format: int32
|
||||
type: integer
|
||||
selector:
|
||||
description: 'Selector is the same as the label selector but in the
|
||||
string format to avoid introspection by clients. The string will be
|
||||
in the same format as the query-param syntax. More info about label
|
||||
selectors: http://kubernetes.io/docs/user-guide/labels#label-selectors'
|
||||
type: string
|
||||
required:
|
||||
- replicas
|
||||
type: object
|
||||
type: object
|
||||
version: v1alpha2
|
||||
versions:
|
||||
- name: v1alpha2
|
||||
served: true
|
||||
storage: true
|
||||
status:
|
||||
acceptedNames:
|
||||
kind: ""
|
||||
plural: ""
|
||||
conditions: []
|
||||
storedVersions: []
|
Loading…
Reference in New Issue
Block a user