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

Remove prom rules and Service Monitor from openshift monitoring namespace #1256

Merged
merged 10 commits into from
Oct 19, 2023
Merged
Original file line number Diff line number Diff line change
Expand Up @@ -10,6 +10,7 @@ import (
"fmt"
"os"
"reflect"
"strings"
"time"

"github.com/go-logr/logr"
Expand Down Expand Up @@ -38,6 +39,7 @@ import (
"sigs.k8s.io/controller-runtime/pkg/reconcile"
"sigs.k8s.io/controller-runtime/pkg/source"

monitoringv1 "github.com/prometheus-operator/prometheus-operator/pkg/apis/monitoring/v1"
mcov1beta2 "github.com/stolostron/multicluster-observability-operator/operators/multiclusterobservability/api/v1beta2"
placementctrl "github.com/stolostron/multicluster-observability-operator/operators/multiclusterobservability/controllers/placementrule"
certctrl "github.com/stolostron/multicluster-observability-operator/operators/multiclusterobservability/pkg/certificates"
Expand Down Expand Up @@ -69,6 +71,7 @@ var (
isRuleStorageSizeChanged = false
isReceiveStorageSizeChanged = false
isStoreStorageSizeChanged = false
isLegacyResourceRemoved = false
)

// MultiClusterObservabilityReconciler reconciles a MultiClusterObservability object
Expand Down Expand Up @@ -318,6 +321,20 @@ func (r *MultiClusterObservabilityReconciler) Reconcile(ctx context.Context, req
}
}

if os.Getenv("UNIT_TEST") != "true" && !isLegacyResourceRemoved {
isLegacyResourceRemoved = true
// Delete PrometheusRule from openshift-monitoring namespace
if err := r.deleteSpecificPrometheusRule(ctx); err != nil {
reqLogger.Error(err, "Failed to delete the specific PrometheusRule in the openshift-monitoring namespace")
return ctrl.Result{}, err
}
// Delete ServiceMonitor from openshft-monitoring namespace
if err := r.deleteServiceMonitorInOpenshiftMonitoringNamespace(ctx); err != nil {
reqLogger.Error(err, "Failed to delete service monitor in the openshift-monitoring namespace")
return ctrl.Result{}, err
}
}

//update status
coleenquadros marked this conversation as resolved.
Show resolved Hide resolved
requeueStatusUpdate <- struct{}{}

Expand Down Expand Up @@ -832,3 +849,43 @@ func (r *MultiClusterObservabilityReconciler) ensureOpenShiftNamespaceLabel(ctx

return reconcile.Result{}, nil
}

func (r *MultiClusterObservabilityReconciler) deleteSpecificPrometheusRule(ctx context.Context) error {
promRule := &monitoringv1.PrometheusRule{}
err := r.Client.Get(ctx, client.ObjectKey{Name: "acm-observability-alert-rules",
Namespace: "openshift-monitoring"}, promRule)
if err == nil {
err = r.Client.Delete(ctx, promRule)
if err != nil {
log.Error(err, "Failed to delete PrometheusRule in openshift-monitoring namespace")
return err
}
log.Info("Deleted PrometheusRule from openshift-monitoring namespace")
} else if !apierrors.IsNotFound(err) {
log.Error(err, "Failed to fetch PrometheusRule")
return err
}

return nil
}

func (r *MultiClusterObservabilityReconciler) deleteServiceMonitorInOpenshiftMonitoringNamespace(ctx context.Context) error {
serviceMonitorList := &monitoringv1.ServiceMonitorList{}
err := r.Client.List(ctx, serviceMonitorList, client.InNamespace("openshift-monitoring"))
if !apierrors.IsNotFound(err) && err != nil {
log.Error(err, "Failed to fetch ServiceMonitors")
return err
}

for _, sm := range serviceMonitorList.Items {
if strings.HasPrefix(sm.Name, "observability-") {
err = r.Client.Delete(ctx, sm)
if err != nil {
log.Error(err, "Failed to delete ServiceMonitor", "ServiceMonitorName", sm.Name)
return err
}
log.Info("Deleted ServiceMonitor", "ServiceMonitorName", sm.Name)
}
}
return nil
}
Original file line number Diff line number Diff line change
Expand Up @@ -12,6 +12,8 @@ import (
"testing"
"time"

monitoringv1 "github.com/prometheus-operator/prometheus-operator/pkg/apis/monitoring/v1"

oauthv1 "github.com/openshift/api/oauth/v1"
routev1 "github.com/openshift/api/route/v1"
observatoriumv1alpha1 "github.com/stolostron/observatorium-operator/api/v1alpha1"
Expand Down Expand Up @@ -1004,3 +1006,59 @@ func createAlertManagerConfigMap(name string) *corev1.ConfigMap {
},
}
}

func TestPrometheusRulesRemovedFromOpenshiftMonitoringNamespace(t *testing.T) {
promRule := &monitoringv1.PrometheusRule{
ObjectMeta: metav1.ObjectMeta{
Name: "acm-observability-alert-rules",
Namespace: "openshift-monitoring",
},
//Sample rules
Spec: monitoringv1.PrometheusRuleSpec{
Groups: []monitoringv1.RuleGroup{
{
Name: "test",
Rules: []monitoringv1.Rule{
{
Alert: "test",
},
},
},
},
},
}
s := scheme.Scheme
monitoringv1.AddToScheme(s)
objs := []runtime.Object{promRule}
c := fake.NewClientBuilder().WithRuntimeObjects(objs...).Build()
r := &MultiClusterObservabilityReconciler{Client: c, Scheme: s}
err := r.deleteSpecificPrometheusRule(context.TODO())
if err != nil {
t.Fatalf("Failed to delete PrometheusRule: (%v)", err)
}
}

func TestServiceMonitorRemovedFromOpenshiftMonitoringNamespace(t *testing.T) {
sm := &monitoringv1.ServiceMonitor{
ObjectMeta: metav1.ObjectMeta{
Name: "observability-sm-test",
Namespace: "openshift-monitoring",
},
Spec: monitoringv1.ServiceMonitorSpec{
Endpoints: []monitoringv1.Endpoint{
{
Port: "test",
},
},
},
}
s := scheme.Scheme
monitoringv1.AddToScheme(s)
objs := []runtime.Object{sm}
c := fake.NewClientBuilder().WithRuntimeObjects(objs...).Build()
r := &MultiClusterObservabilityReconciler{Client: c, Scheme: s}
err := r.deleteServiceMonitorInOpenshiftMonitoringNamespace(context.TODO())
if err != nil {
t.Fatalf("Failed to delete ServiceMonitor: (%v)", err)
}
}
Original file line number Diff line number Diff line change
Expand Up @@ -4,7 +4,7 @@ metadata:
annotations:
update-namespace: 'false'
name: acm-observability-alert-rules
namespace: openshift-monitoring
namespace: open-cluster-management-observability
spec:
groups:
- name: observability.rules
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -23,21 +23,21 @@ import (
)

const (
ocpMonitoringNamespace = "openshift-monitoring"
metricsNamePrefix = "acm_"
metricsNamePrefix = "acm_"
)

var (
ocpMonitoringNamespace = config.GetDefaultNamespace()
log = logf.Log.WithName("sm_controller")
isSmControllerRunnning = false
isSmControllerRunning = false
)

func Start() {

if isSmControllerRunnning {
if isSmControllerRunning {
return
}
isSmControllerRunnning = true
isSmControllerRunning = true

promClient, err := promclientset.NewForConfig(ctrl.GetConfigOrDie())
if err != nil {
Expand All @@ -56,7 +56,6 @@ func Start() {
time.Minute*60,
cache.ResourceEventHandlerFuncs{
AddFunc: onAdd(promClient),
DeleteFunc: onDelete(promClient),
UpdateFunc: onUpdate(promClient),
},
)
Expand All @@ -74,22 +73,6 @@ func onAdd(promClient promclientset.Interface) func(obj interface{}) {
}
}

func onDelete(promClient promclientset.Interface) func(obj interface{}) {
return func(obj interface{}) {
sm := obj.(*promv1.ServiceMonitor)
if sm.ObjectMeta.OwnerReferences != nil && sm.ObjectMeta.OwnerReferences[0].Kind == "Observatorium" {
err := promClient.MonitoringV1().
ServiceMonitors(ocpMonitoringNamespace).
Delete(context.TODO(), sm.Name, metav1.DeleteOptions{})
if err != nil {
log.Error(err, "Failed to delete ServiceMonitor", "namespace", ocpMonitoringNamespace, "name", sm.Name)
} else {
log.Info("ServiceMonitor Deleted", "namespace", ocpMonitoringNamespace, "name", sm.Name)
}
}
}
}

func onUpdate(promClient promclientset.Interface) func(oldObj interface{}, newObj interface{}) {
return func(oldObj interface{}, newObj interface{}) {
newSm := newObj.(*promv1.ServiceMonitor)
Expand Down