Skip to content

Commit

Permalink
Added a flag to disable PDB
Browse files Browse the repository at this point in the history
Added tests for disablePDB flag
  • Loading branch information
sud82 committed Apr 24, 2024
1 parent b301d66 commit ac39d15
Show file tree
Hide file tree
Showing 12 changed files with 183 additions and 33 deletions.
2 changes: 1 addition & 1 deletion api/v1/aerospikecluster_mutating_webhook.go
Original file line number Diff line number Diff line change
Expand Up @@ -72,7 +72,7 @@ func (c *AerospikeCluster) Default(operation v1.Operation) admission.Response {

func (c *AerospikeCluster) setDefaults(asLog logr.Logger) error {
// Set maxUnavailable default to 1
if c.Spec.MaxUnavailable == nil {
if !GetBool(c.Spec.DisablePDB) && c.Spec.MaxUnavailable == nil {
maxUnavailable := intstr.FromInt(1)
c.Spec.MaxUnavailable = &maxUnavailable
}
Expand Down
31 changes: 20 additions & 11 deletions api/v1/aerospikecluster_types.go
Original file line number Diff line number Diff line change
Expand Up @@ -68,14 +68,17 @@ type AerospikeClusterSpec struct { //nolint:govet // for readability
// Aerospike cluster size
// +operator-sdk:csv:customresourcedefinitions:type=spec,displayName="Cluster Size"
Size int32 `json:"size"`
// Aerospike server image
// +operator-sdk:csv:customresourcedefinitions:type=spec,displayName="Server Image"
Image string `json:"image"`
// MaxUnavailable is the percentage/number of pods that can be allowed to go down or unavailable before application
// disruption. This value is used to create PodDisruptionBudget. Defaults to 1.
// Refer Aerospike documentation for more details.
// +operator-sdk:csv:customresourcedefinitions:type=spec,displayName="Max Unavailable"
MaxUnavailable *intstr.IntOrString `json:"maxUnavailable,omitempty"`
// Aerospike server image
// +operator-sdk:csv:customresourcedefinitions:type=spec,displayName="Server Image"
Image string `json:"image"`
// Disable the PodDisruptionBudget creation for the Aerospike cluster.
// +operator-sdk:csv:customresourcedefinitions:type=spec,displayName="Disable PodDisruptionBudget"
DisablePDB *bool `json:"disablePDB,omitempty"`
// Storage specify persistent storage to use for the Aerospike pods
// +operator-sdk:csv:customresourcedefinitions:type=spec,displayName="Storage"
Storage AerospikeStorageSpec `json:"storage,omitempty"`
Expand Down Expand Up @@ -637,6 +640,8 @@ type AerospikeClusterStatusSpec struct { //nolint:govet // for readability
// MaxUnavailable is the percentage/number of pods that can be allowed to go down or unavailable before application
// disruption. This value is used to create PodDisruptionBudget. Defaults to 1.
MaxUnavailable *intstr.IntOrString `json:"maxUnavailable,omitempty"`
// Disable the PodDisruptionBudget creation for the Aerospike cluster.
DisablePDB *bool `json:"disablePDB,omitempty"`
// If set true then multiple pods can be created per Kubernetes Node.
// This will create a NodePort service for each Pod.
// NodePort, as the name implies, opens a specific port on all the Kubernetes Nodes ,
Expand Down Expand Up @@ -1000,11 +1005,13 @@ func CopySpecToStatus(spec *AerospikeClusterSpec) (*AerospikeClusterStatusSpec,
}

if spec.EnableDynamicConfigUpdate != nil {
enableDynamicConfigUpdate := lib.DeepCopy(
spec.EnableDynamicConfigUpdate,
).(*bool)
enableDynamicConfigUpdate := *spec.EnableDynamicConfigUpdate
status.EnableDynamicConfigUpdate = &enableDynamicConfigUpdate
}

status.EnableDynamicConfigUpdate = enableDynamicConfigUpdate
if spec.DisablePDB != nil {
disablePDB := *spec.DisablePDB
status.DisablePDB = &disablePDB
}

// Storage
Expand Down Expand Up @@ -1097,11 +1104,13 @@ func CopyStatusToSpec(status *AerospikeClusterStatusSpec) (*AerospikeClusterSpec
}

if status.EnableDynamicConfigUpdate != nil {
enableDynamicConfigUpdate := lib.DeepCopy(
status.EnableDynamicConfigUpdate,
).(*bool)
enableDynamicConfigUpdate := *status.EnableDynamicConfigUpdate
spec.EnableDynamicConfigUpdate = &enableDynamicConfigUpdate
}

spec.EnableDynamicConfigUpdate = enableDynamicConfigUpdate
if status.DisablePDB != nil {
disablePDB := *status.DisablePDB
spec.DisablePDB = &disablePDB
}

// Storage
Expand Down
13 changes: 11 additions & 2 deletions api/v1/aerospikecluster_validating_webhook.go
Original file line number Diff line number Diff line change
Expand Up @@ -2222,8 +2222,17 @@ func validateIntOrStringField(value *intstr.IntOrString, fieldPath string) error

func (c *AerospikeCluster) validateMaxUnavailable() error {
// safe check for corner cases when mutation webhook somehow didn't work
if c.Spec.MaxUnavailable == nil {
return fmt.Errorf("maxUnavailable cannot be nil. Mutation webhook didn't work")
if !GetBool(c.Spec.DisablePDB) && c.Spec.MaxUnavailable == nil {
return fmt.Errorf("maxUnavailable cannot be nil if PDB is not disabled. Mutation webhook didn't work")
}

if GetBool(c.Spec.DisablePDB) {
if c.Spec.MaxUnavailable != nil {
return fmt.Errorf("maxUnavailable must be nil if PDB is disabled")
}

// PDB is disabled, so no need to validate further
return nil
}

if err := validateIntOrStringField(c.Spec.MaxUnavailable, "spec.maxUnavailable"); err != nil {
Expand Down
10 changes: 10 additions & 0 deletions api/v1/zz_generated.deepcopy.go

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

8 changes: 8 additions & 0 deletions config/crd/bases/asdb.aerospike.com_aerospikeclusters.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -281,6 +281,10 @@ spec:
- customInterface
type: string
type: object
disablePDB:
description: Disable the PodDisruptionBudget creation for the Aerospike
cluster.
type: boolean
enableDynamicConfigUpdate:
description: EnableDynamicConfigUpdate enables dynamic config update
flow of the operator. If enabled, operator will try to update the
Expand Down Expand Up @@ -9601,6 +9605,10 @@ spec:
- customInterface
type: string
type: object
disablePDB:
description: Disable the PodDisruptionBudget creation for the Aerospike
cluster.
type: boolean
enableDynamicConfigUpdate:
description: EnableDynamicConfigUpdate enables dynamic config update
flow of the operator. If enabled, operator will try to update the
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -47,6 +47,9 @@ spec:
the Aerospike cluster.
displayName: Aerospike Network Policy
path: aerospikeNetworkPolicy
- description: Disable the PodDisruptionBudget creation for the Aerospike cluster.
displayName: Disable PodDisruptionBudget
path: disablePDB
- description: EnableDynamicConfigUpdate enables dynamic config update flow
of the operator. If enabled, operator will try to update the Aerospike config
dynamically. In case of inconsistent state during dynamic config update,
Expand Down
1 change: 1 addition & 0 deletions config/rbac/role.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -117,6 +117,7 @@ rules:
- poddisruptionbudgets
verbs:
- create
- delete
- get
- patch
- update
2 changes: 1 addition & 1 deletion controllers/aerospikecluster_controller.go
Original file line number Diff line number Diff line change
Expand Up @@ -86,7 +86,7 @@ type RackState struct {
// +kubebuilder:rbac:groups=core,resources=configmaps,verbs=get;list;watch;create;update;patch;delete
// +kubebuilder:rbac:groups=core,resources=secrets,verbs=get
// +kubebuilder:rbac:groups=apps,resources=statefulsets,verbs=get;list;watch;create;update;patch;delete
// +kubebuilder:rbac:groups=policy,resources=poddisruptionbudgets,verbs=get;create;update;patch
// +kubebuilder:rbac:groups=policy,resources=poddisruptionbudgets,verbs=get;create;update;patch;delete
//nolint:lll // marker
// +kubebuilder:rbac:groups=asdb.aerospike.com,resources=aerospikeclusters,verbs=get;list;watch;create;update;patch;delete
// +kubebuilder:rbac:groups=asdb.aerospike.com,resources=aerospikeclusters/status,verbs=get;update;patch
Expand Down
38 changes: 38 additions & 0 deletions controllers/poddistruptionbudget.go
Original file line number Diff line number Diff line change
Expand Up @@ -14,6 +14,44 @@ import (
"github.com/aerospike/aerospike-kubernetes-operator/pkg/utils"
)

func (r *SingleClusterReconciler) reconcilePDB() error {
// If spec.DisablePDB is set to true, then we don't need to create PDB
// If it exist then delete it
if asdbv1.GetBool(r.aeroCluster.Spec.DisablePDB) {
if !asdbv1.GetBool(r.aeroCluster.Status.DisablePDB) {
r.Log.Info("PodDisruptionBudget is disabled. Deleting old PodDisruptionBudget")
return r.deletePDB()
}

r.Log.Info("PodDisruptionBudget is disabled, skipping PodDisruptionBudget creation")
return nil

Check failure on line 27 in controllers/poddistruptionbudget.go

View workflow job for this annotation

GitHub Actions / lint

return statements should not be cuddled if block has more than two lines (wsl)
}

// Create or update PodDisruptionBudget
return r.createOrUpdatePDB()
}

func (r *SingleClusterReconciler) deletePDB() error {
pdb := &v1.PodDisruptionBudget{}

// Get the PodDisruptionBudget
if err := r.Client.Get(
context.TODO(), types.NamespacedName{
Name: r.aeroCluster.Name, Namespace: r.aeroCluster.Namespace,
}, pdb,
); err != nil {
if errors.IsNotFound(err) {
// PodDisruptionBudget is already deleted
return nil
}

return err
}

// Delete the PodDisruptionBudget
return r.Client.Delete(context.TODO(), pdb)
}

func (r *SingleClusterReconciler) createOrUpdatePDB() error {
podList, err := r.getClusterPodList()
if err != nil {
Expand Down
8 changes: 4 additions & 4 deletions controllers/reconciler.go
Original file line number Diff line number Diff line change
Expand Up @@ -138,11 +138,11 @@ func (r *SingleClusterReconciler) Reconcile() (result ctrl.Result, recErr error)
return res.result, recErr
}

if err := r.createOrUpdatePDB(); err != nil {
r.Log.Error(err, "Failed to create PodDisruptionBudget")
if err := r.reconcilePDB(); err != nil {
r.Log.Error(err, "Failed to reconcile PodDisruptionBudget")
r.Recorder.Eventf(
r.aeroCluster, corev1.EventTypeWarning, "PodDisruptionBudgetCreateFailed",
"Failed to create PodDisruptionBudget %s/%s",
r.aeroCluster, corev1.EventTypeWarning, "PodDisruptionBudgetReconcileFailed",
"Failed to reconcile PodDisruptionBudget %s/%s",
r.aeroCluster.Namespace, r.aeroCluster.Name,
)

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -281,6 +281,10 @@ spec:
- customInterface
type: string
type: object
disablePDB:
description: Disable the PodDisruptionBudget creation for the Aerospike
cluster.
type: boolean
enableDynamicConfigUpdate:
description: EnableDynamicConfigUpdate enables dynamic config update
flow of the operator. If enabled, operator will try to update the
Expand Down Expand Up @@ -9601,6 +9605,10 @@ spec:
- customInterface
type: string
type: object
disablePDB:
description: Disable the PodDisruptionBudget creation for the Aerospike
cluster.
type: boolean
enableDynamicConfigUpdate:
description: EnableDynamicConfigUpdate enables dynamic config update
flow of the operator. If enabled, operator will try to update the
Expand Down
Loading

0 comments on commit ac39d15

Please sign in to comment.