Skip to content

Commit

Permalink
controllers: Shut down OCS client CSV pods if not in provider mode
Browse files Browse the repository at this point in the history
The ocs-client-operator is a dependency of the odf-operator, which gets
installed regardless of whether the cluster is in provider mode. However,
the client operator is not needed in non-provider mode. This change ensures
that the client operator is shut down if the cluster is not in provider mode.

Signed-off-by: Nitin Goyal <nigoyal@redhat.com>
  • Loading branch information
iamniting committed Jul 23, 2024
1 parent abe8dbc commit 0c5c60c
Show file tree
Hide file tree
Showing 2 changed files with 68 additions and 2 deletions.
4 changes: 3 additions & 1 deletion controllers/storagesystem_controller.go
Original file line number Diff line number Diff line change
Expand Up @@ -263,7 +263,9 @@ func (r *StorageSystemReconciler) SetupWithManager(mgr ctrl.Manager) error {
return ctrl.NewControllerManagedBy(mgr).
For(&odfv1alpha1.StorageSystem{}, builder.WithPredicates(generationChangedPredicate)).
Owns(&operatorv1alpha1.Subscription{}, builder.WithPredicates(generationChangedPredicate, ignoreCreatePredicate)).
Owns(&ocsv1.StorageCluster{}, builder.WithPredicates(generationChangedPredicate)).
// Although we own the storage cluster, we are not a controller owner.
// Not being a controller owner requires us to pass builder.MatchEveryOwner.
Owns(&ocsv1.StorageCluster{}, builder.MatchEveryOwner, builder.WithPredicates(generationChangedPredicate)).
WithOptions(controller.Options{MaxConcurrentReconciles: 1}).
Complete(r)
}
66 changes: 65 additions & 1 deletion controllers/subscriptions.go
Original file line number Diff line number Diff line change
Expand Up @@ -20,11 +20,14 @@ import (
"context"
"fmt"
"os"
"slices"

"go.uber.org/multierr"
appsv1 "k8s.io/api/apps/v1"
corev1 "k8s.io/api/core/v1"
"k8s.io/apimachinery/pkg/api/errors"
metav1 "k8s.io/apimachinery/pkg/apis/meta/v1"
"k8s.io/apimachinery/pkg/labels"
"k8s.io/apimachinery/pkg/types"
"sigs.k8s.io/controller-runtime/pkg/client"
"sigs.k8s.io/controller-runtime/pkg/controller/controllerutil"
Expand Down Expand Up @@ -259,9 +262,52 @@ func GetVendorCsvNames(cli client.Client, kind odfv1alpha1.StorageKind) ([]strin
csvNames = []string{OcsSubscriptionStartingCSV, RookSubscriptionStartingCSV, NoobaaSubscriptionStartingCSV,
PrometheusSubscriptionStartingCSV, RecipeSubscriptionStartingCSV}

if isProvider, err = isProviderMode(cli); !isProvider {
isProvider, err = isProviderMode(cli)
if err != nil {
return csvNames, err
}

if !isProvider {
csvNames = append(csvNames, OcsClientSubscriptionStartingCSV, CSIAddonsSubscriptionStartingCSV)
}

// In provider mode, upgrades of the ocs-client-operator and csiaddons are managed by the provider, not the odf-operator.
// This can result in these operators lagging behind the odf-operator, with different CSV versions.
// Therefore, we need to fetch the CSV name from the operator deployment.
// We are only fetching the ocs-client-operator CSV name and ignoring the csiaddons
// Because the ocs-client-operator is essential when enabling provider mode as we need to bring it up.

// Fetch the CSV name from the client operator deployment and append it to the csv list
if isProvider {
// get ocs-client-operator deployment with label
deployments := &appsv1.DeploymentList{}
err = cli.List(context.TODO(), deployments, &client.ListOptions{
Namespace: OperatorNamespace,
LabelSelector: labels.SelectorFromSet(map[string]string{"app": "ocs-client-operator"}),
})

if err != nil {
return csvNames, err
}

if len(deployments.Items) == 0 {
return csvNames, fmt.Errorf("ocs-client-operator deployment not found")
}

// get owner ref index from deployment
ownerRefIndex := slices.IndexFunc(deployments.Items[0].OwnerReferences, func(o metav1.OwnerReference) bool {
return o.Kind == "ClusterServiceVersion"
})
if ownerRefIndex == -1 {
return csvNames, fmt.Errorf("ClusterServiceVersion owner reference not found in ocs-client-operator deployment")
}

ownerRef := deployments.Items[0].OwnerReferences[ownerRefIndex]

// get csv name from owner ref
csvNames = append(csvNames, ownerRef.Name)
OcsClientSubscriptionStartingCSV = ownerRef.Name
}
}

return csvNames, err
Expand All @@ -285,6 +331,24 @@ func EnsureVendorCsv(cli client.Client, csvName string) (*operatorv1alpha1.Clust
}
_, err = controllerutil.CreateOrUpdate(context.TODO(), cli, csvObj, func() error {
csvObj.OwnerReferences = []metav1.OwnerReference{}

// Shut down the OCS client operator CSV pods in non provider mode
if csvName == OcsClientSubscriptionStartingCSV {
isProvider, err := isProviderMode(cli)
if err != nil {
return err
}

var replicas int32 = 0
if isProvider {
replicas = 1
}

for i := range csvObj.Spec.InstallStrategy.StrategySpec.DeploymentSpecs {
csvObj.Spec.InstallStrategy.StrategySpec.DeploymentSpecs[i].Spec.Replicas = &replicas
}
}

return SetOdfSubControllerReference(cli, csvObj)
})
if err != nil && !errors.IsAlreadyExists(err) {
Expand Down

0 comments on commit 0c5c60c

Please sign in to comment.