From a5ed5313e122bd8a966d066e622e3bae8a6ee6b1 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Martin=20M=C3=A1gr?= Date: Wed, 10 Apr 2024 14:39:20 +0200 Subject: [PATCH] KSM --- ....openstack.org_openstackcontrolplanes.yaml | 9 +++++ .../core.openstack.org_openstackversions.yaml | 6 ++++ apis/core/v1beta1/openstackversion_types.go | 1 + apis/core/v1beta1/zz_generated.deepcopy.go | 5 +++ ....openstack.org_openstackcontrolplanes.yaml | 9 +++++ .../core.openstack.org_openstackversions.yaml | 6 ++++ hack/export_related_images.sh | 1 + pkg/openstack/telemetry.go | 34 +++++++++++++++++++ pkg/openstack/version.go | 1 + 9 files changed, 72 insertions(+) diff --git a/apis/bases/core.openstack.org_openstackcontrolplanes.yaml b/apis/bases/core.openstack.org_openstackcontrolplanes.yaml index 6bd5672b6..000ad93dd 100644 --- a/apis/bases/core.openstack.org_openstackcontrolplanes.yaml +++ b/apis/bases/core.openstack.org_openstackcontrolplanes.yaml @@ -16390,6 +16390,13 @@ spec: enabled: default: true type: boolean + ksmTls: + properties: + caBundleSecretName: + type: string + secretName: + type: string + type: object networkAttachmentDefinitions: items: type: string @@ -17418,6 +17425,8 @@ spec: type: string keystoneAPIImage: type: string + ksmImage: + type: string manilaAPIImage: type: string manilaSchedulerImage: diff --git a/apis/bases/core.openstack.org_openstackversions.yaml b/apis/bases/core.openstack.org_openstackversions.yaml index b48b8431a..9d9fc91ba 100644 --- a/apis/bases/core.openstack.org_openstackversions.yaml +++ b/apis/bases/core.openstack.org_openstackversions.yaml @@ -143,6 +143,8 @@ spec: type: string keystoneAPIImage: type: string + ksmImage: + type: string manilaAPIImage: type: string manilaSchedulerImage: @@ -338,6 +340,8 @@ spec: type: string keystoneAPIImage: type: string + ksmImage: + type: string manilaAPIImage: type: string manilaSchedulerImage: @@ -502,6 +506,8 @@ spec: type: string keystoneAPIImage: type: string + ksmImage: + type: string manilaAPIImage: type: string manilaSchedulerImage: diff --git a/apis/core/v1beta1/openstackversion_types.go b/apis/core/v1beta1/openstackversion_types.go index 49b403507..c0a64672d 100644 --- a/apis/core/v1beta1/openstackversion_types.go +++ b/apis/core/v1beta1/openstackversion_types.go @@ -118,6 +118,7 @@ type ContainerTemplate struct { IronicPxeImage *string `json:"ironicPxeImage,omitempty"` IronicPythonAgentImage *string `json:"ironicPythonAgentImage,omitempty"` KeystoneAPIImage *string `json:"keystoneAPIImage,omitempty"` + KsmImage *string `json:"ksmImage,omitempty"` ManilaAPIImage *string `json:"manilaAPIImage,omitempty"` ManilaSchedulerImage *string `json:"manilaSchedulerImage,omitempty"` MariadbImage *string `json:"mariadbImage,omitempty"` diff --git a/apis/core/v1beta1/zz_generated.deepcopy.go b/apis/core/v1beta1/zz_generated.deepcopy.go index 5e8d1a0a0..9ec268062 100644 --- a/apis/core/v1beta1/zz_generated.deepcopy.go +++ b/apis/core/v1beta1/zz_generated.deepcopy.go @@ -463,6 +463,11 @@ func (in *ContainerTemplate) DeepCopyInto(out *ContainerTemplate) { *out = new(string) **out = **in } + if in.KsmImage != nil { + in, out := &in.KsmImage, &out.KsmImage + *out = new(string) + **out = **in + } if in.ManilaAPIImage != nil { in, out := &in.ManilaAPIImage, &out.ManilaAPIImage *out = new(string) diff --git a/config/crd/bases/core.openstack.org_openstackcontrolplanes.yaml b/config/crd/bases/core.openstack.org_openstackcontrolplanes.yaml index 6bd5672b6..000ad93dd 100644 --- a/config/crd/bases/core.openstack.org_openstackcontrolplanes.yaml +++ b/config/crd/bases/core.openstack.org_openstackcontrolplanes.yaml @@ -16390,6 +16390,13 @@ spec: enabled: default: true type: boolean + ksmTls: + properties: + caBundleSecretName: + type: string + secretName: + type: string + type: object networkAttachmentDefinitions: items: type: string @@ -17418,6 +17425,8 @@ spec: type: string keystoneAPIImage: type: string + ksmImage: + type: string manilaAPIImage: type: string manilaSchedulerImage: diff --git a/config/crd/bases/core.openstack.org_openstackversions.yaml b/config/crd/bases/core.openstack.org_openstackversions.yaml index b48b8431a..9d9fc91ba 100644 --- a/config/crd/bases/core.openstack.org_openstackversions.yaml +++ b/config/crd/bases/core.openstack.org_openstackversions.yaml @@ -143,6 +143,8 @@ spec: type: string keystoneAPIImage: type: string + ksmImage: + type: string manilaAPIImage: type: string manilaSchedulerImage: @@ -338,6 +340,8 @@ spec: type: string keystoneAPIImage: type: string + ksmImage: + type: string manilaAPIImage: type: string manilaSchedulerImage: @@ -502,6 +506,8 @@ spec: type: string keystoneAPIImage: type: string + ksmImage: + type: string manilaAPIImage: type: string manilaSchedulerImage: diff --git a/hack/export_related_images.sh b/hack/export_related_images.sh index 2fa7e566a..d0642c2c1 100755 --- a/hack/export_related_images.sh +++ b/hack/export_related_images.sh @@ -35,6 +35,7 @@ export RELATED_IMAGE_CEILOMETER_NOTIFICATION_IMAGE_URL_DEFAULT=quay.io/podified- export RELATED_IMAGE_CEILOMETER_IPMI_IMAGE_URL_DEFAULT=quay.io/podified-antelope-centos9/openstack-ceilometer-ipmi:current-podified export RELATED_IMAGE_CEILOMETER_SGCORE_IMAGE_URL_DEFAULT=quay.io/infrawatch/sg-core:current-podified export RELATED_IMAGE_CEILOMETER_PROXY_IMAGE_URL_DEFAULT=quay.io/podified-antelope-centos9/openstack-aodh-api:current-podified +export RELATED_IMAGE_KSM_IMAGE_URL_DEFAULT=registry.k8s.io/kube-state-metrics/kube-state-metrics:v2.10.0 export RELATED_IMAGE_AODH_API_IMAGE_URL_DEFAULT=quay.io/podified-antelope-centos9/openstack-aodh-api:current-podified export RELATED_IMAGE_AODH_EVALUATOR_IMAGE_URL_DEFAULT=quay.io/podified-antelope-centos9/openstack-aodh-evaluator:current-podified export RELATED_IMAGE_AODH_NOTIFIER_IMAGE_URL_DEFAULT=quay.io/podified-antelope-centos9/openstack-aodh-notifier:current-podified diff --git a/pkg/openstack/telemetry.go b/pkg/openstack/telemetry.go index bde204daa..841568aaa 100644 --- a/pkg/openstack/telemetry.go +++ b/pkg/openstack/telemetry.go @@ -65,9 +65,11 @@ func ReconcileTelemetry(ctx context.Context, instance *corev1beta1.OpenStackCont instance.Spec.Telemetry.Template.Autoscaling.Aodh.TLS = telemetry.Spec.Autoscaling.Aodh.TLS instance.Spec.Telemetry.Template.MetricStorage.PrometheusTLS = telemetry.Spec.MetricStorage.PrometheusTLS instance.Spec.Telemetry.Template.Ceilometer.TLS = telemetry.Spec.Ceilometer.TLS + instance.Spec.Telemetry.Template.Ceilometer.KSMTLS = telemetry.Spec.Ceilometer.KSMTLS } instance.Spec.Telemetry.Template.Autoscaling.Aodh.TLS.CaBundleSecretName = instance.Status.TLS.CaBundleSecretName instance.Spec.Telemetry.Template.Ceilometer.TLS.CaBundleSecretName = instance.Status.TLS.CaBundleSecretName + instance.Spec.Telemetry.Template.Ceilometer.KSMTLS.CaBundleSecretName = instance.Status.TLS.CaBundleSecretName instance.Spec.Telemetry.Template.MetricStorage.PrometheusTLS.CaBundleSecretName = instance.Status.TLS.CaBundleSecretName aodhSvcs, err := service.GetServicesListWithLabel( @@ -108,6 +110,15 @@ func ReconcileTelemetry(ctx context.Context, instance *corev1beta1.OpenStackCont if err != nil { return ctrl.Result{}, err } + ksmSvcs, err := service.GetServicesListWithLabel( + ctx, + helper, + instance.Namespace, + map[string]string{common.AppSelector: "kube-state-metrics"}, + ) + if err != nil { + return ctrl.Result{}, err + } // make sure to get to EndpointConfig when all service got created if len(aodhSvcs.Items) == len(instance.Spec.Telemetry.Template.Autoscaling.Aodh.Override.Service) { @@ -216,6 +227,27 @@ func ReconcileTelemetry(ctx context.Context, instance *corev1beta1.OpenStackCont } // update TLS settings with cert secret instance.Spec.Telemetry.Template.Ceilometer.TLS.SecretName = endpointDetails.GetEndptCertSecret(service.EndpointInternal) + + // NOTE: We don't have svc overrides for KSM objects too. + ksmEpDetails, ctrlResult, err := EnsureEndpointConfig( + ctx, + instance, + helper, + telemetry, + ksmSvcs, + nil, + corev1beta1.Override{}, + corev1beta1.OpenStackControlPlaneExposeTelemetryReadyCondition, + false, // TODO (mschuppert) could be removed when all integrated service support TLS + tls.API{}, + ) + if err != nil { + return ctrlResult, err + } else if (ctrlResult != ctrl.Result{}) { + return ctrlResult, nil + } + // update TLS settings with cert secret + instance.Spec.Telemetry.Template.Ceilometer.KSMTLS.SecretName = ksmEpDetails.GetEndptCertSecret(service.EndpointInternal) } helper.GetLogger().Info("Reconciling Telemetry", telemetryNamespaceLabel, instance.Namespace, telemetryNameLabel, telemetryName) @@ -239,6 +271,7 @@ func ReconcileTelemetry(ctx context.Context, instance *corev1beta1.OpenStackCont telemetry.Spec.Ceilometer.NotificationImage = *version.Status.ContainerImages.CeilometerNotificationImage telemetry.Spec.Ceilometer.SgCoreImage = *version.Status.ContainerImages.CeilometerSgcoreImage telemetry.Spec.Ceilometer.ProxyImage = *version.Status.ContainerImages.CeilometerProxyImage + telemetry.Spec.Ceilometer.KSMImage = *version.Status.ContainerImages.KsmImage telemetry.Spec.Autoscaling.AutoscalingSpec.Aodh.APIImage = *version.Status.ContainerImages.AodhAPIImage telemetry.Spec.Autoscaling.AutoscalingSpec.Aodh.EvaluatorImage = *version.Status.ContainerImages.AodhEvaluatorImage telemetry.Spec.Autoscaling.AutoscalingSpec.Aodh.NotifierImage = *version.Status.ContainerImages.AodhNotifierImage @@ -286,6 +319,7 @@ func ReconcileTelemetry(ctx context.Context, instance *corev1beta1.OpenStackCont instance.Status.ContainerImages.CeilometerNotificationImage = version.Status.ContainerImages.CeilometerNotificationImage instance.Status.ContainerImages.CeilometerSgcoreImage = version.Status.ContainerImages.CeilometerSgcoreImage instance.Status.ContainerImages.CeilometerProxyImage = version.Status.ContainerImages.CeilometerProxyImage + instance.Status.ContainerImages.KsmImage = version.Status.ContainerImages.KsmImage instance.Status.ContainerImages.AodhAPIImage = version.Status.ContainerImages.AodhAPIImage instance.Status.ContainerImages.AodhEvaluatorImage = version.Status.ContainerImages.AodhEvaluatorImage instance.Status.ContainerImages.AodhNotifierImage = version.Status.ContainerImages.AodhNotifierImage diff --git a/pkg/openstack/version.go b/pkg/openstack/version.go index f92f3d698..aa59bc327 100644 --- a/pkg/openstack/version.go +++ b/pkg/openstack/version.go @@ -126,6 +126,7 @@ func GetContainerImages(defaults *corev1beta1.ContainerDefaults, instance corev1 IronicPxeImage: getImg(instance.Spec.CustomContainerImages.IronicPxeImage, defaults.IronicPxeImage), IronicPythonAgentImage: getImg(instance.Spec.CustomContainerImages.IronicPythonAgentImage, defaults.IronicPythonAgentImage), KeystoneAPIImage: getImg(instance.Spec.CustomContainerImages.KeystoneAPIImage, defaults.KeystoneAPIImage), + KsmImage: getImg(instance.Spec.CustomContainerImages.KsmImage, defaults.KsmImage), ManilaAPIImage: getImg(instance.Spec.CustomContainerImages.ManilaAPIImage, defaults.ManilaAPIImage), ManilaSchedulerImage: getImg(instance.Spec.CustomContainerImages.ManilaSchedulerImage, defaults.ManilaSchedulerImage), MariadbImage: getImg(instance.Spec.CustomContainerImages.MariadbImage, defaults.MariadbImage),