Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

initial draft for review before generating code #1015

Open
wants to merge 8 commits into
base: main
Choose a base branch
from

Conversation

LiboYu2
Copy link
Collaborator

@LiboYu2 LiboYu2 commented Jan 2, 2025

I would like to get some feedback before generating code for new those fields.

@@ -18,6 +18,7 @@ limitations under the License.
package v1beta1

import (
v2 "k8s.io/api/autoscaling/v2"
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Suggested change
v2 "k8s.io/api/autoscaling/v2"
autoscalingv2 "k8s.io/api/autoscaling/v2"

// This struct allows customization of autoscaling. A custom metric can be used instead of the memory and cpu metrics.
// The scaling behavior can also be customized to meet different performance requirements. The maximum and mininum of
// sizes of the replica sets can be specified to limit the use of resources.
Custom Custom `json:"custom,omitempty"`
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Must be a pointer.

}

// Custom customizes VerticaAutoscaler
type Custom struct {
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Let's use a better name. Maybe CustomAutoscalerSpec?

Comment on lines 92 to 93
// +kubebuilder:default:=3
// +kubebuilder:Minimum:=3
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Suggested change
// +kubebuilder:default:=3
// +kubebuilder:Minimum:=3
// +kubebuilder:Minimum:=0

Copy link
Collaborator Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

This is from https://cloud.google.com/kubernetes-engine/docs/concepts/horizontalpodautoscaler#limitations
**You can't use custom or external metrics with Horizontal Pod autoscaling to scale down to zero Pods and then scale back up.**

// the mininum size of replica set
MinReplicas int32 `json:"minReplicas"`

// +kubebuilder:validation:Optional
Copy link
Collaborator

@roypaulin roypaulin Jan 2, 2025

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Suggested change
// +kubebuilder:validation:Optional
// +kubebuilder:Minimum:=0

// +kubebuilder:validation:Optional
// +operator-sdk:csv:customresourcedefinitions:type=spec
// the mininum size of replica set
MinReplicas int32 `json:"minReplicas"`
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

pointer

Copy link
Collaborator Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

This is an integer. Using a pointer will not reduce memory footprint. Do you really want to use a pointer?

Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Yes, will avoid a conversion later as the hpa expects a pointer.

// +kubebuilder:validation:Optional
// +operator-sdk:csv:customresourcedefinitions:type=spec
// the custom metric to be used for autocaling
Metrics v2.MetricSpec `json:"metrics"`
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

This is a list.

// +kubebuilder:validation:Optional
// +operator-sdk:csv:customresourcedefinitions:type=spec
// define how the autocaler handles the scaleup and scaledown
Behavior v2.HorizontalPodAutoscalerBehavior `json:"behavior,omitempty"`
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

a pointer.

Copy link
Collaborator

@roypaulin roypaulin left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Looks good!


// +kubebuilder:validation:Optional
// +operator-sdk:csv:customresourcedefinitions:type=spec
// the value used to increase the threshold after after a scale up or a scale down
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Suggested change
// the value used to increase the threshold after after a scale up or a scale down
// The value used to increase the threshold after a scale up or a scale down.

Comment on lines 101 to 103
// +operator-sdk:csv:customresourcedefinitions:type=spec
// the maximum size of replica set
MaxReplicas *int32 `json:"maxReplicas"`
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Suggested change
// +operator-sdk:csv:customresourcedefinitions:type=spec
// the maximum size of replica set
MaxReplicas *int32 `json:"maxReplicas"`
// +operator-sdk:csv:customresourcedefinitions:type=spec
// The maximum number of pods when scaling.
MaxReplicas int32 `json:"maxReplicas"`

// +kubebuilder:validation:Optional
// +operator-sdk:csv:customresourcedefinitions:type=spec
// the value used to increase the threshold after after a scale up or a scale down
Increment *int32 `json:"increment"`
Copy link
Collaborator

@roypaulin roypaulin Jan 3, 2025

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Suggested change
Increment *int32 `json:"increment"`
ThresholdAdjustmentValue int32 `json:"thresholdAdjustmentValue,omitempty"`

I changed this field's name after your comment, it is always positive

// MetricDefinition defines increment and metric to be used for autoscaling
type MetricDefinition struct {

// +kubebuilder:validation:Optional
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Suggested change
// +kubebuilder:validation:Optional
// +kubebuilder:validation:Optional
// +kubebuilder:Minimum:=0

Copy link
Collaborator Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

If the increment can only be positive, we can only increase threshold and cannot decrease it. That will work for scale up but not scale down.

Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

It is no longer an increment but a value. For scale up it will be used to decrease.


// +kubebuilder:validation:Optional
// +operator-sdk:csv:customresourcedefinitions:type=spec
// the custom metric to be used for autocaling
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Suggested change
// the custom metric to be used for autocaling
// The custom metric to be used for autocaling.


// +kubebuilder:validation:Optional
// +operator-sdk:csv:customresourcedefinitions:type=spec
// define how the autocaler handles the scaleup and scaledown
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Suggested change
// define how the autocaler handles the scaleup and scaledown
// Specifies the scaling behavior for both scale up and down.

// +kubebuilder:Minimum:=0
// +kubebuilder:validation:Optional
// +operator-sdk:csv:customresourcedefinitions:type=spec
// the mininum size of replica set
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Suggested change
// the mininum size of replica set
// The miminum number of pods when scaling.

// +kubebuilder:validation:Optional
// +operator-sdk:csv:customresourcedefinitions:type=spec
// the mininum size of replica set
MinReplicas *int32 `json:"minReplicas"`
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Suggested change
MinReplicas *int32 `json:"minReplicas"`
MinReplicas *int32 `json:"minReplicas,omitempty"`

// +kubebuilder:Minimum:=0
// +operator-sdk:csv:customresourcedefinitions:type=spec
// the maximum size of replica set
MaxReplicas *int32 `json:"maxReplicas"`
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Suggested change
MaxReplicas *int32 `json:"maxReplicas"`
MaxReplicas *int32 `json:"maxReplicas,omitempty"`

Comment on lines 107 to 108
// the custom metric and increment to be used for autocaling
Metrics []MetricDefinition `json:"metrics"`
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Suggested change
// the custom metric and increment to be used for autocaling
Metrics []MetricDefinition `json:"metrics"`
// The custom metric to be used for autocaling.
Metrics []MetricDefinition `json:"metrics,omitempty"`

// +kubebuilder:validation:Optional
// +operator-sdk:csv:customresourcedefinitions:type=spec
// the custom metric to be used for autocaling
Metric autoscalingv2.MetricSpec `json:"metric"`
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Suggested change
Metric autoscalingv2.MetricSpec `json:"metric"`
Metric autoscalingv2.MetricSpec `json:"metric,omitempty"`

@LiboYu2 LiboYu2 marked this pull request as ready for review January 3, 2025 16:46
Copy link
Collaborator

@roypaulin roypaulin left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I will approve after this last round.

// The miminum number of pods when scaling.
MinReplicas *int32 `json:"minReplicas,omitempty"`

// +kubebuilder:validation:Optional
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Suggested change
// +kubebuilder:validation:Optional

// +kubebuilder:Minimum:=0
// +operator-sdk:csv:customresourcedefinitions:type=spec
// The maximum number of pods when scaling.
MaxReplicas *int32 `json:"maxReplicas,omitempty"`
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Suggested change
MaxReplicas *int32 `json:"maxReplicas,omitempty"`
MaxReplicas int32 `json:"maxReplicas,omitempty"`

// This struct allows customization of autoscaling. Custom metrics can be used instead of the memory and cpu metrics.
// The scaling behavior can also be customized to meet different performance requirements. The maximum and mininum of
// sizes of the replica sets can be specified to limit the use of resources.
CustomAutoscalerSpec *CustomAutoscalerSpec `json:"customAutoscalerSpec,omitempty"`
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Suggested change
CustomAutoscalerSpec *CustomAutoscalerSpec `json:"customAutoscalerSpec,omitempty"`
CustomAutoscaler *CustomAutoscalerSpec `json:"customAutoscalerSpec,omitempty"`

// +operator-sdk:csv:customresourcedefinitions:type=spec
// +kubebuilder:Minimum:=0
// The value used to increase the threshold after after a scale up or a scale down.
ThresholdAdjustmentValue *int32 `json:"thresholdAdjustmentValue,omitempty"`
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Suggested change
ThresholdAdjustmentValue *int32 `json:"thresholdAdjustmentValue,omitempty"`
ThresholdAdjustmentValue int `json:"thresholdAdjustmentValue,omitempty"`


// +kubebuilder:validation:Optional
// +operator-sdk:csv:customresourcedefinitions:type=spec
// The custom metric and increment to be used for autocaling.
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Suggested change
// The custom metric and increment to be used for autocaling.
// The custom metric definition to be used for autocaling.

@roypaulin
Copy link
Collaborator

@LiboYu2 Can you address my remaining comments? We need to merge this.

@LiboYu2
Copy link
Collaborator Author

LiboYu2 commented Jan 6, 2025

@LiboYu2 Can you address my remaining comments? We need to merge this.

I missed some of your comments this morning. I will make changes now. Sorry about that.

@roypaulin
Copy link
Collaborator

@LiboYu2 Can you address my remaining comments? We need to merge this.

I missed some of your comments this morning. I will make changes now. Sorry about that.

No worries!

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

2 participants