-
Notifications
You must be signed in to change notification settings - Fork 4k
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Merge pull request #7195 from aleksandra-malinowska/prov-req-api-v1-5
ProvisioningRequest v1 client
- Loading branch information
Showing
60 changed files
with
2,218 additions
and
621 deletions.
There are no files selected for viewing
21 changes: 21 additions & 0 deletions
21
cluster-autoscaler/apis/provisioningrequest/autoscaling.x-k8s.io/v1/doc.go
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,21 @@ | ||
/* | ||
Copyright 2023 The Kubernetes Authors. | ||
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. | ||
*/ | ||
|
||
// Package v1 contains definitions of Provisioning Request related objects. | ||
// +k8s:deepcopy-gen=package | ||
// +k8s:defaulter-gen=TypeMeta | ||
// +groupName=autoscaling.x-k8s.io | ||
package v1 |
56 changes: 56 additions & 0 deletions
56
cluster-autoscaler/apis/provisioningrequest/autoscaling.x-k8s.io/v1/register.go
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,56 @@ | ||
/* | ||
Copyright 2023 The Kubernetes Authors. | ||
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. | ||
*/ | ||
|
||
// Package v1 contains definitions of Provisioning Request related objects. | ||
package v1 | ||
|
||
import ( | ||
metav1 "k8s.io/apimachinery/pkg/apis/meta/v1" | ||
"k8s.io/apimachinery/pkg/runtime" | ||
"k8s.io/apimachinery/pkg/runtime/schema" | ||
) | ||
|
||
const ( | ||
// GroupName represents the group name for ProvisioningRequest resources. | ||
GroupName = "autoscaling.x-k8s.io" | ||
// GroupVersion represents the group name for ProvisioningRequest resources. | ||
GroupVersion = "v1" | ||
) | ||
|
||
// SchemeGroupVersion represents the group version object for ProvisioningRequest scheme. | ||
var SchemeGroupVersion = schema.GroupVersion{Group: GroupName, Version: GroupVersion} | ||
|
||
var ( | ||
// SchemeBuilder is the scheme builder for ProvisioningRequest. | ||
SchemeBuilder = runtime.NewSchemeBuilder(addKnownTypes) | ||
// AddToScheme is the func that applies all the stored functions to the scheme. | ||
AddToScheme = SchemeBuilder.AddToScheme | ||
) | ||
|
||
// Resource takes an unqualified resource and returns a Group qualified GroupResource | ||
func Resource(resource string) schema.GroupResource { | ||
return SchemeGroupVersion.WithResource(resource).GroupResource() | ||
} | ||
|
||
func addKnownTypes(scheme *runtime.Scheme) error { | ||
scheme.AddKnownTypes(SchemeGroupVersion, | ||
&ProvisioningRequest{}, | ||
&ProvisioningRequestList{}, | ||
) | ||
|
||
metav1.AddToGroupVersion(scheme, SchemeGroupVersion) | ||
return nil | ||
} |
207 changes: 207 additions & 0 deletions
207
cluster-autoscaler/apis/provisioningrequest/autoscaling.x-k8s.io/v1/types.go
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,207 @@ | ||
/* | ||
Copyright 2023 The Kubernetes Authors. | ||
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. | ||
*/ | ||
|
||
// Package v1 contains definitions of Provisioning Request related objects. | ||
package v1 | ||
|
||
import ( | ||
metav1 "k8s.io/apimachinery/pkg/apis/meta/v1" | ||
|
||
// Dependencies for the generation of the code: | ||
_ "github.com/onsi/ginkgo/v2" | ||
_ "github.com/onsi/gomega" | ||
_ "k8s.io/code-generator" | ||
) | ||
|
||
// +genclient | ||
// +kubebuilder:storageversions | ||
// +kubebuilder:resource:shortName=provreq;provreqs | ||
|
||
// ProvisioningRequest is a way to express additional capacity | ||
// that we would like to provision in the cluster. Cluster Autoscaler | ||
// can use this information in its calculations and signal if the capacity | ||
// is available in the cluster or actively add capacity if needed. | ||
// | ||
// +kubebuilder:subresource:status | ||
// +kubebuilder:printcolumn:name="Age",type="date",JSONPath=".metadata.creationTimestamp" | ||
// +k8s:deepcopy-gen:interfaces=k8s.io/apimachinery/pkg/runtime.Object | ||
type ProvisioningRequest struct { | ||
metav1.TypeMeta `json:",inline"` | ||
// Standard object metadata. More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#metadata | ||
// | ||
// +optional | ||
metav1.ObjectMeta `json:"metadata,omitempty"` | ||
// Spec contains specification of the ProvisioningRequest object. | ||
// More info: https://git.k8s.io/community/contributors/devel/api-conventions.md#spec-and-status. | ||
// The spec is immutable, to make changes to the request users are expected to delete an existing | ||
// and create a new object with the corrected fields. | ||
// | ||
// +kubebuilder:validation:Required | ||
Spec ProvisioningRequestSpec `json:"spec"` | ||
// Status of the ProvisioningRequest. CA constantly reconciles this field. | ||
// | ||
// +optional | ||
Status ProvisioningRequestStatus `json:"status,omitempty"` | ||
} | ||
|
||
// ProvisioningRequestList is a object for list of ProvisioningRequest. | ||
// +k8s:deepcopy-gen:interfaces=k8s.io/apimachinery/pkg/runtime.Object | ||
type ProvisioningRequestList struct { | ||
metav1.TypeMeta `json:",inline"` | ||
// Standard list metadata. | ||
// | ||
// +optional | ||
metav1.ListMeta `json:"metadata"` | ||
// Items, list of ProvisioningRequest returned from API. | ||
// | ||
// +optional | ||
Items []ProvisioningRequest `json:"items"` | ||
} | ||
|
||
// ProvisioningRequestSpec is a specification of additional pods for which we | ||
// would like to provision additional resources in the cluster. | ||
type ProvisioningRequestSpec struct { | ||
// PodSets lists groups of pods for which we would like to provision | ||
// resources. | ||
// | ||
// +kubebuilder:validation:Required | ||
// +kubebuilder:validation:MinItems=1 | ||
// +kubebuilder:validation:MaxItems=32 | ||
// +kubebuilder:validation:XValidation:rule="self == oldSelf",message="Value is immutable" | ||
PodSets []PodSet `json:"podSets"` | ||
|
||
// ProvisioningClassName describes the different modes of provisioning the resources. | ||
// Currently there is no support for 'ProvisioningClass' objects. | ||
// Supported values: | ||
// * check-capacity.kubernetes.io - check if current cluster state can fullfil this request, | ||
// do not reserve the capacity. Users should provide a reference to a valid PodTemplate object. | ||
// CA will check if there is enough capacity in cluster to fulfill the request and put | ||
// the answer in 'CapacityAvailable' condition. | ||
// * atomic-scale-up.kubernetes.io - provision the resources in an atomic manner. | ||
// Users should provide a reference to a valid PodTemplate object. | ||
// CA will try to create the VMs in an atomic manner, clean any partially provisioned VMs | ||
// and re-try the operation in a exponential back-off manner. Users can configure the timeout | ||
// duration after which the request will fail by 'ValidUntilSeconds' key in 'Parameters'. | ||
// CA will set 'Failed=true' or 'Provisioned=true' condition according to the outcome. | ||
// * ... - potential other classes that are specific to the cloud providers. | ||
// 'kubernetes.io' suffix is reserved for the modes defined in Kubernetes projects. | ||
// | ||
// +kubebuilder:validation:Required | ||
// +kubebuilder:validation:XValidation:rule="self == oldSelf",message="Value is immutable" | ||
// +kubebuilder:validation:Pattern=`^[a-z0-9]([-a-z0-9]*[a-z0-9])?(\.[a-z0-9]([-a-z0-9]*[a-z0-9])?)*$` | ||
// +kubebuilder:validation:MaxLength=253 | ||
ProvisioningClassName string `json:"provisioningClassName"` | ||
|
||
// Parameters contains all other parameters classes may require. | ||
// 'atomic-scale-up.kubernetes.io' supports 'ValidUntilSeconds' parameter, which should contain | ||
// a string denoting duration for which we should retry (measured since creation fo the CR). | ||
// | ||
// +optional | ||
// +kubebuilder:validation:XValidation:rule="self == oldSelf",message="Value is immutable" | ||
// +kubebuilder:validation:MaxProperties=100 | ||
Parameters map[string]Parameter `json:"parameters"` | ||
} | ||
|
||
// Parameter is limited to 255 characters. | ||
// +kubebuilder:validation:MaxLength=255 | ||
type Parameter string | ||
|
||
// PodSet represents one group of pods for Provisioning Request to provision capacity. | ||
type PodSet struct { | ||
// PodTemplateRef is a reference to a PodTemplate object that is representing pods | ||
// that will consume this reservation (must be within the same namespace). | ||
// Users need to make sure that the fields relevant to scheduler (e.g. node selector tolerations) | ||
// are consistent between this template and actual pods consuming the Provisioning Request. | ||
// | ||
// +kubebuilder:validation:Required | ||
PodTemplateRef Reference `json:"podTemplateRef"` | ||
// Count contains the number of pods that will be created with a given | ||
// template. | ||
// | ||
// +kubebuilder:validation:Minimum=1 | ||
Count int32 `json:"count"` | ||
} | ||
|
||
// Reference represents reference to an object within the same namespace. | ||
type Reference struct { | ||
// Name of the referenced object. | ||
// More info: https://kubernetes.io/docs/concepts/overview/working-with-objects/names#names | ||
// | ||
// +kubebuilder:validation:Required | ||
// +kubebuilder:validation:Pattern=`^[a-z0-9]([-a-z0-9]*[a-z0-9])?(\.[a-z0-9]([-a-z0-9]*[a-z0-9])?)*$` | ||
// +kubebuilder:validation:MaxLength=253 | ||
Name string `json:"name,omitempty"` | ||
} | ||
|
||
// ProvisioningRequestStatus represents the status of the resource reservation. | ||
type ProvisioningRequestStatus struct { | ||
// Conditions represent the observations of a Provisioning Request's | ||
// current state. Those will contain information whether the capacity | ||
// was found/created or if there were any issues. The condition types | ||
// may differ between different provisioning classes. | ||
// | ||
// +listType=map | ||
// +listMapKey=type | ||
// +patchStrategy=merge | ||
// +patchMergeKey=type | ||
// +optional | ||
Conditions []metav1.Condition `json:"conditions"` | ||
|
||
// ProvisioningClassDetails contains all other values custom provisioning classes may | ||
// want to pass to end users. | ||
// | ||
// +optional | ||
// +kubebuilder:validation:MaxProperties=64 | ||
ProvisioningClassDetails map[string]Detail `json:"provisioningClassDetails"` | ||
} | ||
|
||
// Detail is limited to 32768 characters. | ||
// +kubebuilder:validation:MaxLength=32768 | ||
type Detail string | ||
|
||
// The following constants list all currently available Conditions Type values. | ||
// See: https://pkg.go.dev/k8s.io/apimachinery/pkg/apis/meta/v1#Condition | ||
const ( | ||
// Accepted indicates that the ProvisioningRequest was accepted by ClusterAutoscaler, | ||
// so ClusterAutoscaler will attempt to provision the nodes for it. | ||
Accepted string = "Accepted" | ||
// BookingExpired indicates that the ProvisioningRequest had Provisioned condition before | ||
// and capacity reservation time is expired. | ||
BookingExpired string = "BookingExpired" | ||
// CapacityRevoked indicates that requested resources are not longer valid. | ||
CapacityRevoked string = "CapacityRevoked" | ||
// Provisioned indicates that all of the requested resources were created | ||
// and registered in the cluster. CA will set this condition when the | ||
// VM creation finishes successfully. | ||
Provisioned string = "Provisioned" | ||
// Failed indicates that it is impossible to obtain resources to fulfill | ||
// this ProvisioningRequest. | ||
// Condition Reason and Message will contain more details about what failed. | ||
Failed string = "Failed" | ||
) | ||
|
||
const ( | ||
// ProvisioningClassCheckCapacity denotes that CA will check if current cluster state can fulfill this request, | ||
// and reserve the capacity for a specified time. | ||
ProvisioningClassCheckCapacity string = "check-capacity.autoscaling.x-k8s.io" | ||
// ProvisioningClassBestEffortAtomicScaleUp denotes that CA try to provision the capacity | ||
// in an atomic manner. | ||
ProvisioningClassBestEffortAtomicScaleUp string = "best-effort-atomic-scale-up.autoscaling.x-k8s.io" | ||
// ProvisioningRequestPodAnnotationKey is a key used to annotate pods consuming provisioning request. | ||
ProvisioningRequestPodAnnotationKey = "autoscaling.x-k8s.io/consume-provisioning-request" | ||
// ProvisioningClassPodAnnotationKey is a key used to add annotation about Provisioning Class | ||
ProvisioningClassPodAnnotationKey = "autoscaling.x-k8s.io/provisioning-class-name" | ||
) |
Oops, something went wrong.