From 67703a6e04a03900ce24fd6faf2646f19e3ad981 Mon Sep 17 00:00:00 2001 From: Rael Garcia Arnes Date: Fri, 22 Nov 2024 10:49:58 +0100 Subject: [PATCH 1/6] fix: updates a renamed metric in the exporter https://github.com/prometheus-community/postgres_exporter/commit/27d23d02ef107068df81d42ba50ecb4f5068e3db --- .../exporters/postgresql/grafanadashboard.json.j2 | 14 +++++++------- 1 file changed, 7 insertions(+), 7 deletions(-) diff --git a/roles/prometheusexporter/exporters/postgresql/grafanadashboard.json.j2 b/roles/prometheusexporter/exporters/postgresql/grafanadashboard.json.j2 index 516c613..6159894 100644 --- a/roles/prometheusexporter/exporters/postgresql/grafanadashboard.json.j2 +++ b/roles/prometheusexporter/exporters/postgresql/grafanadashboard.json.j2 @@ -1739,7 +1739,7 @@ "steppedLine": false, "targets": [ { - "expr": "irate(pg_stat_bgwriter_buffers_backend{namespace=\"$namespace\", prometheus_exporter=\"$prometheus_exporter\"}[$interval])", + "expr": "irate(pg_stat_bgwriter_buffers_backend_total{namespace=\"$namespace\", prometheus_exporter=\"$prometheus_exporter\"}[$interval])", "format": "time_series", "intervalFactor": 1, "legendFormat": "buffers_backend", @@ -1747,7 +1747,7 @@ "step": 20 }, { - "expr": "irate(pg_stat_bgwriter_buffers_alloc{namespace=\"$namespace\", prometheus_exporter=\"$prometheus_exporter\"}[$interval])", + "expr": "irate(pg_stat_bgwriter_buffers_alloc_total{namespace=\"$namespace\", prometheus_exporter=\"$prometheus_exporter\"}[$interval])", "format": "time_series", "intervalFactor": 1, "legendFormat": "buffers_alloc", @@ -1755,7 +1755,7 @@ "step": 20 }, { - "expr": "irate(pg_stat_bgwriter_buffers_fsync{namespace=\"$namespace\", prometheus_exporter=\"$prometheus_exporter\"}[$interval])", + "expr": "irate(pg_stat_bgwriter_buffers_fsync_total{namespace=\"$namespace\", prometheus_exporter=\"$prometheus_exporter\"}[$interval])", "format": "time_series", "intervalFactor": 1, "legendFormat": "backend_fsync", @@ -1763,7 +1763,7 @@ "step": 20 }, { - "expr": "irate(pg_stat_bgwriter_buffers_checkpoint{namespace=\"$namespace\", prometheus_exporter=\"$prometheus_exporter\"}[$interval])", + "expr": "irate(pg_stat_bgwriter_buffers_checkpoint_total{namespace=\"$namespace\", prometheus_exporter=\"$prometheus_exporter\"}[$interval])", "format": "time_series", "intervalFactor": 1, "legendFormat": "buffers_checkpoint", @@ -1771,7 +1771,7 @@ "step": 20 }, { - "expr": "irate(pg_stat_bgwriter_buffers_clean{namespace=\"$namespace\", prometheus_exporter=\"$prometheus_exporter\"}[$interval])", + "expr": "irate(pg_stat_bgwriter_buffers_clean_total{namespace=\"$namespace\", prometheus_exporter=\"$prometheus_exporter\"}[$interval])", "format": "time_series", "intervalFactor": 1, "legendFormat": "buffers_clean", @@ -2130,7 +2130,7 @@ "steppedLine": false, "targets": [ { - "expr": "irate(pg_stat_bgwriter_checkpoint_write_time{namespace=\"$namespace\", prometheus_exporter=\"$prometheus_exporter\"}[$interval])", + "expr": "irate(pg_stat_bgwriter_checkpoint_write_time_total{namespace=\"$namespace\", prometheus_exporter=\"$prometheus_exporter\"}[$interval])", "format": "time_series", "intervalFactor": 1, "legendFormat": "write_time - Total amount of time that has been spent in the portion of checkpoint processing where files are written to disk.", @@ -2138,7 +2138,7 @@ "step": 10 }, { - "expr": "irate(pg_stat_bgwriter_checkpoint_sync_time{namespace=\"$namespace\", prometheus_exporter=\"$prometheus_exporter\"}[$interval])", + "expr": "irate(pg_stat_bgwriter_checkpoint_sync_time_total{namespace=\"$namespace\", prometheus_exporter=\"$prometheus_exporter\"}[$interval])", "format": "time_series", "intervalFactor": 1, "legendFormat": "sync_time - Total amount of time that has been spent in the portion of checkpoint processing where files are synchronized to disk.", From ff7bb830294f5be709f46e9bd421c3b052ab3b28 Mon Sep 17 00:00:00 2001 From: Rael Garcia Arnes Date: Fri, 22 Nov 2024 10:41:21 +0000 Subject: [PATCH 2/6] docs: improve Makefile target names and documentation --- .github/workflows/release-catalog.yaml | 2 +- .github/workflows/release.yaml | 8 +- Makefile | 239 +++++++++++++------------ 3 files changed, 127 insertions(+), 122 deletions(-) diff --git a/.github/workflows/release-catalog.yaml b/.github/workflows/release-catalog.yaml index 593d51a..8599c35 100644 --- a/.github/workflows/release-catalog.yaml +++ b/.github/workflows/release-catalog.yaml @@ -38,4 +38,4 @@ jobs: run: make catalog-push - name: Build and push the current catalog container image as latest - run: make catalog-retag-latest + run: make catalog-push-latest diff --git a/.github/workflows/release.yaml b/.github/workflows/release.yaml index 73bd80b..f0da803 100644 --- a/.github/workflows/release.yaml +++ b/.github/workflows/release.yaml @@ -61,12 +61,12 @@ jobs: - name: Build and push bundle container image run: make bundle-push - - id: bundle-image-name + - id: bundle-image name: Retrieves the bundle image name - run: echo "BUNDLE_IMAGE=$(make -s bundle-image-name)" >> $GITHUB_OUTPUT + run: echo "BUNDLE_IMAGE=$(make -s bundle-image)" >> $GITHUB_OUTPUT - name: Update catalog files with the new bundle - run: make catalog-update + run: make catalog - name: Create a new draft-release in github run: gh release create "${{ env.RELEASE }}" --draft --title "${{ env.RELEASE }}" --generate-notes @@ -79,7 +79,7 @@ jobs: CATALOG_RELEASE_PR_BODY: | This PR updates the catalog inventory files with the new bundle [${{ needs.check.outputs.stable-release }}](https://github.com/${GITHUB_REPOSITORY}/releases/tag/${{ needs.check.outputs.stable-release }}). - [${{ steps.bundle-image-name.outputs.BUNDLE_IMAGE }}](https://${{ steps.bundle-image-name.outputs.BUNDLE_IMAGE }}) + [${{ steps.bundle-image.outputs.BUNDLE_IMAGE }}](https://${{ steps.bundle-image.outputs.BUNDLE_IMAGE }}) Please review and merge this PR to build and release the new catalog. diff --git a/Makefile b/Makefile index 526a21f..cc5c26b 100644 --- a/Makefile +++ b/Makefile @@ -78,10 +78,6 @@ help: ## Display this help. ##@ Build -.PHONY: run -run: ansible-operator ## Run against the configured Kubernetes cluster in ~/.kube/config - ANSIBLE_ROLES_PATH="$(ANSIBLE_ROLES_PATH):$(shell pwd)/roles" $(ANSIBLE_OPERATOR) run - .PHONY: container-build container-build: ## Build container with the manager. ${CONTAINER_RUNTIME} buildx build \ @@ -94,31 +90,27 @@ container-push: ## Push container image with the manager. --platform linux/arm64,linux/amd64 \ --tag $(IMG) --file $(CONTAINER_FILE) $(CONTAINER_CTX) -.PHONY: container-image-name -container-image-name: ## Outputs the container image +.PHONY: container-image +container-image: ## Outputs the container image name and tag. @echo $(IMG) -##@ Deployment - -.PHONY: install -install: kustomize ## Install CRDs into the K8s cluster specified in ~/.kube/config. - $(KUSTOMIZE) build config/crd | kubectl apply -f - - -.PHONY: uninstall -uninstall: kustomize ## Uninstall CRDs from the K8s cluster specified in ~/.kube/config. - $(KUSTOMIZE) build config/crd | kubectl delete -f - - -.PHONY: deploy -deploy: kustomize ## Deploy controller to the K8s cluster specified in ~/.kube/config. - cd config/manager && $(KUSTOMIZE) edit set image controller=${IMG} - $(KUSTOMIZE) build config/manual | kubectl apply -f - +##@ Dependencies -.PHONY: undeploy -undeploy: ## Undeploy controller from the K8s cluster specified in ~/.kube/config. - $(KUSTOMIZE) build config/manual | kubectl delete -f - - -OS := $(shell uname -s | tr '[:upper:]' '[:lower:]') -ARCH := $(shell uname -m | sed 's/x86_64/amd64/' | sed 's/aarch64/arm64/') +.PHONY: ansible-operator +ANSIBLE_OPERATOR = $(shell pwd)/bin/ansible-operator +ansible-operator: ## Download ansible-operator locally if necessary, preferring the $(pwd)/bin path over global if both exist. +ifeq (,$(wildcard $(ANSIBLE_OPERATOR))) +ifeq (,$(shell which ansible-operator 2>/dev/null)) + @{ \ + set -e ;\ + mkdir -p $(dir $(ANSIBLE_OPERATOR)) ;\ + curl -sSLo $(ANSIBLE_OPERATOR) https://github.com/operator-framework/operator-sdk/releases/download/v1.24.0/ansible-operator_$(OS)_$(ARCH) ;\ + chmod +x $(ANSIBLE_OPERATOR) ;\ + } +else +ANSIBLE_OPERATOR = $(shell which ansible-operator) +endif +endif .PHONY: kustomize KUSTOMIZE = $(shell pwd)/bin/kustomize @@ -136,22 +128,83 @@ KUSTOMIZE = $(shell which kustomize) endif endif -.PHONY: ansible-operator -ANSIBLE_OPERATOR = $(shell pwd)/bin/ansible-operator -ansible-operator: ## Download ansible-operator locally if necessary, preferring the $(pwd)/bin path over global if both exist. -ifeq (,$(wildcard $(ANSIBLE_OPERATOR))) -ifeq (,$(shell which ansible-operator 2>/dev/null)) +.PHONY: opm +OPM = ./bin/opm +opm: ## Download opm locally if necessary. +ifeq (,$(wildcard $(OPM))) +ifeq (,$(shell which opm 2>/dev/null)) @{ \ set -e ;\ - mkdir -p $(dir $(ANSIBLE_OPERATOR)) ;\ - curl -sSLo $(ANSIBLE_OPERATOR) https://github.com/operator-framework/operator-sdk/releases/download/v1.24.0/ansible-operator_$(OS)_$(ARCH) ;\ - chmod +x $(ANSIBLE_OPERATOR) ;\ + mkdir -p $(dir $(OPM)) ;\ + curl -sSLo $(OPM) https://github.com/operator-framework/operator-registry/releases/download/v1.23.0/$(OS)-$(ARCH)-opm ;\ + chmod +x $(OPM) ;\ } else -ANSIBLE_OPERATOR = $(shell which ansible-operator) +OPM = $(shell which opm) endif endif +############################################# +#### Custom Targets with extra binaries ##### +############################################# + +.PHONY: operator-sdk +OPERATOR_SDK_RELEASE = v1.24.0 +OPERATOR_SDK = $(shell pwd)/bin/operator-sdk-$(OPERATOR_SDK_RELEASE) +OPERATOR_SDK_DL_URL = https://github.com/operator-framework/operator-sdk/releases/download/$(OPERATOR_SDK_RELEASE)/operator-sdk_$(OS)_$(ARCH) +operator-sdk: ## Download operator-sdk binary if necessary. + @if [ ! -f $(OPERATOR_SDK) ]; then\ + mkdir -p $(shell pwd)/bin;\ + curl -sL -o $(OPERATOR_SDK) $(OPERATOR_SDK_DL_URL);\ + chmod +x $(OPERATOR_SDK);\ + fi + +## Download kind locally if necessary. +KIND_RELEASE = v0.11.1 +KIND = $(shell pwd)/bin/kind-$(KIND_RELEASE) +KIND_DL_URL = https://github.com/kubernetes-sigs/kind/releases/download/$(KIND_RELEASE)/kind-$(OS)-$(ARCH) +$(KIND): + mkdir -p $(shell pwd)/bin + curl -sL -o $(KIND) $(KIND_DL_URL) + chmod +x $(KIND) + +## Download kuttl locally if necessary for e2e tests. +KUTTL_RELEASE = 0.9.0 +KUTTL = $(shell pwd)/bin/kuttl-v$(KUTTL_RELEASE) +KUTTL_DL_URL = https://github.com/kudobuilder/kuttl/releases/download/v$(KUTTL_RELEASE)/kubectl-kuttl_$(KUTTL_RELEASE)_$(OS)_x86_64 +$(KUTTL): + mkdir -p $(shell pwd)/bin + curl -sL -o $(KUTTL) $(KUTTL_DL_URL) + chmod +x $(KUTTL) + +##@ Deployment + +.PHONY: run +run: ansible-operator ## Run against the configured Kubernetes cluster in ~/.kube/config. + ANSIBLE_ROLES_PATH="$(ANSIBLE_ROLES_PATH):$(shell pwd)/roles" $(ANSIBLE_OPERATOR) run + +.PHONY: install +install: kustomize ## Install CRDs into the K8s cluster specified in ~/.kube/config. + $(KUSTOMIZE) build config/crd | kubectl apply -f - + +.PHONY: uninstall +uninstall: kustomize ## Uninstall CRDs from the K8s cluster specified in ~/.kube/config. + $(KUSTOMIZE) build config/crd | kubectl delete -f - + +.PHONY: deploy +deploy: kustomize ## Deploy controller to the K8s cluster specified in ~/.kube/config. + cd config/manager && $(KUSTOMIZE) edit set image controller=${IMG} + $(KUSTOMIZE) build config/manual | kubectl apply -f - + +.PHONY: undeploy +undeploy: ## Undeploy controller from the K8s cluster specified in ~/.kube/config. + $(KUSTOMIZE) build config/manual | kubectl delete -f - + +OS := $(shell uname -s | tr '[:upper:]' '[:lower:]') +ARCH := $(shell uname -m | sed 's/x86_64/amd64/' | sed 's/aarch64/arm64/') + +##@ Bundle + .PHONY: bundle bundle: operator-sdk kustomize ## Generate bundle manifests and metadata, then validate generated files. $(OPERATOR_SDK) generate kustomize manifests -q @@ -169,30 +222,15 @@ bundle-push: ## Push the bundle image. $(MAKE) container-push \ IMG=$(BUNDLE_IMG) CONTAINER_FILE=$(BUNDLE_CONTAINER_FILE) -bundle-image-name: ## Outputs the bundle image name - @$(MAKE) container-image-name IMG=$(BUNDLE_IMG) - -.PHONY: opm -OPM = ./bin/opm -opm: ## Download opm locally if necessary. -ifeq (,$(wildcard $(OPM))) -ifeq (,$(shell which opm 2>/dev/null)) - @{ \ - set -e ;\ - mkdir -p $(dir $(OPM)) ;\ - curl -sSLo $(OPM) https://github.com/operator-framework/operator-registry/releases/download/v1.23.0/$(OS)-$(ARCH)-opm ;\ - chmod +x $(OPM) ;\ - } -else -OPM = $(shell which opm) -endif -endif - +bundle-image: ## Outputs the bundle image name. + @$(MAKE) container-image IMG=$(BUNDLE_IMG) # A comma-separated list of bundle images (e.g. make catalog-build BUNDLE_IMGS=example.com/operator-bundle:v0.1.0,example.com/operator-bundle:v0.2.0). # These images MUST exist in a registry and be pull-able. BUNDLE_IMGS ?= $(BUNDLE_IMG) +##@ Catalog + # The image tag given to the resulting catalog image (e.g. make catalog-build CATALOG_IMG=example.com/operator-catalog:v0.2.0). CATALOG_IMG ?= $(IMAGE_TAG_BASE)-catalog:v$(VERSION) @@ -213,108 +251,75 @@ ifneq ($(origin CATALOG_BASE_IMG), undefined) FROM_INDEX_OPT := --from-index $(CATALOG_BASE_IMG) endif -catalog-render: opm ## Render the clusterserviceversion yaml +.PHONY: catalog +catalog: opm catalog-add-bundle catalog-validate ## Update and validate the catalog with the current bundle. + +catalog-render-bundle: opm # Render the current clusterserviceversion yaml from the bundle container into the catalog. $(OPM) render $(BUNDLE_IMGS) -oyaml > catalog/prometheus-exporter-operator/objects/prometheus-exporter-operator.v$(VERSION).clusterserviceversion.yaml -catalog-add-entry: ## Add catalog entry if missing +catalog-add-entry: # Adds a catalog entry if missing grep -Eq 'name: prometheus-exporter-operator\.v$(VERSION)$$' $(CATALOG_CHANNEL_FILE) || \ yq -i '.entries += {"name": "prometheus-exporter-operator.v$(VERSION)","replaces":"$(shell yq '.entries[-1].name' $(CATALOG_CHANNEL_FILE))"}' $(CATALOG_CHANNEL_FILE) .PHONY: catalog-add-bundle-to-alpha -catalog-add-bundle-to-alpha: opm catalog-render ## Adds the alpha bundle to a file based catalog +catalog-add-bundle-to-alpha: opm catalog-render-bundle # Adds the alpha bundle to a file based catalog $(MAKE) catalog-add-entry CATALOG_CHANNEL_FILE=catalog/prometheus-exporter-operator/alpha-channel.yaml .PHONY: catalog-add-bundle-to-stable -catalog-add-bundle-to-stable: opm catalog-render catalog-add-bundle-to-alpha ## Adds a bundle to a file based catalog +catalog-add-bundle-to-stable: opm catalog-render-bundle catalog-add-bundle-to-alpha # Adds a bundle to a file based catalog $(MAKE) catalog-add-entry CATALOG_CHANNEL_FILE=catalog/prometheus-exporter-operator/stable-channel.yaml .PHONY: catalog-add-bundle -catalog-add-bundle: opm catalog-render ## Adds a bundle to a file based catalog +catalog-add-bundle: opm catalog-render-bundle # Adds a bundle to a file based catalog if echo $(VERSION) | grep -q 'alpha'; \ then $(MAKE) catalog-add-bundle-to-alpha; \ else $(MAKE) catalog-add-bundle-to-stable; \ fi -# Validate the catalog. .PHONY: catalog-validate -catalog-validate: ## Push a catalog image. +catalog-validate: # Validate the catalog files. $(OPM) validate catalog/prometheus-exporter-operator -.PHONY: catalog-update -catalog-update: opm catalog-add-bundle catalog-validate ## Update and generate new release catalog files - -catalog-build: opm catalog-validate ## Build the bundle image. +catalog-build: opm catalog-validate ## Build the catalog image. $(MAKE) container-build \ IMG=$(CATALOG_IMG) CONTAINER_FILE=$(CATALOG_CONTAINER_FILE) CONTAINER_CTX=$(CATALOG_CONTAINER_CTX) -# Push the catalog image. .PHONY: catalog-push catalog-push: opm catalog-validate ## Push a catalog image. $(MAKE) container-push\ IMG=$(CATALOG_IMG) CONTAINER_FILE=$(CATALOG_CONTAINER_FILE) CONTAINER_CTX=$(CATALOG_CONTAINER_CTX) -############################################# -#### Custom Targets with extra binaries ##### -############################################# - -# Download operator-sdk binary if necessary -.PHONY: operator-sdk -OPERATOR_SDK_RELEASE = v1.24.0 -OPERATOR_SDK = $(shell pwd)/bin/operator-sdk-$(OPERATOR_SDK_RELEASE) -OPERATOR_SDK_DL_URL = https://github.com/operator-framework/operator-sdk/releases/download/$(OPERATOR_SDK_RELEASE)/operator-sdk_$(OS)_$(ARCH) -operator-sdk: - @if [ ! -f $(OPERATOR_SDK) ]; then\ - mkdir -p $(shell pwd)/bin;\ - curl -sL -o $(OPERATOR_SDK) $(OPERATOR_SDK_DL_URL);\ - chmod +x $(OPERATOR_SDK);\ - fi - -# Download kind locally if necessary -KIND_RELEASE = v0.11.1 -KIND = $(shell pwd)/bin/kind-$(KIND_RELEASE) -KIND_DL_URL = https://github.com/kubernetes-sigs/kind/releases/download/$(KIND_RELEASE)/kind-$(OS)-$(ARCH) -$(KIND): - mkdir -p $(shell pwd)/bin - curl -sL -o $(KIND) $(KIND_DL_URL) - chmod +x $(KIND) +catalog-image: ## Outputs the catalog image name. + @$(MAKE) container-image IMG=$(CATALOG_IMG) -# Download kuttl locally if necessary for e2e tests -KUTTL_RELEASE = 0.9.0 -KUTTL = $(shell pwd)/bin/kuttl-v$(KUTTL_RELEASE) -KUTTL_DL_URL = https://github.com/kudobuilder/kuttl/releases/download/v$(KUTTL_RELEASE)/kubectl-kuttl_$(KUTTL_RELEASE)_$(OS)_x86_64 -$(KUTTL): - mkdir -p $(shell pwd)/bin - curl -sL -o $(KUTTL) $(KUTTL_DL_URL) - chmod +x $(KUTTL) +catalog-push-latest: ## Push the catalog with the `latest` image tag. + $(MAKE) container-push \ + IMG=$(CATALOG_BASE_IMG) CONTAINER_FILE=$(CATALOG_CONTAINER_FILE) CONTAINER_CTX=$(CATALOG_CONTAINER_CTX) #################################################### -#### Custom Targets to publish release catalog ##### +##### Custom Targets to release a new version ###### #################################################### -##@ Release Catalog +##@ Release -prepare-release: +get-new-release: + @hack/new-release.sh v$(VERSION) + +prepare-release: ## Prepare bundle release files. if echo $(VERSION) | grep -q 'alpha'; \ then $(MAKE) prepare-alpha-release; \ else $(MAKE) prepare-stable-release; \ fi -prepare-alpha-release: bundle ## Prepare alpha release +prepare-alpha-release: bundle # Prepare alpha release. -prepare-stable-release: bundle ## Prepare stable release +prepare-stable-release: bundle # Prepare stable release. $(MAKE) bundle CHANNELS=alpha,stable DEFAULT_CHANNEL=alpha -catalog-retag-latest: - $(MAKE) container-push \ - IMG=$(CATALOG_BASE_IMG) CONTAINER_FILE=$(CATALOG_CONTAINER_FILE) CONTAINER_CTX=$(CATALOG_CONTAINER_CTX) - -bundle-publish: prepare-release bundle-push ## Publish new bundle - -catalog-publish: catalog-add-bundle catalog-push catalog-retag-latest ## Builds and pushes the catalog image +bundle-publish: prepare-release bundle-push ## Publish new bundle. -release-publish: container-push bundle-publish catalog-publish ## Publish a new stable release (operator, catalog and bundle) +catalog-publish: catalog-add-bundle catalog-push catalog-push-latest ## Build and push the catalog image. -get-new-release: - @hack/new-release.sh v$(VERSION) +release-publish: container-push bundle-publish catalog-publish ## Publish a new stable release (operator, catalog and bundle). ################################################### #### Custom Targets to manually test with Kind #### @@ -322,14 +327,14 @@ get-new-release: ##@ Testing kind-create: export KUBECONFIG = ${PWD}/kubeconfig -kind-create: $(KIND) ## Creates a k8s kind cluster +kind-create: $(KIND) ## Creates a k8s kind cluster. $(KIND) create cluster --wait 5m || true -kind-delete: $(KIND) ## Deletes the k8s kind cluster +kind-delete: $(KIND) ## Deletes the k8s kind cluster. $(KIND) delete cluster kind-deploy: export KUBECONFIG = ${PWD}/kubeconfig -kind-deploy: kustomize $(KIND) ## Deploys the operator in the k8s kind cluster +kind-deploy: kustomize $(KIND) ## Deploys the operator in the k8s kind cluster. ${CONTAINER_RUNTIME} build --tag $(IMG) \ --file $(CONTAINER_FILE) $(CONTAINER_CTX) $(KIND) load docker-image $(IMG) @@ -337,5 +342,5 @@ kind-deploy: kustomize $(KIND) ## Deploys the operator in the k8s kind cluster $(KUSTOMIZE) build config/testing | kubectl apply -f - test-e2e: export KUBECONFIG = ${PWD}/kubeconfig -test-e2e: kind-create kustomize kind-deploy $(KUTTL) ## Run kuttl e2e tests in the k8s kind cluster +test-e2e: kind-create kustomize kind-deploy $(KUTTL) ## Run kuttl e2e tests in the k8s kind cluster. $(KUTTL) From 75903e5486de2d1896014b7549a5a8b7588c65e2 Mon Sep 17 00:00:00 2001 From: Rael Garcia Arnes Date: Fri, 22 Nov 2024 11:07:16 +0100 Subject: [PATCH 3/6] release: replace 0.8.2 with 0.9.0-alpha.1 Signed-off-by: Rael Garcia Arnes --- Makefile | 2 +- bundle.Dockerfile | 3 +- ...porter-operator.clusterserviceversion.yaml | 6 ++-- bundle/metadata/annotations.yaml | 3 +- .../alpha-channel.yaml | 8 +---- ....v0.8.2-alpha.1.clusterserviceversion.yaml | 32 ------------------- ....v0.8.2-alpha.3.clusterserviceversion.yaml | 32 ------------------- ...operator.v0.8.2.clusterserviceversion.yaml | 32 ------------------- ...v0.9.0-alpha.1.clusterserviceversion.yaml} | 12 +++---- .../stable-channel.yaml | 2 -- config/manager/kustomization.yaml | 2 +- 11 files changed, 14 insertions(+), 120 deletions(-) delete mode 100644 catalog/prometheus-exporter-operator/objects/prometheus-exporter-operator.v0.8.2-alpha.1.clusterserviceversion.yaml delete mode 100644 catalog/prometheus-exporter-operator/objects/prometheus-exporter-operator.v0.8.2-alpha.3.clusterserviceversion.yaml delete mode 100644 catalog/prometheus-exporter-operator/objects/prometheus-exporter-operator.v0.8.2.clusterserviceversion.yaml rename catalog/prometheus-exporter-operator/objects/{prometheus-exporter-operator.v0.8.2-alpha.2.clusterserviceversion.yaml => prometheus-exporter-operator.v0.9.0-alpha.1.clusterserviceversion.yaml} (98%) diff --git a/Makefile b/Makefile index cc5c26b..a01ae96 100644 --- a/Makefile +++ b/Makefile @@ -2,7 +2,7 @@ # To re-generate a bundle for another specific version without changing the standard setup, you can: # - use the VERSION as arg of the bundle target (e.g make bundle VERSION=0.0.2) # - use environment variables to overwrite this value (e.g export VERSION=0.0.2) -VERSION ?= 0.8.2 +VERSION ?= 0.9.0-alpha.1 # CHANNELS define the bundle channels used in the bundle. # Add a new line here if you would like to change its default config. (E.g CHANNELS = "candidate,fast,stable") diff --git a/bundle.Dockerfile b/bundle.Dockerfile index 07c3405..9fc49ea 100644 --- a/bundle.Dockerfile +++ b/bundle.Dockerfile @@ -5,8 +5,7 @@ LABEL operators.operatorframework.io.bundle.mediatype.v1=registry+v1 LABEL operators.operatorframework.io.bundle.manifests.v1=manifests/ LABEL operators.operatorframework.io.bundle.metadata.v1=metadata/ LABEL operators.operatorframework.io.bundle.package.v1=prometheus-exporter-operator -LABEL operators.operatorframework.io.bundle.channels.v1=alpha,stable -LABEL operators.operatorframework.io.bundle.channel.default.v1=alpha +LABEL operators.operatorframework.io.bundle.channels.v1=alpha LABEL operators.operatorframework.io.metrics.builder=operator-sdk-v1.24.0 LABEL operators.operatorframework.io.metrics.mediatype.v1=metrics+v1 LABEL operators.operatorframework.io.metrics.project_layout=ansible.sdk.operatorframework.io/v1 diff --git a/bundle/manifests/prometheus-exporter-operator.clusterserviceversion.yaml b/bundle/manifests/prometheus-exporter-operator.clusterserviceversion.yaml index 41d25a8..999844a 100644 --- a/bundle/manifests/prometheus-exporter-operator.clusterserviceversion.yaml +++ b/bundle/manifests/prometheus-exporter-operator.clusterserviceversion.yaml @@ -34,7 +34,7 @@ metadata: operators.operatorframework.io/project_layout: ansible.sdk.operatorframework.io/v1 repository: https://github.com/3scale-ops/prometheus-exporter-operator support: Red Hat, Inc. - name: prometheus-exporter-operator.v0.8.2 + name: prometheus-exporter-operator.v0.9.0-alpha.1 namespace: placeholder spec: apiservicedefinitions: {} @@ -125,7 +125,7 @@ spec: valueFrom: fieldRef: fieldPath: metadata.annotations['olm.targetNamespaces'] - image: quay.io/3scale/prometheus-exporter-operator:v0.8.2 + image: quay.io/3scale/prometheus-exporter-operator:v0.9.0-alpha.1 livenessProbe: httpGet: path: /healthz @@ -310,4 +310,4 @@ spec: provider: name: Red Hat url: https://www.redhat.com - version: 0.8.2 + version: 0.9.0-alpha.1 diff --git a/bundle/metadata/annotations.yaml b/bundle/metadata/annotations.yaml index 5639002..aabb48c 100644 --- a/bundle/metadata/annotations.yaml +++ b/bundle/metadata/annotations.yaml @@ -4,8 +4,7 @@ annotations: operators.operatorframework.io.bundle.manifests.v1: manifests/ operators.operatorframework.io.bundle.metadata.v1: metadata/ operators.operatorframework.io.bundle.package.v1: prometheus-exporter-operator - operators.operatorframework.io.bundle.channels.v1: alpha,stable - operators.operatorframework.io.bundle.channel.default.v1: alpha + operators.operatorframework.io.bundle.channels.v1: alpha operators.operatorframework.io.metrics.builder: operator-sdk-v1.24.0 operators.operatorframework.io.metrics.mediatype.v1: metrics+v1 operators.operatorframework.io.metrics.project_layout: ansible.sdk.operatorframework.io/v1 diff --git a/catalog/prometheus-exporter-operator/alpha-channel.yaml b/catalog/prometheus-exporter-operator/alpha-channel.yaml index f9ee502..cedfbe1 100644 --- a/catalog/prometheus-exporter-operator/alpha-channel.yaml +++ b/catalog/prometheus-exporter-operator/alpha-channel.yaml @@ -17,14 +17,8 @@ entries: replaces: prometheus-exporter-operator.v0.7.0 - name: prometheus-exporter-operator.v0.8.1 replaces: prometheus-exporter-operator.v0.8.0 - - name: prometheus-exporter-operator.v0.8.2-alpha.1 + - name: prometheus-exporter-operator.v0.9.0-alpha.1 replaces: prometheus-exporter-operator.v0.8.1 - - name: prometheus-exporter-operator.v0.8.2-alpha.2 - replaces: prometheus-exporter-operator.v0.8.2-alpha.1 - - name: prometheus-exporter-operator.v0.8.2-alpha.3 - replaces: prometheus-exporter-operator.v0.8.2-alpha.2 - - name: prometheus-exporter-operator.v0.8.2 - replaces: prometheus-exporter-operator.v0.8.2-alpha.3 name: alpha package: prometheus-exporter-operator schema: olm.channel diff --git a/catalog/prometheus-exporter-operator/objects/prometheus-exporter-operator.v0.8.2-alpha.1.clusterserviceversion.yaml b/catalog/prometheus-exporter-operator/objects/prometheus-exporter-operator.v0.8.2-alpha.1.clusterserviceversion.yaml deleted file mode 100644 index 9c79240..0000000 --- a/catalog/prometheus-exporter-operator/objects/prometheus-exporter-operator.v0.8.2-alpha.1.clusterserviceversion.yaml +++ /dev/null @@ -1,32 +0,0 @@ ---- -image: quay.io/3scale/prometheus-exporter-operator-bundle:v0.8.2-alpha.1 -name: prometheus-exporter-operator.v0.8.2-alpha.1 -package: prometheus-exporter-operator -properties: -- type: olm.gvk - value: - group: monitoring.3scale.net - kind: PrometheusExporter - version: v1alpha1 -- type: olm.package - value: - packageName: prometheus-exporter-operator - version: 0.8.2-alpha.1 -- type: olm.bundle.object - value: - data: {"apiVersion":"apiextensions.k8s.io/v1","kind":"CustomResourceDefinition","metadata":{"creationTimestamp":null,"name":"prometheusexporters.monitoring.3scale.net"},"spec":{"group":"monitoring.3scale.net","names":{"kind":"PrometheusExporter","listKind":"PrometheusExporterList","plural":"prometheusexporters","singular":"prometheusexporter"},"scope":"Namespaced","versions":[{"name":"v1alpha1","schema":{"openAPIV3Schema":{"description":"PrometheusExporter is the Schema for the prometheusexporters API","properties":{"apiVersion":{"description":"APIVersion defines the versioned schema of this representation of an object. Servers should convert recognized schemas to the latest internal value, and may reject unrecognized values. More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#resources","type":"string"},"kind":{"description":"Kind is a string value representing the REST resource this object represents. Servers may infer this from the endpoint the client submits requests to. Cannot be updated. In CamelCase. More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds","type":"string"},"metadata":{"type":"object"},"spec":{"description":"Spec defines the desired state of PrometheusExporter","properties":{"awsCredentialsSecretName":{"description":"For cloudwatch exporter, the Secret name containing AWS IAM credentials (AWS_ACCESS_KEY_ID / AWS_SECRET_ACCESS_KEY)","type":"string"},"configurationConfigmapName":{"description":"For cloudwatch exporter, the ConfigMap name containing Cloudwatch config.yml (Services, Dimensions, Tags used for autodiscovery...). For probe exporter, ConfigMap name containing blackbox modules configuration.","type":"string"},"configurationSecretName":{"description":"For probe exporter, optional Secret name containing blackbox modules configuration. Replaces usage of configurationConfigmapName (in case config includes sensitive data and so you prefer to use a Secret)","type":"string"},"dbCheckKeys":{"description":"For redis exporter, the optional redis keys to monitor","type":"string"},"dbConnectionStringSecretName":{"description":"For mysql and postgresql exporters, the Secret name containing connection string definition (DSN)","type":"string"},"dbHost":{"description":"For redis, memcached, sphinx, manticore and es exporters, the db host to monitor","type":"string"},"dbPort":{"description":"For redis, memcached, sphinx, manticore and es exporters, the db port to monitor","type":"integer"},"extraLabel":{"properties":{"key":{"description":"Add extra label key to all created resources","type":"string"},"value":{"description":"Add extra label value to all created resources","type":"string"}},"type":"object"},"grafanaDashboard":{"properties":{"apiVersion":{"description":"GrafanaDashboard custom resource apiVersion","enum":["v1alpha1","v1beta1"],"type":"string"},"enabled":{"description":"Create (true) or not (false) GrafanaDashboard object","type":"boolean"},"label":{"properties":{"key":{"description":"Label key used by grafana-operator for dashboard discovery","type":"string"},"value":{"description":"Label value used by grafana-operator for dashboard discovery","type":"string"}},"type":"object"}},"type":"object"},"image":{"properties":{"name":{"description":"Prometheus exporter image name","type":"string"},"version":{"description":"Prometheus exporter image tag version","type":"string"}},"type":"object"},"livenessProbe":{"description":"Readiness probe","properties":{"failureThreshold":{"description":"Minimum consecutive failures for the probe to be considered failed after having succeeded","format":"int32","type":"integer"},"periodSeconds":{"description":"How often (in seconds) to perform the probe","format":"int32","type":"integer"},"successThreshold":{"description":"Minimum consecutive successes for the probe to be considered successful after having failed","format":"int32","type":"integer"},"timeoutSeconds":{"description":"Number of seconds after which the probe times out","format":"int32","type":"integer"}},"type":"object"},"logLevel":{"description":"For probe exporter, log level of the exporter","enum":["info","debug"],"type":"string"},"nodeSelector":{"additionalProperties":{"type":"string"},"description":"Map of nodeSelector key-value pairs","type":"object"},"port":{"description":"Prometheus exporter port where metrics are available","type":"integer"},"probeTargetLabel":{"description":"For probe exporter, specifies the Prometheus label used to distinguish among monitored targets on grafana dashboard","type":"string"},"readinessProbe":{"description":"Readiness probe","properties":{"failureThreshold":{"description":"Minimum consecutive failures for the probe to be considered failed after having succeeded","format":"int32","type":"integer"},"periodSeconds":{"description":"How often (in seconds) to perform the probe","format":"int32","type":"integer"},"successThreshold":{"description":"Minimum consecutive successes for the probe to be considered successful after having failed","format":"int32","type":"integer"},"timeoutSeconds":{"description":"Number of seconds after which the probe times out","format":"int32","type":"integer"}},"type":"object"},"resources":{"description":"Prometheus exporter resources required.","properties":{"limits":{"additionalProperties":{"anyOf":[{"type":"integer"},{"type":"string"}],"pattern":"^(\\+|-)?(([0-9]+(\\.[0-9]*)?)|(\\.[0-9]+))(([KMGTPE]i)|[numkMGTPE]|([eE](\\+|-)?(([0-9]+(\\.[0-9]*)?)|(\\.[0-9]+))))?$","x-kubernetes-int-or-string":true},"description":"Limits describes the maximum amount of compute resources allowed. More info: https://kubernetes.io/docs/concepts/configuration/manage-compute-resources-container/","type":"object"},"requests":{"additionalProperties":{"anyOf":[{"type":"integer"},{"type":"string"}],"pattern":"^(\\+|-)?(([0-9]+(\\.[0-9]*)?)|(\\.[0-9]+))(([KMGTPE]i)|[numkMGTPE]|([eE](\\+|-)?(([0-9]+(\\.[0-9]*)?)|(\\.[0-9]+))))?$","x-kubernetes-int-or-string":true},"description":"Requests describes the minimum amount of compute resources required. If Requests is omitted for a container, it defaults to Limits if that is explicitly specified, otherwise to an implementation-defined value. More info: https://kubernetes.io/docs/concepts/configuration/manage-compute-resources-container/","type":"object"}},"type":"object"},"sendgridAccumulatedMetrics":{"description":"For sendgrid exporter, configures monthly acumulated metrics (true) instead of daily metrics (false)","type":"boolean"},"sendgridCredentialsSecretName":{"description":"For sendgrid exporter, Secret name containing Sendgrid username and apikey","type":"string"},"sendgridLocation":{"description":"For sendgrid exporter, configures time zone","type":"string"},"sendgridTimeOffset":{"description":"For sendgrid exporter, specifies the offset in seconds from UTC as an integer (needed along with location)","type":"integer"},"serviceMonitor":{"properties":{"enabled":{"description":"Create (true) or not (false) ServiceMonitor object","type":"boolean"},"interval":{"description":"Prometheus scrape interval (example 30s)","type":"string"}},"type":"object"},"type":{"description":"Supported prometheus-exporter types","enum":["memcached","redis","mysql","postgresql","sphinx","manticore","es","cloudwatch","probe","sendgrid"],"type":"string"}},"required":["type"],"type":"object","x-kubernetes-preserve-unknown-fields":true},"status":{"description":"Status defines the observed state of PrometheusExporter","type":"object","x-kubernetes-preserve-unknown-fields":true}},"type":"object"}},"served":true,"storage":true,"subresources":{"status":{}}}]},"status":{"acceptedNames":{"kind":"","plural":""},"conditions":null,"storedVersions":null}} -- type: olm.bundle.object - value: - data: eyJhcGlWZXJzaW9uIjoibW9uaXRvcmluZy5jb3Jlb3MuY29tL3YxIiwia2luZCI6IlNlcnZpY2VNb25pdG9yIiwibWV0YWRhdGEiOnsibGFiZWxzIjp7ImNvbnRyb2wtcGxhbmUiOiJjb250cm9sbGVyLW1hbmFnZXIifSwibmFtZSI6InByb21ldGhldXMtZXhwb3J0ZXItb3BlcmF0b3ItY29udHJvbGxlci1tYW5hZ2VyLW1ldHJpY3MtbW9uaXRvciJ9LCJzcGVjIjp7ImVuZHBvaW50cyI6W3sicGF0aCI6Ii9tZXRyaWNzIiwicG9ydCI6Imh0dHAifV0sInNlbGVjdG9yIjp7Im1hdGNoTGFiZWxzIjp7ImNvbnRyb2wtcGxhbmUiOiJjb250cm9sbGVyLW1hbmFnZXIifX19fQ== -- type: olm.bundle.object - value: - data: eyJhcGlWZXJzaW9uIjoidjEiLCJraW5kIjoiU2VydmljZSIsIm1ldGFkYXRhIjp7ImNyZWF0aW9uVGltZXN0YW1wIjpudWxsLCJsYWJlbHMiOnsiY29udHJvbC1wbGFuZSI6ImNvbnRyb2xsZXItbWFuYWdlciJ9LCJuYW1lIjoicHJvbWV0aGV1cy1leHBvcnRlci1vcGVyYXRvci1jb250cm9sbGVyLW1hbmFnZXItbWV0cmljcy1zZXJ2aWNlIn0sInNwZWMiOnsicG9ydHMiOlt7Im5hbWUiOiJodHRwIiwicG9ydCI6ODA4MCwidGFyZ2V0UG9ydCI6Imh0dHAifV0sInNlbGVjdG9yIjp7ImNvbnRyb2wtcGxhbmUiOiJjb250cm9sbGVyLW1hbmFnZXIifX0sInN0YXR1cyI6eyJsb2FkQmFsYW5jZXIiOnt9fX0= -- type: olm.bundle.object - value: - data: {"apiVersion":"operators.coreos.com/v1alpha1","kind":"ClusterServiceVersion","metadata":{"annotations":{"alm-examples":"[\n  {\n    \"apiVersion\": \"monitoring.3scale.net/v1alpha1\",\n    \"kind\": \"PrometheusExporter\",\n    \"metadata\": {\n      \"name\": \"example-memcached\"\n    },\n    \"spec\": {\n      \"dbHost\": \"your-memcached-host\",\n      \"dbPort\": 11211,\n      \"grafanaDashboard\": {\n        \"label\": {\n          \"key\": \"discovery\",\n          \"value\": \"enabled\"\n        }\n      },\n      \"type\": \"memcached\"\n    }\n  }\n]","capabilities":"Deep Insights","categories":"Monitoring","certified":"false","containerImage":"quay.io/3scale/prometheus-exporter-operator","createdAt":"2020-06-08 00:00:00","description":"Operator to setup 3rd party prometheus exporters, with a collection of grafana dashboards","operators.operatorframework.io/builder":"operator-sdk-v1.24.0","operators.operatorframework.io/project_layout":"ansible.sdk.operatorframework.io/v1","repository":"https://github.com/3scale-ops/prometheus-exporter-operator","support":"Red Hat, Inc."},"name":"prometheus-exporter-operator.v0.8.2-alpha.1","namespace":"placeholder"},"spec":{"apiservicedefinitions":{},"customresourcedefinitions":{"owned":[{"description":"Configures a prometheus exporter to monitor a memcached instance","displayName":"PrometheusExporter","kind":"PrometheusExporter","name":"prometheusexporters.monitoring.3scale.net","version":"v1alpha1"}]},"description":"A Kubernetes Operator based on the Operator SDK to centralize the setup of 3rd party prometheus exporters on **Kubernetes/OpenShift**, with a collection of grafana dashboards.\n\nBy just providing a few parameters like *dbHost* or *dbPort* (operator manage the container image, port, argument, command, volumes... and also prometheus `ServiceMonitor` and `GrafanaDashboard` k8s objects), you can setup different prometheus exporters to monitor:\n* The **internals from different databases**\n* **HTTP/TCP endpoints** (availability, latency, SSL/TLS certificate expiration...)\n* Any available **cloudwatch metric from any AWS Service**\n* Sendgrid email statistics (delivered, bounces, errors, spam...)\n\nCurrent prometheus exporters types supported, managed by same prometheus-exporter-operator:\n* memcached\n* redis\n* mysql\n* postgresql\n* sphinx\n* manticore\n* es (elasticsearch)\n* cloudwatch\n* probe (blackbox)\n* sendgrid\n\nThe operator manages the lifecycle of the following objects:\n* Deployment (one per CR)\n* Service (one per CR)\n* ServiceMonitor (optional, one per CR)\n* GrafanaDashboard (optional, one per Namespace)\n\n### Documentation\nDocumentation can be found on our [website](https://github.com/3scale-ops/prometheus-exporter-operator#documentation).\n\n### Getting help\nIf you encounter any issues while using operator, you can create an issue on our [website](https://github.com/3scale-ops/prometheus-exporter-operator) for bugs, enhancements, or other requests.\n\n### Contributing\nYou can contribute by:\n* Raising any issues you find using Prometheus Exporter Operator\n* Fixing issues by opening [Pull Requests](https://github.com/3scale-ops/prometheus-exporter-operator/pulls)\n* Submitting a patch or opening a PR\n* Improving [documentation](https://github.com/3scale-ops/prometheus-exporter-operator)\n* Talking about Prometheus Exporter Operator\nAll bugs, tasks or enhancements are tracked as [GitHub issues](https://github.com/3scale-ops/prometheus-exporter-operator/issues).\n\n### License\nPrometheus Exporter Operator is licensed under the [Apache 2.0 license](https://github.com/3scale-ops/prometheus-exporter-operator/blob/main/LICENSE)\n","displayName":"Prometheus Exporter Operator","icon":[{"base64data":"PD94bWwgdmVyc2lvbj0iMS4wIiBlbmNvZGluZz0iVVRGLTgiIHN0YW5kYWxvbmU9Im5vIj8+CjxzdmcKICAgeG1sbnM6ZGM9Imh0dHA6Ly9wdXJsLm9yZy9kYy9lbGVtZW50cy8xLjEvIgogICB4bWxuczpjYz0iaHR0cDovL2NyZWF0aXZlY29tbW9ucy5vcmcvbnMjIgogICB4bWxuczpyZGY9Imh0dHA6Ly93d3cudzMub3JnLzE5OTkvMDIvMjItcmRmLXN5bnRheC1ucyMiCiAgIHhtbG5zOnN2Zz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciCiAgIHhtbG5zPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2ZyIKICAgeG1sbnM6c29kaXBvZGk9Imh0dHA6Ly9zb2RpcG9kaS5zb3VyY2Vmb3JnZS5uZXQvRFREL3NvZGlwb2RpLTAuZHRkIgogICB4bWxuczppbmtzY2FwZT0iaHR0cDovL3d3dy5pbmtzY2FwZS5vcmcvbmFtZXNwYWNlcy9pbmtzY2FwZSIKICAgaW5rc2NhcGU6dmVyc2lvbj0iMC45Mi40ICh1bmtub3duKSIKICAgaW5rc2NhcGU6ZXhwb3J0LXlkcGk9IjQxMC4xOSIKICAgaW5rc2NhcGU6ZXhwb3J0LXhkcGk9IjQxMC4xOSIKICAgaW5rc2NhcGU6ZXhwb3J0LWZpbGVuYW1lPSIvVXNlcnMvcmFlbC9Eb3dubG9hZHMvcHJvbWV0aGV1cy1leHBvcnRlci5wbmciCiAgIHNvZGlwb2RpOmRvY25hbWU9InByb21ldGhldXMtZXhwb3J0ZXItM3NjYWxlLW5ldy5zdmciCiAgIGlkPSJzdmc4NDMiCiAgIHByZXNlcnZlQXNwZWN0UmF0aW89InhNaWRZTWlkIG1lZXQiCiAgIHZpZXdCb3g9IjAgMCA3MzYuNDI1NzggNjE5Ljc0ODQ3IgogICBoZWlnaHQ9IjYxOS43NDg0N3B0IgogICB3aWR0aD0iNzM2LjQyNTc4cHQiCiAgIHZlcnNpb249IjEuMCI+CiAgPG1ldGFkYXRhCiAgICAgaWQ9Im1ldGFkYXRhODQ5Ij4KICAgIDxyZGY6UkRGPgogICAgICA8Y2M6V29yawogICAgICAgICByZGY6YWJvdXQ9IiI+CiAgICAgICAgPGRjOmZvcm1hdD5pbWFnZS9zdmcreG1sPC9kYzpmb3JtYXQ+CiAgICAgICAgPGRjOnR5cGUKICAgICAgICAgICByZGY6cmVzb3VyY2U9Imh0dHA6Ly9wdXJsLm9yZy9kYy9kY21pdHlwZS9TdGlsbEltYWdlIiAvPgogICAgICA8L2NjOldvcms+CiAgICA8L3JkZjpSREY+CiAgPC9tZXRhZGF0YT4KICA8ZGVmcwogICAgIGlkPSJkZWZzODQ3IiAvPgogIDxzb2RpcG9kaTpuYW1lZHZpZXcKICAgICBpbmtzY2FwZTpjdXJyZW50LWxheWVyPSJzdmc4NDMiCiAgICAgaW5rc2NhcGU6d2luZG93LW1heGltaXplZD0iMSIKICAgICBpbmtzY2FwZTp3aW5kb3cteT0iMjciCiAgICAgaW5rc2NhcGU6d2luZG93LXg9IjAiCiAgICAgaW5rc2NhcGU6Y3k9IjM1Ny4wNDcxNyIKICAgICBpbmtzY2FwZTpjeD0iMzc0LjM3OTciCiAgICAgaW5rc2NhcGU6em9vbT0iMC42ODc3ODIyNCIKICAgICBpbmtzY2FwZTpsb2NrZ3VpZGVzPSJ0cnVlIgogICAgIHNob3dncmlkPSJmYWxzZSIKICAgICBpZD0ibmFtZWR2aWV3ODQ1IgogICAgIGlua3NjYXBlOndpbmRvdy1oZWlnaHQ9IjEzNzYiCiAgICAgaW5rc2NhcGU6d2luZG93LXdpZHRoPSIyNTYwIgogICAgIGlua3NjYXBlOnBhZ2VzaGFkb3c9IjIiCiAgICAgaW5rc2NhcGU6cGFnZW9wYWNpdHk9IjAiCiAgICAgZ3VpZGV0b2xlcmFuY2U9IjEwIgogICAgIGdyaWR0b2xlcmFuY2U9IjEwIgogICAgIG9iamVjdHRvbGVyYW5jZT0iMTAiCiAgICAgYm9yZGVyb3BhY2l0eT0iMSIKICAgICBpbmtzY2FwZTpkb2N1bWVudC1yb3RhdGlvbj0iMCIKICAgICBib3JkZXJjb2xvcj0iIzY2NjY2NiIKICAgICBwYWdlY29sb3I9IiNmZmZmZmYiIC8+CiAgPHBhdGgKICAgICBkPSJtIDcxNS4xMDM4NiwzMS43NDg0NzYgYyAtMTEuNSw0LjkgLTI3LjMsMTEuNSAtMzUsMTQuNyAtMjAuNiw4LjcgLTUwLDIxLjEgLTY2LjUsMjguMSAtMTcuNSw3LjUgLTM4LjEsMTYuMiAtNzEuMywzMC4wMDAwMDQgLTEzLjYsNS43IC0yNC42LDEwLjcgLTI0LjUsMTEuMSAwLjIsMC4zIDEwLjcsOS40IDIzLjMsMjAuMSAxMi43LDEwLjggMjQuOSwyMS4zIDI3LjIsMjMuNCBsIDQuMywzLjkgLTYuNyw3LjUgYyAtMzEuOSwzNi4xIC04MS41LDg2LjkgLTExMi44LDExNS43IC0xMTAuNiwxMDEuNiAtMjIyLjQsMTcwLjIgLTMyNywyMDAuOCAtMTQuNyw0LjMgLTQxLjEwMDAwMSwxMC42IC00OS41MDAwMDEsMTEuOCAtMS45LDAuMyAtNi40LDEgLTEwLDEuNSAtMy42LDAuNiAtOS40LDEuNCAtMTMsMS43IC0zLjYsMC40IC05LjQsMSAtMTMsMS41IC0zLjYsMC40IC0xNC4yLDAuNyAtMjMuNywwLjYgLTkuNTAwMDAwMywtMC4xIC0xNy4xMDAwMDAzMiwwIC0xNi45MDAwMDAzMiwwLjEgMS40MDAwMDAwMiwxLjQgMzguMzAwMDAwMzIsNi45IDU2LjAwMDAwMDMyLDguMyAxMS41LDEgNTMuNTAwMDAxLDEuMyA2NC4xMDAwMDEsMC41IDIuOCwtMC4yIDkuMywtMC42IDE0LjUsLTEgNS4yLC0wLjMgMTAuNiwtMC44IDEyLC0xIDEuNCwtMC4yIDUuMiwtMC43IDguNSwtMSAzNy40LC0zLjkgODUuNiwtMTQuOSAxMjYuNSwtMjkuMSA5MS40LC0zMS42IDE3Ny4xLC04Mi45IDI2MSwtMTU2LjUgMjAuNSwtMTcuOSA2OC4xLC02NS4yIDg2LjQsLTg1LjcgbCAxMi44LC0xNC4yIDEuOCwyLjIgYyAwLjksMS4zIDEwLjgsMTQgMjEuOSwyOC4zIDExLjEsMTQuMyAyMC41LDI2LjEgMjEsMjYuMyAwLjQsMC4xIDEuNSwtMy43IDIuNSwtOC41IDAuOSwtNC45IDYuNCwtMzMuMSAxMi4xLC02Mi44IDUuNywtMjkuNyAxMi45LC02Ny4xIDE2LC04MyAxNywtODcuODAwMDA0IDE5LjYsLTEwMS43MDAwMDQgMTkuMywtMTAyLjkwMDAwNCAtMC4yLC0wLjggLTgsMiAtMjEuMyw3LjYgeiIKICAgICBpZD0icGF0aDgzNSIKICAgICBpbmtzY2FwZTpjb25uZWN0b3ItY3VydmF0dXJlPSIwIgogICAgIHN0eWxlPSJmaWxsOiM1YTVhNWE7ZmlsbC1vcGFjaXR5OjE7c3Ryb2tlOm5vbmU7c3Ryb2tlLXdpZHRoOjAuMSIgLz4KICA8cGF0aAogICAgIGQ9Im0gMjIuMjAzODU5LDE1Ni41NDg0OCBjIDIsMTUgMTkuNiw2OS42IDI1LDc3LjUgMC44LDEuMSAxLjQsMi41IDEuNCwzLjMgMCwwLjcgMiw1LjQgNC41LDEwLjQgMi41LDUgNC41LDkuNSA0LjUsOS45IDAsMS4xIDE1LjUsMjkuNCAyMyw0MS45IDkuMywxNS43IDM2LjEwMDAwMSw1NC44IDM4LjkwMDAwMSw1NyAwLjQsMC4zIDEuOCwyLjEgMy4xLDQgMS4zLDEuOSAyLjcsMy43IDMsNCAwLjMsMC4zIDIuNCwyLjcgNC41LDUuNSAyLjIsMi43IDQuMiw1LjIgNC41LDUuNSAwLjMsMC4zIDMuNCwzLjkgNyw4IDExLjgsMTMuNyAxNy4yLDE5LjMgMzguOCw0MC43IDExLjgsMTEuNyAyMi4xLDIxLjMgMjIuNywyMS4zIDEuNywwIDYzLjksLTM0LjcgNjQuMywtMzUuOCAwLjEsLTAuNSAtNC44LC00IC0xMSwtNy43IC04MS42LC00OS4zIC0xNTYuNjAwMDAxLC0xMTcgLTE5OC41MDAwMDEsLTE3OS41IC0xNS4zLC0yMi44IC0yNywtNDUuMyAtMzUuMiwtNjcuNSAtMSwtMi43IC0xLC0yLjYgLTAuNSwxLjUgeiIKICAgICBpZD0icGF0aDgzNyIKICAgICBpbmtzY2FwZTpjb25uZWN0b3ItY3VydmF0dXJlPSIwIgogICAgIHN0eWxlPSJmaWxsOiNlYzdhMDg7ZmlsbC1vcGFjaXR5OjE7c3Ryb2tlOm5vbmU7c3Ryb2tlLXdpZHRoOjAuMSIgLz4KICA8cGF0aAogICAgIGQ9Im0gMzE4LjMwMzg2LDQ3OS40NDg0OCBjIC0yNi44LDkuNyAtNDguNywxNy45IC00OC43LDE4LjMgMCwxLjIgMzEuNSwyMS42IDUyLjgsMzQuMiA1NCwzMiAxMjkuOSw2NiAxOTAuMiw4NS4xIGwgOC41LDIuNyAyNywtMC42IGMgMjUuOSwtMC42IDI3LjgsLTAuOCA0OCwtNC42IDQwLjUsLTcuNiA2OC43LC0xNy45IDg5LjIsLTMyLjYgNi4xLC00LjMgMTAuOSwtOC4xIDEwLjcsLTguNCAtMS40LC0xLjQgLTUyLjgsLTE2IC04OS40LC0yNS40IC0xNCwtMy43IC0yNi40LC03IC0yNy41LC03LjUgLTEuMSwtMC41IC02LjEsLTEuOCAtMTEuMSwtMyAtMTAsLTIuMyAtNjQuNCwtMjAuMyAtOTAuNywtMzAgLTMwLjgsLTExLjQgLTcyLjIsLTI4LjUgLTEwNC43LC00My40IGwgLTUuNiwtMi41IHoiCiAgICAgaWQ9InBhdGg4MzkiCiAgICAgaW5rc2NhcGU6Y29ubmVjdG9yLWN1cnZhdHVyZT0iMCIKICAgICBzdHlsZT0iZmlsbDojZWM3YTA4O2ZpbGwtb3BhY2l0eToxO3N0cm9rZTpub25lO3N0cm9rZS13aWR0aDowLjEiIC8+Cjwvc3ZnPgo=","mediatype":"image/svg+xml"}],"install":{"spec":{"deployments":[{"label":{"control-plane":"controller-manager"},"name":"prometheus-exporter-operator-controller-manager","spec":{"replicas":1,"selector":{"matchLabels":{"control-plane":"controller-manager"}},"strategy":{},"template":{"metadata":{"annotations":{"kubectl.kubernetes.io/default-container":"manager"},"labels":{"control-plane":"controller-manager"}},"spec":{"containers":[{"args":["--health-probe-bind-address=:6789","--metrics-bind-address=0.0.0.0:8080","--leader-elect","--leader-election-id=prometheus-exporter-operator"],"env":[{"name":"ANSIBLE_GATHERING","value":"explicit"},{"name":"WATCH_NAMESPACE","valueFrom":{"fieldRef":{"fieldPath":"metadata.annotations['olm.targetNamespaces']"}}}],"image":"quay.io/3scale/prometheus-exporter-operator:v0.8.2-alpha.1","livenessProbe":{"httpGet":{"path":"/healthz","port":6789},"initialDelaySeconds":30,"periodSeconds":20,"timeoutSeconds":5},"name":"manager","ports":[{"containerPort":8080,"name":"http"}],"readinessProbe":{"httpGet":{"path":"/readyz","port":6789},"initialDelaySeconds":5,"periodSeconds":10,"timeoutSeconds":5},"resources":{"limits":{"cpu":"1","memory":"1Gi"},"requests":{"cpu":"10m","memory":"128Mi"}},"securityContext":{"allowPrivilegeEscalation":false,"capabilities":{"drop":["ALL"]}}}],"securityContext":{"runAsNonRoot":true},"serviceAccountName":"prometheus-exporter-operator-controller-manager","terminationGracePeriodSeconds":10}}}}],"permissions":[{"rules":[{"apiGroups":[""],"resources":["configmaps"],"verbs":["get","list","watch","create","update","patch","delete"]},{"apiGroups":["coordination.k8s.io"],"resources":["leases"],"verbs":["get","list","watch","create","update","patch","delete"]},{"apiGroups":[""],"resources":["events"],"verbs":["create","patch"]},{"apiGroups":["apps"],"resources":["deployments"],"verbs":["create","delete","get","list","patch","update","watch"]},{"apiGroups":[""],"resources":["services"],"verbs":["create","delete","get","list","patch","update","watch"]},{"apiGroups":[""],"resources":["secrets"],"verbs":["get","list","watch"]},{"apiGroups":[""],"resources":["configmaps"],"verbs":["get","list","watch"]},{"apiGroups":["monitoring.coreos.com"],"resources":["servicemonitors"],"verbs":["create","delete","get","list","patch","update","watch"]},{"apiGroups":["integreatly.org","grafana.integreatly.org"],"resources":["grafanadashboards"],"verbs":["create","delete","get","list","patch","update","watch"]},{"apiGroups":["monitoring.3scale.net"],"resources":["prometheusexporters","prometheusexporters/status","prometheusexporters/finalizers"],"verbs":["create","delete","get","list","patch","update","watch"]}],"serviceAccountName":"prometheus-exporter-operator-controller-manager"}]},"strategy":"deployment"},"installModes":[{"supported":true,"type":"OwnNamespace"},{"supported":true,"type":"SingleNamespace"},{"supported":true,"type":"MultiNamespace"},{"supported":true,"type":"AllNamespaces"}],"keywords":["monitoring","metrics","observability","prometheus","exporter","grafana","mysql","postgresql","memcached","redis","sphinx","elasticsearch","cloudwatch","blackbox","sendgrid","manticore"],"links":[{"name":"GitHub","url":"https://github.com/3scale-ops/prometheus-exporter-operator"}],"maintainers":[{"email":"3scale-operations@redhat.com","name":"3scale Ops"}],"maturity":"alpha","provider":{"name":"Red Hat","url":"https://www.redhat.com"},"version":"0.8.2-alpha.1"}} -relatedImages: -- image: quay.io/3scale/prometheus-exporter-operator-bundle:v0.8.2-alpha.1 - name: "" -- image: quay.io/3scale/prometheus-exporter-operator:v0.8.2-alpha.1 - name: "" -schema: olm.bundle diff --git a/catalog/prometheus-exporter-operator/objects/prometheus-exporter-operator.v0.8.2-alpha.3.clusterserviceversion.yaml b/catalog/prometheus-exporter-operator/objects/prometheus-exporter-operator.v0.8.2-alpha.3.clusterserviceversion.yaml deleted file mode 100644 index b7c827b..0000000 --- a/catalog/prometheus-exporter-operator/objects/prometheus-exporter-operator.v0.8.2-alpha.3.clusterserviceversion.yaml +++ /dev/null @@ -1,32 +0,0 @@ ---- -image: quay.io/3scale/prometheus-exporter-operator-bundle:v0.8.2-alpha.3 -name: prometheus-exporter-operator.v0.8.2-alpha.3 -package: prometheus-exporter-operator -properties: -- type: olm.gvk - value: - group: monitoring.3scale.net - kind: PrometheusExporter - version: v1alpha1 -- type: olm.package - value: - packageName: prometheus-exporter-operator - version: 0.8.2-alpha.3 -- type: olm.bundle.object - value: - data: {"apiVersion":"apiextensions.k8s.io/v1","kind":"CustomResourceDefinition","metadata":{"creationTimestamp":null,"name":"prometheusexporters.monitoring.3scale.net"},"spec":{"group":"monitoring.3scale.net","names":{"kind":"PrometheusExporter","listKind":"PrometheusExporterList","plural":"prometheusexporters","singular":"prometheusexporter"},"scope":"Namespaced","versions":[{"name":"v1alpha1","schema":{"openAPIV3Schema":{"description":"PrometheusExporter is the Schema for the prometheusexporters API","properties":{"apiVersion":{"description":"APIVersion defines the versioned schema of this representation of an object. Servers should convert recognized schemas to the latest internal value, and may reject unrecognized values. More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#resources","type":"string"},"kind":{"description":"Kind is a string value representing the REST resource this object represents. Servers may infer this from the endpoint the client submits requests to. Cannot be updated. In CamelCase. More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds","type":"string"},"metadata":{"type":"object"},"spec":{"description":"Spec defines the desired state of PrometheusExporter","properties":{"awsCredentialsSecretName":{"description":"For cloudwatch exporter, the Secret name containing AWS IAM credentials (AWS_ACCESS_KEY_ID / AWS_SECRET_ACCESS_KEY)","type":"string"},"configurationConfigmapName":{"description":"For cloudwatch exporter, the ConfigMap name containing Cloudwatch config.yml (Services, Dimensions, Tags used for autodiscovery...). For probe exporter, ConfigMap name containing blackbox modules configuration.","type":"string"},"configurationSecretName":{"description":"For probe exporter, optional Secret name containing blackbox modules configuration. Replaces usage of configurationConfigmapName (in case config includes sensitive data and so you prefer to use a Secret)","type":"string"},"dbCheckKeys":{"description":"For redis exporter, the optional redis keys to monitor","type":"string"},"dbConnectionStringSecretName":{"description":"For mysql and postgresql exporters, the Secret name containing connection string definition (DSN)","type":"string"},"dbHost":{"description":"For redis, memcached, sphinx, manticore and es exporters, the db host to monitor","type":"string"},"dbPort":{"description":"For redis, memcached, sphinx, manticore and es exporters, the db port to monitor","type":"integer"},"extraLabel":{"properties":{"key":{"description":"Add extra label key to all created resources","type":"string"},"value":{"description":"Add extra label value to all created resources","type":"string"}},"type":"object"},"grafanaDashboard":{"properties":{"apiVersion":{"description":"GrafanaDashboard custom resource apiVersion","enum":["v1alpha1","v1beta1"],"type":"string"},"enabled":{"description":"Create (true) or not (false) GrafanaDashboard object","type":"boolean"},"label":{"properties":{"key":{"description":"Label key used by grafana-operator for dashboard discovery","type":"string"},"value":{"description":"Label value used by grafana-operator for dashboard discovery","type":"string"}},"type":"object"}},"type":"object"},"image":{"properties":{"name":{"description":"Prometheus exporter image name","type":"string"},"version":{"description":"Prometheus exporter image tag version","type":"string"}},"type":"object"},"livenessProbe":{"description":"Readiness probe","properties":{"failureThreshold":{"description":"Minimum consecutive failures for the probe to be considered failed after having succeeded","format":"int32","type":"integer"},"periodSeconds":{"description":"How often (in seconds) to perform the probe","format":"int32","type":"integer"},"successThreshold":{"description":"Minimum consecutive successes for the probe to be considered successful after having failed","format":"int32","type":"integer"},"timeoutSeconds":{"description":"Number of seconds after which the probe times out","format":"int32","type":"integer"}},"type":"object"},"logLevel":{"description":"For probe exporter, log level of the exporter","enum":["info","debug"],"type":"string"},"nodeSelector":{"additionalProperties":{"type":"string"},"description":"Map of nodeSelector key-value pairs","type":"object"},"port":{"description":"Prometheus exporter port where metrics are available","type":"integer"},"probeTargetLabel":{"description":"For probe exporter, specifies the Prometheus label used to distinguish among monitored targets on grafana dashboard","type":"string"},"readinessProbe":{"description":"Readiness probe","properties":{"failureThreshold":{"description":"Minimum consecutive failures for the probe to be considered failed after having succeeded","format":"int32","type":"integer"},"periodSeconds":{"description":"How often (in seconds) to perform the probe","format":"int32","type":"integer"},"successThreshold":{"description":"Minimum consecutive successes for the probe to be considered successful after having failed","format":"int32","type":"integer"},"timeoutSeconds":{"description":"Number of seconds after which the probe times out","format":"int32","type":"integer"}},"type":"object"},"resources":{"description":"Prometheus exporter resources required.","properties":{"limits":{"additionalProperties":{"anyOf":[{"type":"integer"},{"type":"string"}],"pattern":"^(\\+|-)?(([0-9]+(\\.[0-9]*)?)|(\\.[0-9]+))(([KMGTPE]i)|[numkMGTPE]|([eE](\\+|-)?(([0-9]+(\\.[0-9]*)?)|(\\.[0-9]+))))?$","x-kubernetes-int-or-string":true},"description":"Limits describes the maximum amount of compute resources allowed. More info: https://kubernetes.io/docs/concepts/configuration/manage-compute-resources-container/","type":"object"},"requests":{"additionalProperties":{"anyOf":[{"type":"integer"},{"type":"string"}],"pattern":"^(\\+|-)?(([0-9]+(\\.[0-9]*)?)|(\\.[0-9]+))(([KMGTPE]i)|[numkMGTPE]|([eE](\\+|-)?(([0-9]+(\\.[0-9]*)?)|(\\.[0-9]+))))?$","x-kubernetes-int-or-string":true},"description":"Requests describes the minimum amount of compute resources required. If Requests is omitted for a container, it defaults to Limits if that is explicitly specified, otherwise to an implementation-defined value. More info: https://kubernetes.io/docs/concepts/configuration/manage-compute-resources-container/","type":"object"}},"type":"object"},"sendgridAccumulatedMetrics":{"description":"For sendgrid exporter, configures monthly acumulated metrics (true) instead of daily metrics (false)","type":"boolean"},"sendgridCredentialsSecretName":{"description":"For sendgrid exporter, Secret name containing Sendgrid username and apikey","type":"string"},"sendgridLocation":{"description":"For sendgrid exporter, configures time zone","type":"string"},"sendgridTimeOffset":{"description":"For sendgrid exporter, specifies the offset in seconds from UTC as an integer (needed along with location)","type":"integer"},"serviceMonitor":{"properties":{"enabled":{"description":"Create (true) or not (false) ServiceMonitor object","type":"boolean"},"interval":{"description":"Prometheus scrape interval (example 30s)","type":"string"}},"type":"object"},"tolerations":{"description":"Tolerations allow the pods to schedule onto nodes with matching taints","items":{"description":"The pod this Toleration is attached to tolerates any taint that matches the triple \u003ckey,value,effect\u003e using the matching operator \u003coperator\u003e.","properties":{"effect":{"description":"Effect indicates the taint effect to match. Empty means match all taint effects. When specified, allowed values are NoSchedule, PreferNoSchedule and NoExecute.","type":"string"},"key":{"description":"Key is the taint key that the toleration applies to. Empty means match all taint keys. If the key is empty, operator must be Exists; this combination means to match all values and all keys.","type":"string"},"operator":{"description":"Operator represents a key's relationship to the value. Valid operators are Exists and Equal. Defaults to Equal. Exists is equivalent to wildcard for value, so that a pod can tolerate all taints of a particular category.","type":"string"},"tolerationSeconds":{"description":"TolerationSeconds represents the period of time the toleration (which must be of effect NoExecute, otherwise this field is ignored) tolerates the taint. By default, it is not set, which means tolerate the taint forever (do not evict). Zero and negative values will be treated as 0 (evict immediately) by the system.","format":"int64","type":"integer"},"value":{"description":"Value is the taint value the toleration matches to. If the operator is Exists, the value should be empty, otherwise just a regular string.","type":"string"}},"type":"object"},"type":"array"},"type":{"description":"Supported prometheus-exporter types","enum":["memcached","redis","mysql","postgresql","sphinx","manticore","es","cloudwatch","probe","sendgrid"],"type":"string"}},"required":["type"],"type":"object","x-kubernetes-preserve-unknown-fields":true},"status":{"description":"Status defines the observed state of PrometheusExporter","type":"object","x-kubernetes-preserve-unknown-fields":true}},"type":"object"}},"served":true,"storage":true,"subresources":{"status":{}}}]},"status":{"acceptedNames":{"kind":"","plural":""},"conditions":null,"storedVersions":null}} -- type: olm.bundle.object - value: - data: eyJhcGlWZXJzaW9uIjoibW9uaXRvcmluZy5jb3Jlb3MuY29tL3YxIiwia2luZCI6IlNlcnZpY2VNb25pdG9yIiwibWV0YWRhdGEiOnsibGFiZWxzIjp7ImNvbnRyb2wtcGxhbmUiOiJjb250cm9sbGVyLW1hbmFnZXIifSwibmFtZSI6InByb21ldGhldXMtZXhwb3J0ZXItb3BlcmF0b3ItY29udHJvbGxlci1tYW5hZ2VyLW1ldHJpY3MtbW9uaXRvciJ9LCJzcGVjIjp7ImVuZHBvaW50cyI6W3sicGF0aCI6Ii9tZXRyaWNzIiwicG9ydCI6Imh0dHAifV0sInNlbGVjdG9yIjp7Im1hdGNoTGFiZWxzIjp7ImNvbnRyb2wtcGxhbmUiOiJjb250cm9sbGVyLW1hbmFnZXIifX19fQ== -- type: olm.bundle.object - value: - data: eyJhcGlWZXJzaW9uIjoidjEiLCJraW5kIjoiU2VydmljZSIsIm1ldGFkYXRhIjp7ImNyZWF0aW9uVGltZXN0YW1wIjpudWxsLCJsYWJlbHMiOnsiY29udHJvbC1wbGFuZSI6ImNvbnRyb2xsZXItbWFuYWdlciJ9LCJuYW1lIjoicHJvbWV0aGV1cy1leHBvcnRlci1vcGVyYXRvci1jb250cm9sbGVyLW1hbmFnZXItbWV0cmljcy1zZXJ2aWNlIn0sInNwZWMiOnsicG9ydHMiOlt7Im5hbWUiOiJodHRwIiwicG9ydCI6ODA4MCwidGFyZ2V0UG9ydCI6Imh0dHAifV0sInNlbGVjdG9yIjp7ImNvbnRyb2wtcGxhbmUiOiJjb250cm9sbGVyLW1hbmFnZXIifX0sInN0YXR1cyI6eyJsb2FkQmFsYW5jZXIiOnt9fX0= -- type: olm.bundle.object - value: - data: {"apiVersion":"operators.coreos.com/v1alpha1","kind":"ClusterServiceVersion","metadata":{"annotations":{"alm-examples":"[\n  {\n    \"apiVersion\": \"monitoring.3scale.net/v1alpha1\",\n    \"kind\": \"PrometheusExporter\",\n    \"metadata\": {\n      \"name\": \"example-memcached\"\n    },\n    \"spec\": {\n      \"dbHost\": \"your-memcached-host\",\n      \"dbPort\": 11211,\n      \"grafanaDashboard\": {\n        \"label\": {\n          \"key\": \"discovery\",\n          \"value\": \"enabled\"\n        }\n      },\n      \"type\": \"memcached\"\n    }\n  }\n]","capabilities":"Deep Insights","categories":"Monitoring","certified":"false","containerImage":"quay.io/3scale/prometheus-exporter-operator","createdAt":"2020-06-08 00:00:00","description":"Operator to setup 3rd party prometheus exporters, with a collection of grafana dashboards","operators.operatorframework.io/builder":"operator-sdk-v1.24.0","operators.operatorframework.io/project_layout":"ansible.sdk.operatorframework.io/v1","repository":"https://github.com/3scale-ops/prometheus-exporter-operator","support":"Red Hat, Inc."},"name":"prometheus-exporter-operator.v0.8.2-alpha.3","namespace":"placeholder"},"spec":{"apiservicedefinitions":{},"customresourcedefinitions":{"owned":[{"description":"Configures a prometheus exporter to monitor a memcached instance","displayName":"PrometheusExporter","kind":"PrometheusExporter","name":"prometheusexporters.monitoring.3scale.net","version":"v1alpha1"}]},"description":"A Kubernetes Operator based on the Operator SDK to centralize the setup of 3rd party prometheus exporters on **Kubernetes/OpenShift**, with a collection of grafana dashboards.\n\nBy just providing a few parameters like *dbHost* or *dbPort* (operator manage the container image, port, argument, command, volumes... and also prometheus `ServiceMonitor` and `GrafanaDashboard` k8s objects), you can setup different prometheus exporters to monitor:\n* The **internals from different databases**\n* **HTTP/TCP endpoints** (availability, latency, SSL/TLS certificate expiration...)\n* Any available **cloudwatch metric from any AWS Service**\n* Sendgrid email statistics (delivered, bounces, errors, spam...)\n\nCurrent prometheus exporters types supported, managed by same prometheus-exporter-operator:\n* memcached\n* redis\n* mysql\n* postgresql\n* sphinx\n* manticore\n* es (elasticsearch)\n* cloudwatch\n* probe (blackbox)\n* sendgrid\n\nThe operator manages the lifecycle of the following objects:\n* Deployment (one per CR)\n* Service (one per CR)\n* ServiceMonitor (optional, one per CR)\n* GrafanaDashboard (optional, one per Namespace)\n\n### Documentation\nDocumentation can be found on our [website](https://github.com/3scale-ops/prometheus-exporter-operator#documentation).\n\n### Getting help\nIf you encounter any issues while using operator, you can create an issue on our [website](https://github.com/3scale-ops/prometheus-exporter-operator) for bugs, enhancements, or other requests.\n\n### Contributing\nYou can contribute by:\n* Raising any issues you find using Prometheus Exporter Operator\n* Fixing issues by opening [Pull Requests](https://github.com/3scale-ops/prometheus-exporter-operator/pulls)\n* Submitting a patch or opening a PR\n* Improving [documentation](https://github.com/3scale-ops/prometheus-exporter-operator)\n* Talking about Prometheus Exporter Operator\nAll bugs, tasks or enhancements are tracked as [GitHub issues](https://github.com/3scale-ops/prometheus-exporter-operator/issues).\n\n### License\nPrometheus Exporter Operator is licensed under the [Apache 2.0 license](https://github.com/3scale-ops/prometheus-exporter-operator/blob/main/LICENSE)\n","displayName":"Prometheus Exporter Operator","icon":[{"base64data":"PD94bWwgdmVyc2lvbj0iMS4wIiBlbmNvZGluZz0iVVRGLTgiIHN0YW5kYWxvbmU9Im5vIj8+CjxzdmcKICAgeG1sbnM6ZGM9Imh0dHA6Ly9wdXJsLm9yZy9kYy9lbGVtZW50cy8xLjEvIgogICB4bWxuczpjYz0iaHR0cDovL2NyZWF0aXZlY29tbW9ucy5vcmcvbnMjIgogICB4bWxuczpyZGY9Imh0dHA6Ly93d3cudzMub3JnLzE5OTkvMDIvMjItcmRmLXN5bnRheC1ucyMiCiAgIHhtbG5zOnN2Zz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciCiAgIHhtbG5zPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2ZyIKICAgeG1sbnM6c29kaXBvZGk9Imh0dHA6Ly9zb2RpcG9kaS5zb3VyY2Vmb3JnZS5uZXQvRFREL3NvZGlwb2RpLTAuZHRkIgogICB4bWxuczppbmtzY2FwZT0iaHR0cDovL3d3dy5pbmtzY2FwZS5vcmcvbmFtZXNwYWNlcy9pbmtzY2FwZSIKICAgaW5rc2NhcGU6dmVyc2lvbj0iMC45Mi40ICh1bmtub3duKSIKICAgaW5rc2NhcGU6ZXhwb3J0LXlkcGk9IjQxMC4xOSIKICAgaW5rc2NhcGU6ZXhwb3J0LXhkcGk9IjQxMC4xOSIKICAgaW5rc2NhcGU6ZXhwb3J0LWZpbGVuYW1lPSIvVXNlcnMvcmFlbC9Eb3dubG9hZHMvcHJvbWV0aGV1cy1leHBvcnRlci5wbmciCiAgIHNvZGlwb2RpOmRvY25hbWU9InByb21ldGhldXMtZXhwb3J0ZXItM3NjYWxlLW5ldy5zdmciCiAgIGlkPSJzdmc4NDMiCiAgIHByZXNlcnZlQXNwZWN0UmF0aW89InhNaWRZTWlkIG1lZXQiCiAgIHZpZXdCb3g9IjAgMCA3MzYuNDI1NzggNjE5Ljc0ODQ3IgogICBoZWlnaHQ9IjYxOS43NDg0N3B0IgogICB3aWR0aD0iNzM2LjQyNTc4cHQiCiAgIHZlcnNpb249IjEuMCI+CiAgPG1ldGFkYXRhCiAgICAgaWQ9Im1ldGFkYXRhODQ5Ij4KICAgIDxyZGY6UkRGPgogICAgICA8Y2M6V29yawogICAgICAgICByZGY6YWJvdXQ9IiI+CiAgICAgICAgPGRjOmZvcm1hdD5pbWFnZS9zdmcreG1sPC9kYzpmb3JtYXQ+CiAgICAgICAgPGRjOnR5cGUKICAgICAgICAgICByZGY6cmVzb3VyY2U9Imh0dHA6Ly9wdXJsLm9yZy9kYy9kY21pdHlwZS9TdGlsbEltYWdlIiAvPgogICAgICA8L2NjOldvcms+CiAgICA8L3JkZjpSREY+CiAgPC9tZXRhZGF0YT4KICA8ZGVmcwogICAgIGlkPSJkZWZzODQ3IiAvPgogIDxzb2RpcG9kaTpuYW1lZHZpZXcKICAgICBpbmtzY2FwZTpjdXJyZW50LWxheWVyPSJzdmc4NDMiCiAgICAgaW5rc2NhcGU6d2luZG93LW1heGltaXplZD0iMSIKICAgICBpbmtzY2FwZTp3aW5kb3cteT0iMjciCiAgICAgaW5rc2NhcGU6d2luZG93LXg9IjAiCiAgICAgaW5rc2NhcGU6Y3k9IjM1Ny4wNDcxNyIKICAgICBpbmtzY2FwZTpjeD0iMzc0LjM3OTciCiAgICAgaW5rc2NhcGU6em9vbT0iMC42ODc3ODIyNCIKICAgICBpbmtzY2FwZTpsb2NrZ3VpZGVzPSJ0cnVlIgogICAgIHNob3dncmlkPSJmYWxzZSIKICAgICBpZD0ibmFtZWR2aWV3ODQ1IgogICAgIGlua3NjYXBlOndpbmRvdy1oZWlnaHQ9IjEzNzYiCiAgICAgaW5rc2NhcGU6d2luZG93LXdpZHRoPSIyNTYwIgogICAgIGlua3NjYXBlOnBhZ2VzaGFkb3c9IjIiCiAgICAgaW5rc2NhcGU6cGFnZW9wYWNpdHk9IjAiCiAgICAgZ3VpZGV0b2xlcmFuY2U9IjEwIgogICAgIGdyaWR0b2xlcmFuY2U9IjEwIgogICAgIG9iamVjdHRvbGVyYW5jZT0iMTAiCiAgICAgYm9yZGVyb3BhY2l0eT0iMSIKICAgICBpbmtzY2FwZTpkb2N1bWVudC1yb3RhdGlvbj0iMCIKICAgICBib3JkZXJjb2xvcj0iIzY2NjY2NiIKICAgICBwYWdlY29sb3I9IiNmZmZmZmYiIC8+CiAgPHBhdGgKICAgICBkPSJtIDcxNS4xMDM4NiwzMS43NDg0NzYgYyAtMTEuNSw0LjkgLTI3LjMsMTEuNSAtMzUsMTQuNyAtMjAuNiw4LjcgLTUwLDIxLjEgLTY2LjUsMjguMSAtMTcuNSw3LjUgLTM4LjEsMTYuMiAtNzEuMywzMC4wMDAwMDQgLTEzLjYsNS43IC0yNC42LDEwLjcgLTI0LjUsMTEuMSAwLjIsMC4zIDEwLjcsOS40IDIzLjMsMjAuMSAxMi43LDEwLjggMjQuOSwyMS4zIDI3LjIsMjMuNCBsIDQuMywzLjkgLTYuNyw3LjUgYyAtMzEuOSwzNi4xIC04MS41LDg2LjkgLTExMi44LDExNS43IC0xMTAuNiwxMDEuNiAtMjIyLjQsMTcwLjIgLTMyNywyMDAuOCAtMTQuNyw0LjMgLTQxLjEwMDAwMSwxMC42IC00OS41MDAwMDEsMTEuOCAtMS45LDAuMyAtNi40LDEgLTEwLDEuNSAtMy42LDAuNiAtOS40LDEuNCAtMTMsMS43IC0zLjYsMC40IC05LjQsMSAtMTMsMS41IC0zLjYsMC40IC0xNC4yLDAuNyAtMjMuNywwLjYgLTkuNTAwMDAwMywtMC4xIC0xNy4xMDAwMDAzMiwwIC0xNi45MDAwMDAzMiwwLjEgMS40MDAwMDAwMiwxLjQgMzguMzAwMDAwMzIsNi45IDU2LjAwMDAwMDMyLDguMyAxMS41LDEgNTMuNTAwMDAxLDEuMyA2NC4xMDAwMDEsMC41IDIuOCwtMC4yIDkuMywtMC42IDE0LjUsLTEgNS4yLC0wLjMgMTAuNiwtMC44IDEyLC0xIDEuNCwtMC4yIDUuMiwtMC43IDguNSwtMSAzNy40LC0zLjkgODUuNiwtMTQuOSAxMjYuNSwtMjkuMSA5MS40LC0zMS42IDE3Ny4xLC04Mi45IDI2MSwtMTU2LjUgMjAuNSwtMTcuOSA2OC4xLC02NS4yIDg2LjQsLTg1LjcgbCAxMi44LC0xNC4yIDEuOCwyLjIgYyAwLjksMS4zIDEwLjgsMTQgMjEuOSwyOC4zIDExLjEsMTQuMyAyMC41LDI2LjEgMjEsMjYuMyAwLjQsMC4xIDEuNSwtMy43IDIuNSwtOC41IDAuOSwtNC45IDYuNCwtMzMuMSAxMi4xLC02Mi44IDUuNywtMjkuNyAxMi45LC02Ny4xIDE2LC04MyAxNywtODcuODAwMDA0IDE5LjYsLTEwMS43MDAwMDQgMTkuMywtMTAyLjkwMDAwNCAtMC4yLC0wLjggLTgsMiAtMjEuMyw3LjYgeiIKICAgICBpZD0icGF0aDgzNSIKICAgICBpbmtzY2FwZTpjb25uZWN0b3ItY3VydmF0dXJlPSIwIgogICAgIHN0eWxlPSJmaWxsOiM1YTVhNWE7ZmlsbC1vcGFjaXR5OjE7c3Ryb2tlOm5vbmU7c3Ryb2tlLXdpZHRoOjAuMSIgLz4KICA8cGF0aAogICAgIGQ9Im0gMjIuMjAzODU5LDE1Ni41NDg0OCBjIDIsMTUgMTkuNiw2OS42IDI1LDc3LjUgMC44LDEuMSAxLjQsMi41IDEuNCwzLjMgMCwwLjcgMiw1LjQgNC41LDEwLjQgMi41LDUgNC41LDkuNSA0LjUsOS45IDAsMS4xIDE1LjUsMjkuNCAyMyw0MS45IDkuMywxNS43IDM2LjEwMDAwMSw1NC44IDM4LjkwMDAwMSw1NyAwLjQsMC4zIDEuOCwyLjEgMy4xLDQgMS4zLDEuOSAyLjcsMy43IDMsNCAwLjMsMC4zIDIuNCwyLjcgNC41LDUuNSAyLjIsMi43IDQuMiw1LjIgNC41LDUuNSAwLjMsMC4zIDMuNCwzLjkgNyw4IDExLjgsMTMuNyAxNy4yLDE5LjMgMzguOCw0MC43IDExLjgsMTEuNyAyMi4xLDIxLjMgMjIuNywyMS4zIDEuNywwIDYzLjksLTM0LjcgNjQuMywtMzUuOCAwLjEsLTAuNSAtNC44LC00IC0xMSwtNy43IC04MS42LC00OS4zIC0xNTYuNjAwMDAxLC0xMTcgLTE5OC41MDAwMDEsLTE3OS41IC0xNS4zLC0yMi44IC0yNywtNDUuMyAtMzUuMiwtNjcuNSAtMSwtMi43IC0xLC0yLjYgLTAuNSwxLjUgeiIKICAgICBpZD0icGF0aDgzNyIKICAgICBpbmtzY2FwZTpjb25uZWN0b3ItY3VydmF0dXJlPSIwIgogICAgIHN0eWxlPSJmaWxsOiNlYzdhMDg7ZmlsbC1vcGFjaXR5OjE7c3Ryb2tlOm5vbmU7c3Ryb2tlLXdpZHRoOjAuMSIgLz4KICA8cGF0aAogICAgIGQ9Im0gMzE4LjMwMzg2LDQ3OS40NDg0OCBjIC0yNi44LDkuNyAtNDguNywxNy45IC00OC43LDE4LjMgMCwxLjIgMzEuNSwyMS42IDUyLjgsMzQuMiA1NCwzMiAxMjkuOSw2NiAxOTAuMiw4NS4xIGwgOC41LDIuNyAyNywtMC42IGMgMjUuOSwtMC42IDI3LjgsLTAuOCA0OCwtNC42IDQwLjUsLTcuNiA2OC43LC0xNy45IDg5LjIsLTMyLjYgNi4xLC00LjMgMTAuOSwtOC4xIDEwLjcsLTguNCAtMS40LC0xLjQgLTUyLjgsLTE2IC04OS40LC0yNS40IC0xNCwtMy43IC0yNi40LC03IC0yNy41LC03LjUgLTEuMSwtMC41IC02LjEsLTEuOCAtMTEuMSwtMyAtMTAsLTIuMyAtNjQuNCwtMjAuMyAtOTAuNywtMzAgLTMwLjgsLTExLjQgLTcyLjIsLTI4LjUgLTEwNC43LC00My40IGwgLTUuNiwtMi41IHoiCiAgICAgaWQ9InBhdGg4MzkiCiAgICAgaW5rc2NhcGU6Y29ubmVjdG9yLWN1cnZhdHVyZT0iMCIKICAgICBzdHlsZT0iZmlsbDojZWM3YTA4O2ZpbGwtb3BhY2l0eToxO3N0cm9rZTpub25lO3N0cm9rZS13aWR0aDowLjEiIC8+Cjwvc3ZnPgo=","mediatype":"image/svg+xml"}],"install":{"spec":{"deployments":[{"label":{"control-plane":"controller-manager"},"name":"prometheus-exporter-operator-controller-manager","spec":{"replicas":1,"selector":{"matchLabels":{"control-plane":"controller-manager"}},"strategy":{},"template":{"metadata":{"annotations":{"kubectl.kubernetes.io/default-container":"manager"},"labels":{"control-plane":"controller-manager"}},"spec":{"containers":[{"args":["--health-probe-bind-address=:6789","--metrics-bind-address=0.0.0.0:8080","--leader-elect","--leader-election-id=prometheus-exporter-operator"],"env":[{"name":"ANSIBLE_GATHERING","value":"explicit"},{"name":"WATCH_NAMESPACE","valueFrom":{"fieldRef":{"fieldPath":"metadata.annotations['olm.targetNamespaces']"}}}],"image":"quay.io/3scale/prometheus-exporter-operator:v0.8.2-alpha.3","livenessProbe":{"httpGet":{"path":"/healthz","port":6789},"initialDelaySeconds":30,"periodSeconds":20,"timeoutSeconds":5},"name":"manager","ports":[{"containerPort":8080,"name":"http"}],"readinessProbe":{"httpGet":{"path":"/readyz","port":6789},"initialDelaySeconds":5,"periodSeconds":10,"timeoutSeconds":5},"resources":{"limits":{"cpu":"1","memory":"1Gi"},"requests":{"cpu":"10m","memory":"128Mi"}},"securityContext":{"allowPrivilegeEscalation":false,"capabilities":{"drop":["ALL"]}}}],"securityContext":{"runAsNonRoot":true},"serviceAccountName":"prometheus-exporter-operator-controller-manager","terminationGracePeriodSeconds":10}}}}],"permissions":[{"rules":[{"apiGroups":[""],"resources":["configmaps"],"verbs":["get","list","watch","create","update","patch","delete"]},{"apiGroups":["coordination.k8s.io"],"resources":["leases"],"verbs":["get","list","watch","create","update","patch","delete"]},{"apiGroups":[""],"resources":["events"],"verbs":["create","patch"]},{"apiGroups":["apps"],"resources":["deployments"],"verbs":["create","delete","get","list","patch","update","watch"]},{"apiGroups":[""],"resources":["services"],"verbs":["create","delete","get","list","patch","update","watch"]},{"apiGroups":[""],"resources":["secrets"],"verbs":["get","list","watch"]},{"apiGroups":[""],"resources":["configmaps"],"verbs":["get","list","watch"]},{"apiGroups":["monitoring.coreos.com"],"resources":["servicemonitors"],"verbs":["create","delete","get","list","patch","update","watch"]},{"apiGroups":["integreatly.org","grafana.integreatly.org"],"resources":["grafanadashboards"],"verbs":["create","delete","get","list","patch","update","watch"]},{"apiGroups":["monitoring.3scale.net"],"resources":["prometheusexporters","prometheusexporters/status","prometheusexporters/finalizers"],"verbs":["create","delete","get","list","patch","update","watch"]}],"serviceAccountName":"prometheus-exporter-operator-controller-manager"}]},"strategy":"deployment"},"installModes":[{"supported":true,"type":"OwnNamespace"},{"supported":true,"type":"SingleNamespace"},{"supported":true,"type":"MultiNamespace"},{"supported":true,"type":"AllNamespaces"}],"keywords":["monitoring","metrics","observability","prometheus","exporter","grafana","mysql","postgresql","memcached","redis","sphinx","elasticsearch","cloudwatch","blackbox","sendgrid","manticore"],"links":[{"name":"GitHub","url":"https://github.com/3scale-ops/prometheus-exporter-operator"}],"maintainers":[{"email":"3scale-operations@redhat.com","name":"3scale Ops"}],"maturity":"alpha","provider":{"name":"Red Hat","url":"https://www.redhat.com"},"version":"0.8.2-alpha.3"}} -relatedImages: -- image: quay.io/3scale/prometheus-exporter-operator-bundle:v0.8.2-alpha.3 - name: "" -- image: quay.io/3scale/prometheus-exporter-operator:v0.8.2-alpha.3 - name: "" -schema: olm.bundle diff --git a/catalog/prometheus-exporter-operator/objects/prometheus-exporter-operator.v0.8.2.clusterserviceversion.yaml b/catalog/prometheus-exporter-operator/objects/prometheus-exporter-operator.v0.8.2.clusterserviceversion.yaml deleted file mode 100644 index 5525adc..0000000 --- a/catalog/prometheus-exporter-operator/objects/prometheus-exporter-operator.v0.8.2.clusterserviceversion.yaml +++ /dev/null @@ -1,32 +0,0 @@ ---- -image: quay.io/3scale/prometheus-exporter-operator-bundle:v0.8.2 -name: prometheus-exporter-operator.v0.8.2 -package: prometheus-exporter-operator -properties: -- type: olm.gvk - value: - group: monitoring.3scale.net - kind: PrometheusExporter - version: v1alpha1 -- type: olm.package - value: - packageName: prometheus-exporter-operator - version: 0.8.2 -- type: olm.bundle.object - value: - data: {"apiVersion":"apiextensions.k8s.io/v1","kind":"CustomResourceDefinition","metadata":{"creationTimestamp":null,"name":"prometheusexporters.monitoring.3scale.net"},"spec":{"group":"monitoring.3scale.net","names":{"kind":"PrometheusExporter","listKind":"PrometheusExporterList","plural":"prometheusexporters","singular":"prometheusexporter"},"scope":"Namespaced","versions":[{"name":"v1alpha1","schema":{"openAPIV3Schema":{"description":"PrometheusExporter is the Schema for the prometheusexporters API","properties":{"apiVersion":{"description":"APIVersion defines the versioned schema of this representation of an object. Servers should convert recognized schemas to the latest internal value, and may reject unrecognized values. More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#resources","type":"string"},"kind":{"description":"Kind is a string value representing the REST resource this object represents. Servers may infer this from the endpoint the client submits requests to. Cannot be updated. In CamelCase. More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds","type":"string"},"metadata":{"type":"object"},"spec":{"description":"Spec defines the desired state of PrometheusExporter","properties":{"awsCredentialsSecretName":{"description":"For cloudwatch exporter, the Secret name containing AWS IAM credentials (AWS_ACCESS_KEY_ID / AWS_SECRET_ACCESS_KEY)","type":"string"},"configurationConfigmapName":{"description":"For cloudwatch exporter, the ConfigMap name containing Cloudwatch config.yml (Services, Dimensions, Tags used for autodiscovery...). For probe exporter, ConfigMap name containing blackbox modules configuration.","type":"string"},"configurationSecretName":{"description":"For probe exporter, optional Secret name containing blackbox modules configuration. Replaces usage of configurationConfigmapName (in case config includes sensitive data and so you prefer to use a Secret)","type":"string"},"dbCheckKeys":{"description":"For redis exporter, the optional redis keys to monitor","type":"string"},"dbConnectionStringSecretName":{"description":"For mysql and postgresql exporters, the Secret name containing connection string definition (DSN)","type":"string"},"dbHost":{"description":"For redis, memcached, sphinx, manticore and es exporters, the db host to monitor","type":"string"},"dbPort":{"description":"For redis, memcached, sphinx, manticore and es exporters, the db port to monitor","type":"integer"},"extraLabel":{"properties":{"key":{"description":"Add extra label key to all created resources","type":"string"},"value":{"description":"Add extra label value to all created resources","type":"string"}},"type":"object"},"grafanaDashboard":{"properties":{"apiVersion":{"description":"GrafanaDashboard custom resource apiVersion","enum":["v1alpha1","v1beta1"],"type":"string"},"enabled":{"description":"Create (true) or not (false) GrafanaDashboard object","type":"boolean"},"label":{"properties":{"key":{"description":"Label key used by grafana-operator for dashboard discovery","type":"string"},"value":{"description":"Label value used by grafana-operator for dashboard discovery","type":"string"}},"type":"object"}},"type":"object"},"image":{"properties":{"name":{"description":"Prometheus exporter image name","type":"string"},"version":{"description":"Prometheus exporter image tag version","type":"string"}},"type":"object"},"livenessProbe":{"description":"Readiness probe","properties":{"failureThreshold":{"description":"Minimum consecutive failures for the probe to be considered failed after having succeeded","format":"int32","type":"integer"},"periodSeconds":{"description":"How often (in seconds) to perform the probe","format":"int32","type":"integer"},"successThreshold":{"description":"Minimum consecutive successes for the probe to be considered successful after having failed","format":"int32","type":"integer"},"timeoutSeconds":{"description":"Number of seconds after which the probe times out","format":"int32","type":"integer"}},"type":"object"},"logLevel":{"description":"For probe exporter, log level of the exporter","enum":["info","debug"],"type":"string"},"nodeSelector":{"additionalProperties":{"type":"string"},"description":"Map of nodeSelector key-value pairs","type":"object"},"port":{"description":"Prometheus exporter port where metrics are available","type":"integer"},"probeTargetLabel":{"description":"For probe exporter, specifies the Prometheus label used to distinguish among monitored targets on grafana dashboard","type":"string"},"readinessProbe":{"description":"Readiness probe","properties":{"failureThreshold":{"description":"Minimum consecutive failures for the probe to be considered failed after having succeeded","format":"int32","type":"integer"},"periodSeconds":{"description":"How often (in seconds) to perform the probe","format":"int32","type":"integer"},"successThreshold":{"description":"Minimum consecutive successes for the probe to be considered successful after having failed","format":"int32","type":"integer"},"timeoutSeconds":{"description":"Number of seconds after which the probe times out","format":"int32","type":"integer"}},"type":"object"},"resources":{"description":"Prometheus exporter resources required.","properties":{"limits":{"additionalProperties":{"anyOf":[{"type":"integer"},{"type":"string"}],"pattern":"^(\\+|-)?(([0-9]+(\\.[0-9]*)?)|(\\.[0-9]+))(([KMGTPE]i)|[numkMGTPE]|([eE](\\+|-)?(([0-9]+(\\.[0-9]*)?)|(\\.[0-9]+))))?$","x-kubernetes-int-or-string":true},"description":"Limits describes the maximum amount of compute resources allowed. More info: https://kubernetes.io/docs/concepts/configuration/manage-compute-resources-container/","type":"object"},"requests":{"additionalProperties":{"anyOf":[{"type":"integer"},{"type":"string"}],"pattern":"^(\\+|-)?(([0-9]+(\\.[0-9]*)?)|(\\.[0-9]+))(([KMGTPE]i)|[numkMGTPE]|([eE](\\+|-)?(([0-9]+(\\.[0-9]*)?)|(\\.[0-9]+))))?$","x-kubernetes-int-or-string":true},"description":"Requests describes the minimum amount of compute resources required. If Requests is omitted for a container, it defaults to Limits if that is explicitly specified, otherwise to an implementation-defined value. More info: https://kubernetes.io/docs/concepts/configuration/manage-compute-resources-container/","type":"object"}},"type":"object"},"sendgridAccumulatedMetrics":{"description":"For sendgrid exporter, configures monthly acumulated metrics (true) instead of daily metrics (false)","type":"boolean"},"sendgridCredentialsSecretName":{"description":"For sendgrid exporter, Secret name containing Sendgrid username and apikey","type":"string"},"sendgridLocation":{"description":"For sendgrid exporter, configures time zone","type":"string"},"sendgridTimeOffset":{"description":"For sendgrid exporter, specifies the offset in seconds from UTC as an integer (needed along with location)","type":"integer"},"serviceMonitor":{"properties":{"enabled":{"description":"Create (true) or not (false) ServiceMonitor object","type":"boolean"},"interval":{"description":"Prometheus scrape interval (example 30s)","type":"string"}},"type":"object"},"tolerations":{"description":"Tolerations allow the pods to schedule onto nodes with matching taints","items":{"description":"The pod this Toleration is attached to tolerates any taint that matches the triple \u003ckey,value,effect\u003e using the matching operator \u003coperator\u003e.","properties":{"effect":{"description":"Effect indicates the taint effect to match. Empty means match all taint effects. When specified, allowed values are NoSchedule, PreferNoSchedule and NoExecute.","type":"string"},"key":{"description":"Key is the taint key that the toleration applies to. Empty means match all taint keys. If the key is empty, operator must be Exists; this combination means to match all values and all keys.","type":"string"},"operator":{"description":"Operator represents a key's relationship to the value. Valid operators are Exists and Equal. Defaults to Equal. Exists is equivalent to wildcard for value, so that a pod can tolerate all taints of a particular category.","type":"string"},"tolerationSeconds":{"description":"TolerationSeconds represents the period of time the toleration (which must be of effect NoExecute, otherwise this field is ignored) tolerates the taint. By default, it is not set, which means tolerate the taint forever (do not evict). Zero and negative values will be treated as 0 (evict immediately) by the system.","format":"int64","type":"integer"},"value":{"description":"Value is the taint value the toleration matches to. If the operator is Exists, the value should be empty, otherwise just a regular string.","type":"string"}},"type":"object"},"type":"array"},"type":{"description":"Supported prometheus-exporter types","enum":["memcached","redis","mysql","postgresql","sphinx","manticore","es","cloudwatch","probe","sendgrid"],"type":"string"}},"required":["type"],"type":"object","x-kubernetes-preserve-unknown-fields":true},"status":{"description":"Status defines the observed state of PrometheusExporter","type":"object","x-kubernetes-preserve-unknown-fields":true}},"type":"object"}},"served":true,"storage":true,"subresources":{"status":{}}}]},"status":{"acceptedNames":{"kind":"","plural":""},"conditions":null,"storedVersions":null}} -- type: olm.bundle.object - value: - data: eyJhcGlWZXJzaW9uIjoibW9uaXRvcmluZy5jb3Jlb3MuY29tL3YxIiwia2luZCI6IlNlcnZpY2VNb25pdG9yIiwibWV0YWRhdGEiOnsibGFiZWxzIjp7ImNvbnRyb2wtcGxhbmUiOiJjb250cm9sbGVyLW1hbmFnZXIifSwibmFtZSI6InByb21ldGhldXMtZXhwb3J0ZXItb3BlcmF0b3ItY29udHJvbGxlci1tYW5hZ2VyLW1ldHJpY3MtbW9uaXRvciJ9LCJzcGVjIjp7ImVuZHBvaW50cyI6W3sicGF0aCI6Ii9tZXRyaWNzIiwicG9ydCI6Imh0dHAifV0sInNlbGVjdG9yIjp7Im1hdGNoTGFiZWxzIjp7ImNvbnRyb2wtcGxhbmUiOiJjb250cm9sbGVyLW1hbmFnZXIifX19fQ== -- type: olm.bundle.object - value: - data: eyJhcGlWZXJzaW9uIjoidjEiLCJraW5kIjoiU2VydmljZSIsIm1ldGFkYXRhIjp7ImNyZWF0aW9uVGltZXN0YW1wIjpudWxsLCJsYWJlbHMiOnsiY29udHJvbC1wbGFuZSI6ImNvbnRyb2xsZXItbWFuYWdlciJ9LCJuYW1lIjoicHJvbWV0aGV1cy1leHBvcnRlci1vcGVyYXRvci1jb250cm9sbGVyLW1hbmFnZXItbWV0cmljcy1zZXJ2aWNlIn0sInNwZWMiOnsicG9ydHMiOlt7Im5hbWUiOiJodHRwIiwicG9ydCI6ODA4MCwidGFyZ2V0UG9ydCI6Imh0dHAifV0sInNlbGVjdG9yIjp7ImNvbnRyb2wtcGxhbmUiOiJjb250cm9sbGVyLW1hbmFnZXIifX0sInN0YXR1cyI6eyJsb2FkQmFsYW5jZXIiOnt9fX0= -- type: olm.bundle.object - value: - data: {"apiVersion":"operators.coreos.com/v1alpha1","kind":"ClusterServiceVersion","metadata":{"annotations":{"alm-examples":"[\n  {\n    \"apiVersion\": \"monitoring.3scale.net/v1alpha1\",\n    \"kind\": \"PrometheusExporter\",\n    \"metadata\": {\n      \"name\": \"example-memcached\"\n    },\n    \"spec\": {\n      \"dbHost\": \"your-memcached-host\",\n      \"dbPort\": 11211,\n      \"grafanaDashboard\": {\n        \"label\": {\n          \"key\": \"discovery\",\n          \"value\": \"enabled\"\n        }\n      },\n      \"type\": \"memcached\"\n    }\n  }\n]","capabilities":"Deep Insights","categories":"Monitoring","certified":"false","containerImage":"quay.io/3scale/prometheus-exporter-operator","createdAt":"2020-06-08 00:00:00","description":"Operator to setup 3rd party prometheus exporters, with a collection of grafana dashboards","operators.operatorframework.io/builder":"operator-sdk-v1.24.0","operators.operatorframework.io/project_layout":"ansible.sdk.operatorframework.io/v1","repository":"https://github.com/3scale-ops/prometheus-exporter-operator","support":"Red Hat, Inc."},"name":"prometheus-exporter-operator.v0.8.2","namespace":"placeholder"},"spec":{"apiservicedefinitions":{},"customresourcedefinitions":{"owned":[{"description":"Configures a prometheus exporter to monitor a memcached instance","displayName":"PrometheusExporter","kind":"PrometheusExporter","name":"prometheusexporters.monitoring.3scale.net","version":"v1alpha1"}]},"description":"A Kubernetes Operator based on the Operator SDK to centralize the setup of 3rd party prometheus exporters on **Kubernetes/OpenShift**, with a collection of grafana dashboards.\n\nBy just providing a few parameters like *dbHost* or *dbPort* (operator manage the container image, port, argument, command, volumes... and also prometheus `ServiceMonitor` and `GrafanaDashboard` k8s objects), you can setup different prometheus exporters to monitor:\n* The **internals from different databases**\n* **HTTP/TCP endpoints** (availability, latency, SSL/TLS certificate expiration...)\n* Any available **cloudwatch metric from any AWS Service**\n* Sendgrid email statistics (delivered, bounces, errors, spam...)\n\nCurrent prometheus exporters types supported, managed by same prometheus-exporter-operator:\n* memcached\n* redis\n* mysql\n* postgresql\n* sphinx\n* manticore\n* es (elasticsearch)\n* cloudwatch\n* probe (blackbox)\n* sendgrid\n\nThe operator manages the lifecycle of the following objects:\n* Deployment (one per CR)\n* Service (one per CR)\n* ServiceMonitor (optional, one per CR)\n* GrafanaDashboard (optional, one per Namespace)\n\n### Documentation\nDocumentation can be found on our [website](https://github.com/3scale-ops/prometheus-exporter-operator#documentation).\n\n### Getting help\nIf you encounter any issues while using operator, you can create an issue on our [website](https://github.com/3scale-ops/prometheus-exporter-operator) for bugs, enhancements, or other requests.\n\n### Contributing\nYou can contribute by:\n* Raising any issues you find using Prometheus Exporter Operator\n* Fixing issues by opening [Pull Requests](https://github.com/3scale-ops/prometheus-exporter-operator/pulls)\n* Submitting a patch or opening a PR\n* Improving [documentation](https://github.com/3scale-ops/prometheus-exporter-operator)\n* Talking about Prometheus Exporter Operator\nAll bugs, tasks or enhancements are tracked as [GitHub issues](https://github.com/3scale-ops/prometheus-exporter-operator/issues).\n\n### License\nPrometheus Exporter Operator is licensed under the [Apache 2.0 license](https://github.com/3scale-ops/prometheus-exporter-operator/blob/main/LICENSE)\n","displayName":"Prometheus Exporter Operator","icon":[{"base64data":"PD94bWwgdmVyc2lvbj0iMS4wIiBlbmNvZGluZz0iVVRGLTgiIHN0YW5kYWxvbmU9Im5vIj8+CjxzdmcKICAgeG1sbnM6ZGM9Imh0dHA6Ly9wdXJsLm9yZy9kYy9lbGVtZW50cy8xLjEvIgogICB4bWxuczpjYz0iaHR0cDovL2NyZWF0aXZlY29tbW9ucy5vcmcvbnMjIgogICB4bWxuczpyZGY9Imh0dHA6Ly93d3cudzMub3JnLzE5OTkvMDIvMjItcmRmLXN5bnRheC1ucyMiCiAgIHhtbG5zOnN2Zz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciCiAgIHhtbG5zPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2ZyIKICAgeG1sbnM6c29kaXBvZGk9Imh0dHA6Ly9zb2RpcG9kaS5zb3VyY2Vmb3JnZS5uZXQvRFREL3NvZGlwb2RpLTAuZHRkIgogICB4bWxuczppbmtzY2FwZT0iaHR0cDovL3d3dy5pbmtzY2FwZS5vcmcvbmFtZXNwYWNlcy9pbmtzY2FwZSIKICAgaW5rc2NhcGU6dmVyc2lvbj0iMC45Mi40ICh1bmtub3duKSIKICAgaW5rc2NhcGU6ZXhwb3J0LXlkcGk9IjQxMC4xOSIKICAgaW5rc2NhcGU6ZXhwb3J0LXhkcGk9IjQxMC4xOSIKICAgaW5rc2NhcGU6ZXhwb3J0LWZpbGVuYW1lPSIvVXNlcnMvcmFlbC9Eb3dubG9hZHMvcHJvbWV0aGV1cy1leHBvcnRlci5wbmciCiAgIHNvZGlwb2RpOmRvY25hbWU9InByb21ldGhldXMtZXhwb3J0ZXItM3NjYWxlLW5ldy5zdmciCiAgIGlkPSJzdmc4NDMiCiAgIHByZXNlcnZlQXNwZWN0UmF0aW89InhNaWRZTWlkIG1lZXQiCiAgIHZpZXdCb3g9IjAgMCA3MzYuNDI1NzggNjE5Ljc0ODQ3IgogICBoZWlnaHQ9IjYxOS43NDg0N3B0IgogICB3aWR0aD0iNzM2LjQyNTc4cHQiCiAgIHZlcnNpb249IjEuMCI+CiAgPG1ldGFkYXRhCiAgICAgaWQ9Im1ldGFkYXRhODQ5Ij4KICAgIDxyZGY6UkRGPgogICAgICA8Y2M6V29yawogICAgICAgICByZGY6YWJvdXQ9IiI+CiAgICAgICAgPGRjOmZvcm1hdD5pbWFnZS9zdmcreG1sPC9kYzpmb3JtYXQ+CiAgICAgICAgPGRjOnR5cGUKICAgICAgICAgICByZGY6cmVzb3VyY2U9Imh0dHA6Ly9wdXJsLm9yZy9kYy9kY21pdHlwZS9TdGlsbEltYWdlIiAvPgogICAgICA8L2NjOldvcms+CiAgICA8L3JkZjpSREY+CiAgPC9tZXRhZGF0YT4KICA8ZGVmcwogICAgIGlkPSJkZWZzODQ3IiAvPgogIDxzb2RpcG9kaTpuYW1lZHZpZXcKICAgICBpbmtzY2FwZTpjdXJyZW50LWxheWVyPSJzdmc4NDMiCiAgICAgaW5rc2NhcGU6d2luZG93LW1heGltaXplZD0iMSIKICAgICBpbmtzY2FwZTp3aW5kb3cteT0iMjciCiAgICAgaW5rc2NhcGU6d2luZG93LXg9IjAiCiAgICAgaW5rc2NhcGU6Y3k9IjM1Ny4wNDcxNyIKICAgICBpbmtzY2FwZTpjeD0iMzc0LjM3OTciCiAgICAgaW5rc2NhcGU6em9vbT0iMC42ODc3ODIyNCIKICAgICBpbmtzY2FwZTpsb2NrZ3VpZGVzPSJ0cnVlIgogICAgIHNob3dncmlkPSJmYWxzZSIKICAgICBpZD0ibmFtZWR2aWV3ODQ1IgogICAgIGlua3NjYXBlOndpbmRvdy1oZWlnaHQ9IjEzNzYiCiAgICAgaW5rc2NhcGU6d2luZG93LXdpZHRoPSIyNTYwIgogICAgIGlua3NjYXBlOnBhZ2VzaGFkb3c9IjIiCiAgICAgaW5rc2NhcGU6cGFnZW9wYWNpdHk9IjAiCiAgICAgZ3VpZGV0b2xlcmFuY2U9IjEwIgogICAgIGdyaWR0b2xlcmFuY2U9IjEwIgogICAgIG9iamVjdHRvbGVyYW5jZT0iMTAiCiAgICAgYm9yZGVyb3BhY2l0eT0iMSIKICAgICBpbmtzY2FwZTpkb2N1bWVudC1yb3RhdGlvbj0iMCIKICAgICBib3JkZXJjb2xvcj0iIzY2NjY2NiIKICAgICBwYWdlY29sb3I9IiNmZmZmZmYiIC8+CiAgPHBhdGgKICAgICBkPSJtIDcxNS4xMDM4NiwzMS43NDg0NzYgYyAtMTEuNSw0LjkgLTI3LjMsMTEuNSAtMzUsMTQuNyAtMjAuNiw4LjcgLTUwLDIxLjEgLTY2LjUsMjguMSAtMTcuNSw3LjUgLTM4LjEsMTYuMiAtNzEuMywzMC4wMDAwMDQgLTEzLjYsNS43IC0yNC42LDEwLjcgLTI0LjUsMTEuMSAwLjIsMC4zIDEwLjcsOS40IDIzLjMsMjAuMSAxMi43LDEwLjggMjQuOSwyMS4zIDI3LjIsMjMuNCBsIDQuMywzLjkgLTYuNyw3LjUgYyAtMzEuOSwzNi4xIC04MS41LDg2LjkgLTExMi44LDExNS43IC0xMTAuNiwxMDEuNiAtMjIyLjQsMTcwLjIgLTMyNywyMDAuOCAtMTQuNyw0LjMgLTQxLjEwMDAwMSwxMC42IC00OS41MDAwMDEsMTEuOCAtMS45LDAuMyAtNi40LDEgLTEwLDEuNSAtMy42LDAuNiAtOS40LDEuNCAtMTMsMS43IC0zLjYsMC40IC05LjQsMSAtMTMsMS41IC0zLjYsMC40IC0xNC4yLDAuNyAtMjMuNywwLjYgLTkuNTAwMDAwMywtMC4xIC0xNy4xMDAwMDAzMiwwIC0xNi45MDAwMDAzMiwwLjEgMS40MDAwMDAwMiwxLjQgMzguMzAwMDAwMzIsNi45IDU2LjAwMDAwMDMyLDguMyAxMS41LDEgNTMuNTAwMDAxLDEuMyA2NC4xMDAwMDEsMC41IDIuOCwtMC4yIDkuMywtMC42IDE0LjUsLTEgNS4yLC0wLjMgMTAuNiwtMC44IDEyLC0xIDEuNCwtMC4yIDUuMiwtMC43IDguNSwtMSAzNy40LC0zLjkgODUuNiwtMTQuOSAxMjYuNSwtMjkuMSA5MS40LC0zMS42IDE3Ny4xLC04Mi45IDI2MSwtMTU2LjUgMjAuNSwtMTcuOSA2OC4xLC02NS4yIDg2LjQsLTg1LjcgbCAxMi44LC0xNC4yIDEuOCwyLjIgYyAwLjksMS4zIDEwLjgsMTQgMjEuOSwyOC4zIDExLjEsMTQuMyAyMC41LDI2LjEgMjEsMjYuMyAwLjQsMC4xIDEuNSwtMy43IDIuNSwtOC41IDAuOSwtNC45IDYuNCwtMzMuMSAxMi4xLC02Mi44IDUuNywtMjkuNyAxMi45LC02Ny4xIDE2LC04MyAxNywtODcuODAwMDA0IDE5LjYsLTEwMS43MDAwMDQgMTkuMywtMTAyLjkwMDAwNCAtMC4yLC0wLjggLTgsMiAtMjEuMyw3LjYgeiIKICAgICBpZD0icGF0aDgzNSIKICAgICBpbmtzY2FwZTpjb25uZWN0b3ItY3VydmF0dXJlPSIwIgogICAgIHN0eWxlPSJmaWxsOiM1YTVhNWE7ZmlsbC1vcGFjaXR5OjE7c3Ryb2tlOm5vbmU7c3Ryb2tlLXdpZHRoOjAuMSIgLz4KICA8cGF0aAogICAgIGQ9Im0gMjIuMjAzODU5LDE1Ni41NDg0OCBjIDIsMTUgMTkuNiw2OS42IDI1LDc3LjUgMC44LDEuMSAxLjQsMi41IDEuNCwzLjMgMCwwLjcgMiw1LjQgNC41LDEwLjQgMi41LDUgNC41LDkuNSA0LjUsOS45IDAsMS4xIDE1LjUsMjkuNCAyMyw0MS45IDkuMywxNS43IDM2LjEwMDAwMSw1NC44IDM4LjkwMDAwMSw1NyAwLjQsMC4zIDEuOCwyLjEgMy4xLDQgMS4zLDEuOSAyLjcsMy43IDMsNCAwLjMsMC4zIDIuNCwyLjcgNC41LDUuNSAyLjIsMi43IDQuMiw1LjIgNC41LDUuNSAwLjMsMC4zIDMuNCwzLjkgNyw4IDExLjgsMTMuNyAxNy4yLDE5LjMgMzguOCw0MC43IDExLjgsMTEuNyAyMi4xLDIxLjMgMjIuNywyMS4zIDEuNywwIDYzLjksLTM0LjcgNjQuMywtMzUuOCAwLjEsLTAuNSAtNC44LC00IC0xMSwtNy43IC04MS42LC00OS4zIC0xNTYuNjAwMDAxLC0xMTcgLTE5OC41MDAwMDEsLTE3OS41IC0xNS4zLC0yMi44IC0yNywtNDUuMyAtMzUuMiwtNjcuNSAtMSwtMi43IC0xLC0yLjYgLTAuNSwxLjUgeiIKICAgICBpZD0icGF0aDgzNyIKICAgICBpbmtzY2FwZTpjb25uZWN0b3ItY3VydmF0dXJlPSIwIgogICAgIHN0eWxlPSJmaWxsOiNlYzdhMDg7ZmlsbC1vcGFjaXR5OjE7c3Ryb2tlOm5vbmU7c3Ryb2tlLXdpZHRoOjAuMSIgLz4KICA8cGF0aAogICAgIGQ9Im0gMzE4LjMwMzg2LDQ3OS40NDg0OCBjIC0yNi44LDkuNyAtNDguNywxNy45IC00OC43LDE4LjMgMCwxLjIgMzEuNSwyMS42IDUyLjgsMzQuMiA1NCwzMiAxMjkuOSw2NiAxOTAuMiw4NS4xIGwgOC41LDIuNyAyNywtMC42IGMgMjUuOSwtMC42IDI3LjgsLTAuOCA0OCwtNC42IDQwLjUsLTcuNiA2OC43LC0xNy45IDg5LjIsLTMyLjYgNi4xLC00LjMgMTAuOSwtOC4xIDEwLjcsLTguNCAtMS40LC0xLjQgLTUyLjgsLTE2IC04OS40LC0yNS40IC0xNCwtMy43IC0yNi40LC03IC0yNy41LC03LjUgLTEuMSwtMC41IC02LjEsLTEuOCAtMTEuMSwtMyAtMTAsLTIuMyAtNjQuNCwtMjAuMyAtOTAuNywtMzAgLTMwLjgsLTExLjQgLTcyLjIsLTI4LjUgLTEwNC43LC00My40IGwgLTUuNiwtMi41IHoiCiAgICAgaWQ9InBhdGg4MzkiCiAgICAgaW5rc2NhcGU6Y29ubmVjdG9yLWN1cnZhdHVyZT0iMCIKICAgICBzdHlsZT0iZmlsbDojZWM3YTA4O2ZpbGwtb3BhY2l0eToxO3N0cm9rZTpub25lO3N0cm9rZS13aWR0aDowLjEiIC8+Cjwvc3ZnPgo=","mediatype":"image/svg+xml"}],"install":{"spec":{"deployments":[{"label":{"control-plane":"controller-manager"},"name":"prometheus-exporter-operator-controller-manager","spec":{"replicas":1,"selector":{"matchLabels":{"control-plane":"controller-manager"}},"strategy":{},"template":{"metadata":{"annotations":{"kubectl.kubernetes.io/default-container":"manager"},"labels":{"control-plane":"controller-manager"}},"spec":{"containers":[{"args":["--health-probe-bind-address=:6789","--metrics-bind-address=0.0.0.0:8080","--leader-elect","--leader-election-id=prometheus-exporter-operator"],"env":[{"name":"ANSIBLE_GATHERING","value":"explicit"},{"name":"WATCH_NAMESPACE","valueFrom":{"fieldRef":{"fieldPath":"metadata.annotations['olm.targetNamespaces']"}}}],"image":"quay.io/3scale/prometheus-exporter-operator:v0.8.2","livenessProbe":{"httpGet":{"path":"/healthz","port":6789},"initialDelaySeconds":30,"periodSeconds":20,"timeoutSeconds":5},"name":"manager","ports":[{"containerPort":8080,"name":"http"}],"readinessProbe":{"httpGet":{"path":"/readyz","port":6789},"initialDelaySeconds":5,"periodSeconds":10,"timeoutSeconds":5},"resources":{"limits":{"cpu":"1","memory":"1Gi"},"requests":{"cpu":"10m","memory":"128Mi"}},"securityContext":{"allowPrivilegeEscalation":false,"capabilities":{"drop":["ALL"]}}}],"securityContext":{"runAsNonRoot":true},"serviceAccountName":"prometheus-exporter-operator-controller-manager","terminationGracePeriodSeconds":10}}}}],"permissions":[{"rules":[{"apiGroups":[""],"resources":["configmaps"],"verbs":["get","list","watch","create","update","patch","delete"]},{"apiGroups":["coordination.k8s.io"],"resources":["leases"],"verbs":["get","list","watch","create","update","patch","delete"]},{"apiGroups":[""],"resources":["events"],"verbs":["create","patch"]},{"apiGroups":["apps"],"resources":["deployments"],"verbs":["create","delete","get","list","patch","update","watch"]},{"apiGroups":[""],"resources":["services"],"verbs":["create","delete","get","list","patch","update","watch"]},{"apiGroups":[""],"resources":["secrets"],"verbs":["get","list","watch"]},{"apiGroups":[""],"resources":["configmaps"],"verbs":["get","list","watch"]},{"apiGroups":["monitoring.coreos.com"],"resources":["servicemonitors"],"verbs":["create","delete","get","list","patch","update","watch"]},{"apiGroups":["integreatly.org","grafana.integreatly.org"],"resources":["grafanadashboards"],"verbs":["create","delete","get","list","patch","update","watch"]},{"apiGroups":["monitoring.3scale.net"],"resources":["prometheusexporters","prometheusexporters/status","prometheusexporters/finalizers"],"verbs":["create","delete","get","list","patch","update","watch"]}],"serviceAccountName":"prometheus-exporter-operator-controller-manager"}]},"strategy":"deployment"},"installModes":[{"supported":true,"type":"OwnNamespace"},{"supported":true,"type":"SingleNamespace"},{"supported":true,"type":"MultiNamespace"},{"supported":true,"type":"AllNamespaces"}],"keywords":["monitoring","metrics","observability","prometheus","exporter","grafana","mysql","postgresql","memcached","redis","sphinx","elasticsearch","cloudwatch","blackbox","sendgrid","manticore"],"links":[{"name":"GitHub","url":"https://github.com/3scale-ops/prometheus-exporter-operator"}],"maintainers":[{"email":"3scale-operations@redhat.com","name":"3scale Ops"}],"maturity":"alpha","provider":{"name":"Red Hat","url":"https://www.redhat.com"},"version":"0.8.2"}} -relatedImages: -- image: quay.io/3scale/prometheus-exporter-operator-bundle:v0.8.2 - name: "" -- image: quay.io/3scale/prometheus-exporter-operator:v0.8.2 - name: "" -schema: olm.bundle diff --git a/catalog/prometheus-exporter-operator/objects/prometheus-exporter-operator.v0.8.2-alpha.2.clusterserviceversion.yaml b/catalog/prometheus-exporter-operator/objects/prometheus-exporter-operator.v0.9.0-alpha.1.clusterserviceversion.yaml similarity index 98% rename from catalog/prometheus-exporter-operator/objects/prometheus-exporter-operator.v0.8.2-alpha.2.clusterserviceversion.yaml rename to catalog/prometheus-exporter-operator/objects/prometheus-exporter-operator.v0.9.0-alpha.1.clusterserviceversion.yaml index 1b9d387..da08c60 100644 --- a/catalog/prometheus-exporter-operator/objects/prometheus-exporter-operator.v0.8.2-alpha.2.clusterserviceversion.yaml +++ b/catalog/prometheus-exporter-operator/objects/prometheus-exporter-operator.v0.9.0-alpha.1.clusterserviceversion.yaml @@ -1,6 +1,6 @@ --- -image: quay.io/3scale/prometheus-exporter-operator-bundle:v0.8.2-alpha.2 -name: prometheus-exporter-operator.v0.8.2-alpha.2 +image: quay.io/3scale/prometheus-exporter-operator-bundle:v0.9.0-alpha.1 +name: prometheus-exporter-operator.v0.9.0-alpha.1 package: prometheus-exporter-operator properties: - type: olm.gvk @@ -11,7 +11,7 @@ properties: - type: olm.package value: packageName: prometheus-exporter-operator - version: 0.8.2-alpha.2 + version: 0.9.0-alpha.1 - type: olm.bundle.object value: data: {"apiVersion":"apiextensions.k8s.io/v1","kind":"CustomResourceDefinition","metadata":{"creationTimestamp":null,"name":"prometheusexporters.monitoring.3scale.net"},"spec":{"group":"monitoring.3scale.net","names":{"kind":"PrometheusExporter","listKind":"PrometheusExporterList","plural":"prometheusexporters","singular":"prometheusexporter"},"scope":"Namespaced","versions":[{"name":"v1alpha1","schema":{"openAPIV3Schema":{"description":"PrometheusExporter is the Schema for the prometheusexporters API","properties":{"apiVersion":{"description":"APIVersion defines the versioned schema of this representation of an object. Servers should convert recognized schemas to the latest internal value, and may reject unrecognized values. More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#resources","type":"string"},"kind":{"description":"Kind is a string value representing the REST resource this object represents. Servers may infer this from the endpoint the client submits requests to. Cannot be updated. In CamelCase. More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds","type":"string"},"metadata":{"type":"object"},"spec":{"description":"Spec defines the desired state of PrometheusExporter","properties":{"awsCredentialsSecretName":{"description":"For cloudwatch exporter, the Secret name containing AWS IAM credentials (AWS_ACCESS_KEY_ID / AWS_SECRET_ACCESS_KEY)","type":"string"},"configurationConfigmapName":{"description":"For cloudwatch exporter, the ConfigMap name containing Cloudwatch config.yml (Services, Dimensions, Tags used for autodiscovery...). For probe exporter, ConfigMap name containing blackbox modules configuration.","type":"string"},"configurationSecretName":{"description":"For probe exporter, optional Secret name containing blackbox modules configuration. Replaces usage of configurationConfigmapName (in case config includes sensitive data and so you prefer to use a Secret)","type":"string"},"dbCheckKeys":{"description":"For redis exporter, the optional redis keys to monitor","type":"string"},"dbConnectionStringSecretName":{"description":"For mysql and postgresql exporters, the Secret name containing connection string definition (DSN)","type":"string"},"dbHost":{"description":"For redis, memcached, sphinx, manticore and es exporters, the db host to monitor","type":"string"},"dbPort":{"description":"For redis, memcached, sphinx, manticore and es exporters, the db port to monitor","type":"integer"},"extraLabel":{"properties":{"key":{"description":"Add extra label key to all created resources","type":"string"},"value":{"description":"Add extra label value to all created resources","type":"string"}},"type":"object"},"grafanaDashboard":{"properties":{"apiVersion":{"description":"GrafanaDashboard custom resource apiVersion","enum":["v1alpha1","v1beta1"],"type":"string"},"enabled":{"description":"Create (true) or not (false) GrafanaDashboard object","type":"boolean"},"label":{"properties":{"key":{"description":"Label key used by grafana-operator for dashboard discovery","type":"string"},"value":{"description":"Label value used by grafana-operator for dashboard discovery","type":"string"}},"type":"object"}},"type":"object"},"image":{"properties":{"name":{"description":"Prometheus exporter image name","type":"string"},"version":{"description":"Prometheus exporter image tag version","type":"string"}},"type":"object"},"livenessProbe":{"description":"Readiness probe","properties":{"failureThreshold":{"description":"Minimum consecutive failures for the probe to be considered failed after having succeeded","format":"int32","type":"integer"},"periodSeconds":{"description":"How often (in seconds) to perform the probe","format":"int32","type":"integer"},"successThreshold":{"description":"Minimum consecutive successes for the probe to be considered successful after having failed","format":"int32","type":"integer"},"timeoutSeconds":{"description":"Number of seconds after which the probe times out","format":"int32","type":"integer"}},"type":"object"},"logLevel":{"description":"For probe exporter, log level of the exporter","enum":["info","debug"],"type":"string"},"nodeSelector":{"additionalProperties":{"type":"string"},"description":"Map of nodeSelector key-value pairs","type":"object"},"port":{"description":"Prometheus exporter port where metrics are available","type":"integer"},"probeTargetLabel":{"description":"For probe exporter, specifies the Prometheus label used to distinguish among monitored targets on grafana dashboard","type":"string"},"readinessProbe":{"description":"Readiness probe","properties":{"failureThreshold":{"description":"Minimum consecutive failures for the probe to be considered failed after having succeeded","format":"int32","type":"integer"},"periodSeconds":{"description":"How often (in seconds) to perform the probe","format":"int32","type":"integer"},"successThreshold":{"description":"Minimum consecutive successes for the probe to be considered successful after having failed","format":"int32","type":"integer"},"timeoutSeconds":{"description":"Number of seconds after which the probe times out","format":"int32","type":"integer"}},"type":"object"},"resources":{"description":"Prometheus exporter resources required.","properties":{"limits":{"additionalProperties":{"anyOf":[{"type":"integer"},{"type":"string"}],"pattern":"^(\\+|-)?(([0-9]+(\\.[0-9]*)?)|(\\.[0-9]+))(([KMGTPE]i)|[numkMGTPE]|([eE](\\+|-)?(([0-9]+(\\.[0-9]*)?)|(\\.[0-9]+))))?$","x-kubernetes-int-or-string":true},"description":"Limits describes the maximum amount of compute resources allowed. More info: https://kubernetes.io/docs/concepts/configuration/manage-compute-resources-container/","type":"object"},"requests":{"additionalProperties":{"anyOf":[{"type":"integer"},{"type":"string"}],"pattern":"^(\\+|-)?(([0-9]+(\\.[0-9]*)?)|(\\.[0-9]+))(([KMGTPE]i)|[numkMGTPE]|([eE](\\+|-)?(([0-9]+(\\.[0-9]*)?)|(\\.[0-9]+))))?$","x-kubernetes-int-or-string":true},"description":"Requests describes the minimum amount of compute resources required. If Requests is omitted for a container, it defaults to Limits if that is explicitly specified, otherwise to an implementation-defined value. More info: https://kubernetes.io/docs/concepts/configuration/manage-compute-resources-container/","type":"object"}},"type":"object"},"sendgridAccumulatedMetrics":{"description":"For sendgrid exporter, configures monthly acumulated metrics (true) instead of daily metrics (false)","type":"boolean"},"sendgridCredentialsSecretName":{"description":"For sendgrid exporter, Secret name containing Sendgrid username and apikey","type":"string"},"sendgridLocation":{"description":"For sendgrid exporter, configures time zone","type":"string"},"sendgridTimeOffset":{"description":"For sendgrid exporter, specifies the offset in seconds from UTC as an integer (needed along with location)","type":"integer"},"serviceMonitor":{"properties":{"enabled":{"description":"Create (true) or not (false) ServiceMonitor object","type":"boolean"},"interval":{"description":"Prometheus scrape interval (example 30s)","type":"string"}},"type":"object"},"tolerations":{"description":"Tolerations allow the pods to schedule onto nodes with matching taints","items":{"description":"The pod this Toleration is attached to tolerates any taint that matches the triple \u003ckey,value,effect\u003e using the matching operator \u003coperator\u003e.","properties":{"effect":{"description":"Effect indicates the taint effect to match. Empty means match all taint effects. When specified, allowed values are NoSchedule, PreferNoSchedule and NoExecute.","type":"string"},"key":{"description":"Key is the taint key that the toleration applies to. Empty means match all taint keys. If the key is empty, operator must be Exists; this combination means to match all values and all keys.","type":"string"},"operator":{"description":"Operator represents a key's relationship to the value. Valid operators are Exists and Equal. Defaults to Equal. Exists is equivalent to wildcard for value, so that a pod can tolerate all taints of a particular category.","type":"string"},"tolerationSeconds":{"description":"TolerationSeconds represents the period of time the toleration (which must be of effect NoExecute, otherwise this field is ignored) tolerates the taint. By default, it is not set, which means tolerate the taint forever (do not evict). Zero and negative values will be treated as 0 (evict immediately) by the system.","format":"int64","type":"integer"},"value":{"description":"Value is the taint value the toleration matches to. If the operator is Exists, the value should be empty, otherwise just a regular string.","type":"string"}},"type":"object"},"type":"array"},"type":{"description":"Supported prometheus-exporter types","enum":["memcached","redis","mysql","postgresql","sphinx","manticore","es","cloudwatch","probe","sendgrid"],"type":"string"}},"required":["type"],"type":"object","x-kubernetes-preserve-unknown-fields":true},"status":{"description":"Status defines the observed state of PrometheusExporter","type":"object","x-kubernetes-preserve-unknown-fields":true}},"type":"object"}},"served":true,"storage":true,"subresources":{"status":{}}}]},"status":{"acceptedNames":{"kind":"","plural":""},"conditions":null,"storedVersions":null}} @@ -23,10 +23,10 @@ properties: data: eyJhcGlWZXJzaW9uIjoidjEiLCJraW5kIjoiU2VydmljZSIsIm1ldGFkYXRhIjp7ImNyZWF0aW9uVGltZXN0YW1wIjpudWxsLCJsYWJlbHMiOnsiY29udHJvbC1wbGFuZSI6ImNvbnRyb2xsZXItbWFuYWdlciJ9LCJuYW1lIjoicHJvbWV0aGV1cy1leHBvcnRlci1vcGVyYXRvci1jb250cm9sbGVyLW1hbmFnZXItbWV0cmljcy1zZXJ2aWNlIn0sInNwZWMiOnsicG9ydHMiOlt7Im5hbWUiOiJodHRwIiwicG9ydCI6ODA4MCwidGFyZ2V0UG9ydCI6Imh0dHAifV0sInNlbGVjdG9yIjp7ImNvbnRyb2wtcGxhbmUiOiJjb250cm9sbGVyLW1hbmFnZXIifX0sInN0YXR1cyI6eyJsb2FkQmFsYW5jZXIiOnt9fX0= - type: olm.bundle.object value: - data: {"apiVersion":"operators.coreos.com/v1alpha1","kind":"ClusterServiceVersion","metadata":{"annotations":{"alm-examples":"[\n  {\n    \"apiVersion\": \"monitoring.3scale.net/v1alpha1\",\n    \"kind\": \"PrometheusExporter\",\n    \"metadata\": {\n      \"name\": \"example-memcached\"\n    },\n    \"spec\": {\n      \"dbHost\": \"your-memcached-host\",\n      \"dbPort\": 11211,\n      \"grafanaDashboard\": {\n        \"label\": {\n          \"key\": \"discovery\",\n          \"value\": \"enabled\"\n        }\n      },\n      \"type\": \"memcached\"\n    }\n  }\n]","capabilities":"Deep Insights","categories":"Monitoring","certified":"false","containerImage":"quay.io/3scale/prometheus-exporter-operator","createdAt":"2020-06-08 00:00:00","description":"Operator to setup 3rd party prometheus exporters, with a collection of grafana dashboards","operators.operatorframework.io/builder":"operator-sdk-v1.24.0","operators.operatorframework.io/project_layout":"ansible.sdk.operatorframework.io/v1","repository":"https://github.com/3scale-ops/prometheus-exporter-operator","support":"Red Hat, Inc."},"name":"prometheus-exporter-operator.v0.8.2-alpha.2","namespace":"placeholder"},"spec":{"apiservicedefinitions":{},"customresourcedefinitions":{"owned":[{"description":"Configures a prometheus exporter to monitor a memcached instance","displayName":"PrometheusExporter","kind":"PrometheusExporter","name":"prometheusexporters.monitoring.3scale.net","version":"v1alpha1"}]},"description":"A Kubernetes Operator based on the Operator SDK to centralize the setup of 3rd party prometheus exporters on **Kubernetes/OpenShift**, with a collection of grafana dashboards.\n\nBy just providing a few parameters like *dbHost* or *dbPort* (operator manage the container image, port, argument, command, volumes... and also prometheus `ServiceMonitor` and `GrafanaDashboard` k8s objects), you can setup different prometheus exporters to monitor:\n* The **internals from different databases**\n* **HTTP/TCP endpoints** (availability, latency, SSL/TLS certificate expiration...)\n* Any available **cloudwatch metric from any AWS Service**\n* Sendgrid email statistics (delivered, bounces, errors, spam...)\n\nCurrent prometheus exporters types supported, managed by same prometheus-exporter-operator:\n* memcached\n* redis\n* mysql\n* postgresql\n* sphinx\n* manticore\n* es (elasticsearch)\n* cloudwatch\n* probe (blackbox)\n* sendgrid\n\nThe operator manages the lifecycle of the following objects:\n* Deployment (one per CR)\n* Service (one per CR)\n* ServiceMonitor (optional, one per CR)\n* GrafanaDashboard (optional, one per Namespace)\n\n### Documentation\nDocumentation can be found on our [website](https://github.com/3scale-ops/prometheus-exporter-operator#documentation).\n\n### Getting help\nIf you encounter any issues while using operator, you can create an issue on our [website](https://github.com/3scale-ops/prometheus-exporter-operator) for bugs, enhancements, or other requests.\n\n### Contributing\nYou can contribute by:\n* Raising any issues you find using Prometheus Exporter Operator\n* Fixing issues by opening [Pull Requests](https://github.com/3scale-ops/prometheus-exporter-operator/pulls)\n* Submitting a patch or opening a PR\n* Improving [documentation](https://github.com/3scale-ops/prometheus-exporter-operator)\n* Talking about Prometheus Exporter Operator\nAll bugs, tasks or enhancements are tracked as [GitHub issues](https://github.com/3scale-ops/prometheus-exporter-operator/issues).\n\n### License\nPrometheus Exporter Operator is licensed under the [Apache 2.0 license](https://github.com/3scale-ops/prometheus-exporter-operator/blob/main/LICENSE)\n","displayName":"Prometheus Exporter Operator","icon":[{"base64data":"PD94bWwgdmVyc2lvbj0iMS4wIiBlbmNvZGluZz0iVVRGLTgiIHN0YW5kYWxvbmU9Im5vIj8+CjxzdmcKICAgeG1sbnM6ZGM9Imh0dHA6Ly9wdXJsLm9yZy9kYy9lbGVtZW50cy8xLjEvIgogICB4bWxuczpjYz0iaHR0cDovL2NyZWF0aXZlY29tbW9ucy5vcmcvbnMjIgogICB4bWxuczpyZGY9Imh0dHA6Ly93d3cudzMub3JnLzE5OTkvMDIvMjItcmRmLXN5bnRheC1ucyMiCiAgIHhtbG5zOnN2Zz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciCiAgIHhtbG5zPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2ZyIKICAgeG1sbnM6c29kaXBvZGk9Imh0dHA6Ly9zb2RpcG9kaS5zb3VyY2Vmb3JnZS5uZXQvRFREL3NvZGlwb2RpLTAuZHRkIgogICB4bWxuczppbmtzY2FwZT0iaHR0cDovL3d3dy5pbmtzY2FwZS5vcmcvbmFtZXNwYWNlcy9pbmtzY2FwZSIKICAgaW5rc2NhcGU6dmVyc2lvbj0iMC45Mi40ICh1bmtub3duKSIKICAgaW5rc2NhcGU6ZXhwb3J0LXlkcGk9IjQxMC4xOSIKICAgaW5rc2NhcGU6ZXhwb3J0LXhkcGk9IjQxMC4xOSIKICAgaW5rc2NhcGU6ZXhwb3J0LWZpbGVuYW1lPSIvVXNlcnMvcmFlbC9Eb3dubG9hZHMvcHJvbWV0aGV1cy1leHBvcnRlci5wbmciCiAgIHNvZGlwb2RpOmRvY25hbWU9InByb21ldGhldXMtZXhwb3J0ZXItM3NjYWxlLW5ldy5zdmciCiAgIGlkPSJzdmc4NDMiCiAgIHByZXNlcnZlQXNwZWN0UmF0aW89InhNaWRZTWlkIG1lZXQiCiAgIHZpZXdCb3g9IjAgMCA3MzYuNDI1NzggNjE5Ljc0ODQ3IgogICBoZWlnaHQ9IjYxOS43NDg0N3B0IgogICB3aWR0aD0iNzM2LjQyNTc4cHQiCiAgIHZlcnNpb249IjEuMCI+CiAgPG1ldGFkYXRhCiAgICAgaWQ9Im1ldGFkYXRhODQ5Ij4KICAgIDxyZGY6UkRGPgogICAgICA8Y2M6V29yawogICAgICAgICByZGY6YWJvdXQ9IiI+CiAgICAgICAgPGRjOmZvcm1hdD5pbWFnZS9zdmcreG1sPC9kYzpmb3JtYXQ+CiAgICAgICAgPGRjOnR5cGUKICAgICAgICAgICByZGY6cmVzb3VyY2U9Imh0dHA6Ly9wdXJsLm9yZy9kYy9kY21pdHlwZS9TdGlsbEltYWdlIiAvPgogICAgICA8L2NjOldvcms+CiAgICA8L3JkZjpSREY+CiAgPC9tZXRhZGF0YT4KICA8ZGVmcwogICAgIGlkPSJkZWZzODQ3IiAvPgogIDxzb2RpcG9kaTpuYW1lZHZpZXcKICAgICBpbmtzY2FwZTpjdXJyZW50LWxheWVyPSJzdmc4NDMiCiAgICAgaW5rc2NhcGU6d2luZG93LW1heGltaXplZD0iMSIKICAgICBpbmtzY2FwZTp3aW5kb3cteT0iMjciCiAgICAgaW5rc2NhcGU6d2luZG93LXg9IjAiCiAgICAgaW5rc2NhcGU6Y3k9IjM1Ny4wNDcxNyIKICAgICBpbmtzY2FwZTpjeD0iMzc0LjM3OTciCiAgICAgaW5rc2NhcGU6em9vbT0iMC42ODc3ODIyNCIKICAgICBpbmtzY2FwZTpsb2NrZ3VpZGVzPSJ0cnVlIgogICAgIHNob3dncmlkPSJmYWxzZSIKICAgICBpZD0ibmFtZWR2aWV3ODQ1IgogICAgIGlua3NjYXBlOndpbmRvdy1oZWlnaHQ9IjEzNzYiCiAgICAgaW5rc2NhcGU6d2luZG93LXdpZHRoPSIyNTYwIgogICAgIGlua3NjYXBlOnBhZ2VzaGFkb3c9IjIiCiAgICAgaW5rc2NhcGU6cGFnZW9wYWNpdHk9IjAiCiAgICAgZ3VpZGV0b2xlcmFuY2U9IjEwIgogICAgIGdyaWR0b2xlcmFuY2U9IjEwIgogICAgIG9iamVjdHRvbGVyYW5jZT0iMTAiCiAgICAgYm9yZGVyb3BhY2l0eT0iMSIKICAgICBpbmtzY2FwZTpkb2N1bWVudC1yb3RhdGlvbj0iMCIKICAgICBib3JkZXJjb2xvcj0iIzY2NjY2NiIKICAgICBwYWdlY29sb3I9IiNmZmZmZmYiIC8+CiAgPHBhdGgKICAgICBkPSJtIDcxNS4xMDM4NiwzMS43NDg0NzYgYyAtMTEuNSw0LjkgLTI3LjMsMTEuNSAtMzUsMTQuNyAtMjAuNiw4LjcgLTUwLDIxLjEgLTY2LjUsMjguMSAtMTcuNSw3LjUgLTM4LjEsMTYuMiAtNzEuMywzMC4wMDAwMDQgLTEzLjYsNS43IC0yNC42LDEwLjcgLTI0LjUsMTEuMSAwLjIsMC4zIDEwLjcsOS40IDIzLjMsMjAuMSAxMi43LDEwLjggMjQuOSwyMS4zIDI3LjIsMjMuNCBsIDQuMywzLjkgLTYuNyw3LjUgYyAtMzEuOSwzNi4xIC04MS41LDg2LjkgLTExMi44LDExNS43IC0xMTAuNiwxMDEuNiAtMjIyLjQsMTcwLjIgLTMyNywyMDAuOCAtMTQuNyw0LjMgLTQxLjEwMDAwMSwxMC42IC00OS41MDAwMDEsMTEuOCAtMS45LDAuMyAtNi40LDEgLTEwLDEuNSAtMy42LDAuNiAtOS40LDEuNCAtMTMsMS43IC0zLjYsMC40IC05LjQsMSAtMTMsMS41IC0zLjYsMC40IC0xNC4yLDAuNyAtMjMuNywwLjYgLTkuNTAwMDAwMywtMC4xIC0xNy4xMDAwMDAzMiwwIC0xNi45MDAwMDAzMiwwLjEgMS40MDAwMDAwMiwxLjQgMzguMzAwMDAwMzIsNi45IDU2LjAwMDAwMDMyLDguMyAxMS41LDEgNTMuNTAwMDAxLDEuMyA2NC4xMDAwMDEsMC41IDIuOCwtMC4yIDkuMywtMC42IDE0LjUsLTEgNS4yLC0wLjMgMTAuNiwtMC44IDEyLC0xIDEuNCwtMC4yIDUuMiwtMC43IDguNSwtMSAzNy40LC0zLjkgODUuNiwtMTQuOSAxMjYuNSwtMjkuMSA5MS40LC0zMS42IDE3Ny4xLC04Mi45IDI2MSwtMTU2LjUgMjAuNSwtMTcuOSA2OC4xLC02NS4yIDg2LjQsLTg1LjcgbCAxMi44LC0xNC4yIDEuOCwyLjIgYyAwLjksMS4zIDEwLjgsMTQgMjEuOSwyOC4zIDExLjEsMTQuMyAyMC41LDI2LjEgMjEsMjYuMyAwLjQsMC4xIDEuNSwtMy43IDIuNSwtOC41IDAuOSwtNC45IDYuNCwtMzMuMSAxMi4xLC02Mi44IDUuNywtMjkuNyAxMi45LC02Ny4xIDE2LC04MyAxNywtODcuODAwMDA0IDE5LjYsLTEwMS43MDAwMDQgMTkuMywtMTAyLjkwMDAwNCAtMC4yLC0wLjggLTgsMiAtMjEuMyw3LjYgeiIKICAgICBpZD0icGF0aDgzNSIKICAgICBpbmtzY2FwZTpjb25uZWN0b3ItY3VydmF0dXJlPSIwIgogICAgIHN0eWxlPSJmaWxsOiM1YTVhNWE7ZmlsbC1vcGFjaXR5OjE7c3Ryb2tlOm5vbmU7c3Ryb2tlLXdpZHRoOjAuMSIgLz4KICA8cGF0aAogICAgIGQ9Im0gMjIuMjAzODU5LDE1Ni41NDg0OCBjIDIsMTUgMTkuNiw2OS42IDI1LDc3LjUgMC44LDEuMSAxLjQsMi41IDEuNCwzLjMgMCwwLjcgMiw1LjQgNC41LDEwLjQgMi41LDUgNC41LDkuNSA0LjUsOS45IDAsMS4xIDE1LjUsMjkuNCAyMyw0MS45IDkuMywxNS43IDM2LjEwMDAwMSw1NC44IDM4LjkwMDAwMSw1NyAwLjQsMC4zIDEuOCwyLjEgMy4xLDQgMS4zLDEuOSAyLjcsMy43IDMsNCAwLjMsMC4zIDIuNCwyLjcgNC41LDUuNSAyLjIsMi43IDQuMiw1LjIgNC41LDUuNSAwLjMsMC4zIDMuNCwzLjkgNyw4IDExLjgsMTMuNyAxNy4yLDE5LjMgMzguOCw0MC43IDExLjgsMTEuNyAyMi4xLDIxLjMgMjIuNywyMS4zIDEuNywwIDYzLjksLTM0LjcgNjQuMywtMzUuOCAwLjEsLTAuNSAtNC44LC00IC0xMSwtNy43IC04MS42LC00OS4zIC0xNTYuNjAwMDAxLC0xMTcgLTE5OC41MDAwMDEsLTE3OS41IC0xNS4zLC0yMi44IC0yNywtNDUuMyAtMzUuMiwtNjcuNSAtMSwtMi43IC0xLC0yLjYgLTAuNSwxLjUgeiIKICAgICBpZD0icGF0aDgzNyIKICAgICBpbmtzY2FwZTpjb25uZWN0b3ItY3VydmF0dXJlPSIwIgogICAgIHN0eWxlPSJmaWxsOiNlYzdhMDg7ZmlsbC1vcGFjaXR5OjE7c3Ryb2tlOm5vbmU7c3Ryb2tlLXdpZHRoOjAuMSIgLz4KICA8cGF0aAogICAgIGQ9Im0gMzE4LjMwMzg2LDQ3OS40NDg0OCBjIC0yNi44LDkuNyAtNDguNywxNy45IC00OC43LDE4LjMgMCwxLjIgMzEuNSwyMS42IDUyLjgsMzQuMiA1NCwzMiAxMjkuOSw2NiAxOTAuMiw4NS4xIGwgOC41LDIuNyAyNywtMC42IGMgMjUuOSwtMC42IDI3LjgsLTAuOCA0OCwtNC42IDQwLjUsLTcuNiA2OC43LC0xNy45IDg5LjIsLTMyLjYgNi4xLC00LjMgMTAuOSwtOC4xIDEwLjcsLTguNCAtMS40LC0xLjQgLTUyLjgsLTE2IC04OS40LC0yNS40IC0xNCwtMy43IC0yNi40LC03IC0yNy41LC03LjUgLTEuMSwtMC41IC02LjEsLTEuOCAtMTEuMSwtMyAtMTAsLTIuMyAtNjQuNCwtMjAuMyAtOTAuNywtMzAgLTMwLjgsLTExLjQgLTcyLjIsLTI4LjUgLTEwNC43LC00My40IGwgLTUuNiwtMi41IHoiCiAgICAgaWQ9InBhdGg4MzkiCiAgICAgaW5rc2NhcGU6Y29ubmVjdG9yLWN1cnZhdHVyZT0iMCIKICAgICBzdHlsZT0iZmlsbDojZWM3YTA4O2ZpbGwtb3BhY2l0eToxO3N0cm9rZTpub25lO3N0cm9rZS13aWR0aDowLjEiIC8+Cjwvc3ZnPgo=","mediatype":"image/svg+xml"}],"install":{"spec":{"deployments":[{"label":{"control-plane":"controller-manager"},"name":"prometheus-exporter-operator-controller-manager","spec":{"replicas":1,"selector":{"matchLabels":{"control-plane":"controller-manager"}},"strategy":{},"template":{"metadata":{"annotations":{"kubectl.kubernetes.io/default-container":"manager"},"labels":{"control-plane":"controller-manager"}},"spec":{"containers":[{"args":["--health-probe-bind-address=:6789","--metrics-bind-address=0.0.0.0:8080","--leader-elect","--leader-election-id=prometheus-exporter-operator"],"env":[{"name":"ANSIBLE_GATHERING","value":"explicit"},{"name":"WATCH_NAMESPACE","valueFrom":{"fieldRef":{"fieldPath":"metadata.annotations['olm.targetNamespaces']"}}}],"image":"quay.io/3scale/prometheus-exporter-operator:v0.8.2-alpha.2","livenessProbe":{"httpGet":{"path":"/healthz","port":6789},"initialDelaySeconds":30,"periodSeconds":20,"timeoutSeconds":5},"name":"manager","ports":[{"containerPort":8080,"name":"http"}],"readinessProbe":{"httpGet":{"path":"/readyz","port":6789},"initialDelaySeconds":5,"periodSeconds":10,"timeoutSeconds":5},"resources":{"limits":{"cpu":"1","memory":"1Gi"},"requests":{"cpu":"10m","memory":"128Mi"}},"securityContext":{"allowPrivilegeEscalation":false,"capabilities":{"drop":["ALL"]}}}],"securityContext":{"runAsNonRoot":true},"serviceAccountName":"prometheus-exporter-operator-controller-manager","terminationGracePeriodSeconds":10}}}}],"permissions":[{"rules":[{"apiGroups":[""],"resources":["configmaps"],"verbs":["get","list","watch","create","update","patch","delete"]},{"apiGroups":["coordination.k8s.io"],"resources":["leases"],"verbs":["get","list","watch","create","update","patch","delete"]},{"apiGroups":[""],"resources":["events"],"verbs":["create","patch"]},{"apiGroups":["apps"],"resources":["deployments"],"verbs":["create","delete","get","list","patch","update","watch"]},{"apiGroups":[""],"resources":["services"],"verbs":["create","delete","get","list","patch","update","watch"]},{"apiGroups":[""],"resources":["secrets"],"verbs":["get","list","watch"]},{"apiGroups":[""],"resources":["configmaps"],"verbs":["get","list","watch"]},{"apiGroups":["monitoring.coreos.com"],"resources":["servicemonitors"],"verbs":["create","delete","get","list","patch","update","watch"]},{"apiGroups":["integreatly.org","grafana.integreatly.org"],"resources":["grafanadashboards"],"verbs":["create","delete","get","list","patch","update","watch"]},{"apiGroups":["monitoring.3scale.net"],"resources":["prometheusexporters","prometheusexporters/status","prometheusexporters/finalizers"],"verbs":["create","delete","get","list","patch","update","watch"]}],"serviceAccountName":"prometheus-exporter-operator-controller-manager"}]},"strategy":"deployment"},"installModes":[{"supported":true,"type":"OwnNamespace"},{"supported":true,"type":"SingleNamespace"},{"supported":true,"type":"MultiNamespace"},{"supported":true,"type":"AllNamespaces"}],"keywords":["monitoring","metrics","observability","prometheus","exporter","grafana","mysql","postgresql","memcached","redis","sphinx","elasticsearch","cloudwatch","blackbox","sendgrid","manticore"],"links":[{"name":"GitHub","url":"https://github.com/3scale-ops/prometheus-exporter-operator"}],"maintainers":[{"email":"3scale-operations@redhat.com","name":"3scale Ops"}],"maturity":"alpha","provider":{"name":"Red Hat","url":"https://www.redhat.com"},"version":"0.8.2-alpha.2"}} + data: {"apiVersion":"operators.coreos.com/v1alpha1","kind":"ClusterServiceVersion","metadata":{"annotations":{"alm-examples":"[\n  {\n    \"apiVersion\": \"monitoring.3scale.net/v1alpha1\",\n    \"kind\": \"PrometheusExporter\",\n    \"metadata\": {\n      \"name\": \"example-memcached\"\n    },\n    \"spec\": {\n      \"dbHost\": \"your-memcached-host\",\n      \"dbPort\": 11211,\n      \"grafanaDashboard\": {\n        \"label\": {\n          \"key\": \"discovery\",\n          \"value\": \"enabled\"\n        }\n      },\n      \"type\": \"memcached\"\n    }\n  }\n]","capabilities":"Deep Insights","categories":"Monitoring","certified":"false","containerImage":"quay.io/3scale/prometheus-exporter-operator","createdAt":"2020-06-08 00:00:00","description":"Operator to setup 3rd party prometheus exporters, with a collection of grafana dashboards","operators.operatorframework.io/builder":"operator-sdk-v1.24.0","operators.operatorframework.io/project_layout":"ansible.sdk.operatorframework.io/v1","repository":"https://github.com/3scale-ops/prometheus-exporter-operator","support":"Red Hat, Inc."},"name":"prometheus-exporter-operator.v0.9.0-alpha.1","namespace":"placeholder"},"spec":{"apiservicedefinitions":{},"customresourcedefinitions":{"owned":[{"description":"Configures a prometheus exporter to monitor a memcached instance","displayName":"PrometheusExporter","kind":"PrometheusExporter","name":"prometheusexporters.monitoring.3scale.net","version":"v1alpha1"}]},"description":"A Kubernetes Operator based on the Operator SDK to centralize the setup of 3rd party prometheus exporters on **Kubernetes/OpenShift**, with a collection of grafana dashboards.\n\nBy just providing a few parameters like *dbHost* or *dbPort* (operator manage the container image, port, argument, command, volumes... and also prometheus `ServiceMonitor` and `GrafanaDashboard` k8s objects), you can setup different prometheus exporters to monitor:\n* The **internals from different databases**\n* **HTTP/TCP endpoints** (availability, latency, SSL/TLS certificate expiration...)\n* Any available **cloudwatch metric from any AWS Service**\n* Sendgrid email statistics (delivered, bounces, errors, spam...)\n\nCurrent prometheus exporters types supported, managed by same prometheus-exporter-operator:\n* memcached\n* redis\n* mysql\n* postgresql\n* sphinx\n* manticore\n* es (elasticsearch)\n* cloudwatch\n* probe (blackbox)\n* sendgrid\n\nThe operator manages the lifecycle of the following objects:\n* Deployment (one per CR)\n* Service (one per CR)\n* ServiceMonitor (optional, one per CR)\n* GrafanaDashboard (optional, one per Namespace)\n\n### Documentation\nDocumentation can be found on our [website](https://github.com/3scale-ops/prometheus-exporter-operator#documentation).\n\n### Getting help\nIf you encounter any issues while using operator, you can create an issue on our [website](https://github.com/3scale-ops/prometheus-exporter-operator) for bugs, enhancements, or other requests.\n\n### Contributing\nYou can contribute by:\n* Raising any issues you find using Prometheus Exporter Operator\n* Fixing issues by opening [Pull Requests](https://github.com/3scale-ops/prometheus-exporter-operator/pulls)\n* Submitting a patch or opening a PR\n* Improving [documentation](https://github.com/3scale-ops/prometheus-exporter-operator)\n* Talking about Prometheus Exporter Operator\nAll bugs, tasks or enhancements are tracked as [GitHub issues](https://github.com/3scale-ops/prometheus-exporter-operator/issues).\n\n### License\nPrometheus Exporter Operator is licensed under the [Apache 2.0 license](https://github.com/3scale-ops/prometheus-exporter-operator/blob/main/LICENSE)\n","displayName":"Prometheus Exporter Operator","icon":[{"base64data":"PD94bWwgdmVyc2lvbj0iMS4wIiBlbmNvZGluZz0iVVRGLTgiIHN0YW5kYWxvbmU9Im5vIj8+CjxzdmcKICAgeG1sbnM6ZGM9Imh0dHA6Ly9wdXJsLm9yZy9kYy9lbGVtZW50cy8xLjEvIgogICB4bWxuczpjYz0iaHR0cDovL2NyZWF0aXZlY29tbW9ucy5vcmcvbnMjIgogICB4bWxuczpyZGY9Imh0dHA6Ly93d3cudzMub3JnLzE5OTkvMDIvMjItcmRmLXN5bnRheC1ucyMiCiAgIHhtbG5zOnN2Zz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciCiAgIHhtbG5zPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2ZyIKICAgeG1sbnM6c29kaXBvZGk9Imh0dHA6Ly9zb2RpcG9kaS5zb3VyY2Vmb3JnZS5uZXQvRFREL3NvZGlwb2RpLTAuZHRkIgogICB4bWxuczppbmtzY2FwZT0iaHR0cDovL3d3dy5pbmtzY2FwZS5vcmcvbmFtZXNwYWNlcy9pbmtzY2FwZSIKICAgaW5rc2NhcGU6dmVyc2lvbj0iMC45Mi40ICh1bmtub3duKSIKICAgaW5rc2NhcGU6ZXhwb3J0LXlkcGk9IjQxMC4xOSIKICAgaW5rc2NhcGU6ZXhwb3J0LXhkcGk9IjQxMC4xOSIKICAgaW5rc2NhcGU6ZXhwb3J0LWZpbGVuYW1lPSIvVXNlcnMvcmFlbC9Eb3dubG9hZHMvcHJvbWV0aGV1cy1leHBvcnRlci5wbmciCiAgIHNvZGlwb2RpOmRvY25hbWU9InByb21ldGhldXMtZXhwb3J0ZXItM3NjYWxlLW5ldy5zdmciCiAgIGlkPSJzdmc4NDMiCiAgIHByZXNlcnZlQXNwZWN0UmF0aW89InhNaWRZTWlkIG1lZXQiCiAgIHZpZXdCb3g9IjAgMCA3MzYuNDI1NzggNjE5Ljc0ODQ3IgogICBoZWlnaHQ9IjYxOS43NDg0N3B0IgogICB3aWR0aD0iNzM2LjQyNTc4cHQiCiAgIHZlcnNpb249IjEuMCI+CiAgPG1ldGFkYXRhCiAgICAgaWQ9Im1ldGFkYXRhODQ5Ij4KICAgIDxyZGY6UkRGPgogICAgICA8Y2M6V29yawogICAgICAgICByZGY6YWJvdXQ9IiI+CiAgICAgICAgPGRjOmZvcm1hdD5pbWFnZS9zdmcreG1sPC9kYzpmb3JtYXQ+CiAgICAgICAgPGRjOnR5cGUKICAgICAgICAgICByZGY6cmVzb3VyY2U9Imh0dHA6Ly9wdXJsLm9yZy9kYy9kY21pdHlwZS9TdGlsbEltYWdlIiAvPgogICAgICA8L2NjOldvcms+CiAgICA8L3JkZjpSREY+CiAgPC9tZXRhZGF0YT4KICA8ZGVmcwogICAgIGlkPSJkZWZzODQ3IiAvPgogIDxzb2RpcG9kaTpuYW1lZHZpZXcKICAgICBpbmtzY2FwZTpjdXJyZW50LWxheWVyPSJzdmc4NDMiCiAgICAgaW5rc2NhcGU6d2luZG93LW1heGltaXplZD0iMSIKICAgICBpbmtzY2FwZTp3aW5kb3cteT0iMjciCiAgICAgaW5rc2NhcGU6d2luZG93LXg9IjAiCiAgICAgaW5rc2NhcGU6Y3k9IjM1Ny4wNDcxNyIKICAgICBpbmtzY2FwZTpjeD0iMzc0LjM3OTciCiAgICAgaW5rc2NhcGU6em9vbT0iMC42ODc3ODIyNCIKICAgICBpbmtzY2FwZTpsb2NrZ3VpZGVzPSJ0cnVlIgogICAgIHNob3dncmlkPSJmYWxzZSIKICAgICBpZD0ibmFtZWR2aWV3ODQ1IgogICAgIGlua3NjYXBlOndpbmRvdy1oZWlnaHQ9IjEzNzYiCiAgICAgaW5rc2NhcGU6d2luZG93LXdpZHRoPSIyNTYwIgogICAgIGlua3NjYXBlOnBhZ2VzaGFkb3c9IjIiCiAgICAgaW5rc2NhcGU6cGFnZW9wYWNpdHk9IjAiCiAgICAgZ3VpZGV0b2xlcmFuY2U9IjEwIgogICAgIGdyaWR0b2xlcmFuY2U9IjEwIgogICAgIG9iamVjdHRvbGVyYW5jZT0iMTAiCiAgICAgYm9yZGVyb3BhY2l0eT0iMSIKICAgICBpbmtzY2FwZTpkb2N1bWVudC1yb3RhdGlvbj0iMCIKICAgICBib3JkZXJjb2xvcj0iIzY2NjY2NiIKICAgICBwYWdlY29sb3I9IiNmZmZmZmYiIC8+CiAgPHBhdGgKICAgICBkPSJtIDcxNS4xMDM4NiwzMS43NDg0NzYgYyAtMTEuNSw0LjkgLTI3LjMsMTEuNSAtMzUsMTQuNyAtMjAuNiw4LjcgLTUwLDIxLjEgLTY2LjUsMjguMSAtMTcuNSw3LjUgLTM4LjEsMTYuMiAtNzEuMywzMC4wMDAwMDQgLTEzLjYsNS43IC0yNC42LDEwLjcgLTI0LjUsMTEuMSAwLjIsMC4zIDEwLjcsOS40IDIzLjMsMjAuMSAxMi43LDEwLjggMjQuOSwyMS4zIDI3LjIsMjMuNCBsIDQuMywzLjkgLTYuNyw3LjUgYyAtMzEuOSwzNi4xIC04MS41LDg2LjkgLTExMi44LDExNS43IC0xMTAuNiwxMDEuNiAtMjIyLjQsMTcwLjIgLTMyNywyMDAuOCAtMTQuNyw0LjMgLTQxLjEwMDAwMSwxMC42IC00OS41MDAwMDEsMTEuOCAtMS45LDAuMyAtNi40LDEgLTEwLDEuNSAtMy42LDAuNiAtOS40LDEuNCAtMTMsMS43IC0zLjYsMC40IC05LjQsMSAtMTMsMS41IC0zLjYsMC40IC0xNC4yLDAuNyAtMjMuNywwLjYgLTkuNTAwMDAwMywtMC4xIC0xNy4xMDAwMDAzMiwwIC0xNi45MDAwMDAzMiwwLjEgMS40MDAwMDAwMiwxLjQgMzguMzAwMDAwMzIsNi45IDU2LjAwMDAwMDMyLDguMyAxMS41LDEgNTMuNTAwMDAxLDEuMyA2NC4xMDAwMDEsMC41IDIuOCwtMC4yIDkuMywtMC42IDE0LjUsLTEgNS4yLC0wLjMgMTAuNiwtMC44IDEyLC0xIDEuNCwtMC4yIDUuMiwtMC43IDguNSwtMSAzNy40LC0zLjkgODUuNiwtMTQuOSAxMjYuNSwtMjkuMSA5MS40LC0zMS42IDE3Ny4xLC04Mi45IDI2MSwtMTU2LjUgMjAuNSwtMTcuOSA2OC4xLC02NS4yIDg2LjQsLTg1LjcgbCAxMi44LC0xNC4yIDEuOCwyLjIgYyAwLjksMS4zIDEwLjgsMTQgMjEuOSwyOC4zIDExLjEsMTQuMyAyMC41LDI2LjEgMjEsMjYuMyAwLjQsMC4xIDEuNSwtMy43IDIuNSwtOC41IDAuOSwtNC45IDYuNCwtMzMuMSAxMi4xLC02Mi44IDUuNywtMjkuNyAxMi45LC02Ny4xIDE2LC04MyAxNywtODcuODAwMDA0IDE5LjYsLTEwMS43MDAwMDQgMTkuMywtMTAyLjkwMDAwNCAtMC4yLC0wLjggLTgsMiAtMjEuMyw3LjYgeiIKICAgICBpZD0icGF0aDgzNSIKICAgICBpbmtzY2FwZTpjb25uZWN0b3ItY3VydmF0dXJlPSIwIgogICAgIHN0eWxlPSJmaWxsOiM1YTVhNWE7ZmlsbC1vcGFjaXR5OjE7c3Ryb2tlOm5vbmU7c3Ryb2tlLXdpZHRoOjAuMSIgLz4KICA8cGF0aAogICAgIGQ9Im0gMjIuMjAzODU5LDE1Ni41NDg0OCBjIDIsMTUgMTkuNiw2OS42IDI1LDc3LjUgMC44LDEuMSAxLjQsMi41IDEuNCwzLjMgMCwwLjcgMiw1LjQgNC41LDEwLjQgMi41LDUgNC41LDkuNSA0LjUsOS45IDAsMS4xIDE1LjUsMjkuNCAyMyw0MS45IDkuMywxNS43IDM2LjEwMDAwMSw1NC44IDM4LjkwMDAwMSw1NyAwLjQsMC4zIDEuOCwyLjEgMy4xLDQgMS4zLDEuOSAyLjcsMy43IDMsNCAwLjMsMC4zIDIuNCwyLjcgNC41LDUuNSAyLjIsMi43IDQuMiw1LjIgNC41LDUuNSAwLjMsMC4zIDMuNCwzLjkgNyw4IDExLjgsMTMuNyAxNy4yLDE5LjMgMzguOCw0MC43IDExLjgsMTEuNyAyMi4xLDIxLjMgMjIuNywyMS4zIDEuNywwIDYzLjksLTM0LjcgNjQuMywtMzUuOCAwLjEsLTAuNSAtNC44LC00IC0xMSwtNy43IC04MS42LC00OS4zIC0xNTYuNjAwMDAxLC0xMTcgLTE5OC41MDAwMDEsLTE3OS41IC0xNS4zLC0yMi44IC0yNywtNDUuMyAtMzUuMiwtNjcuNSAtMSwtMi43IC0xLC0yLjYgLTAuNSwxLjUgeiIKICAgICBpZD0icGF0aDgzNyIKICAgICBpbmtzY2FwZTpjb25uZWN0b3ItY3VydmF0dXJlPSIwIgogICAgIHN0eWxlPSJmaWxsOiNlYzdhMDg7ZmlsbC1vcGFjaXR5OjE7c3Ryb2tlOm5vbmU7c3Ryb2tlLXdpZHRoOjAuMSIgLz4KICA8cGF0aAogICAgIGQ9Im0gMzE4LjMwMzg2LDQ3OS40NDg0OCBjIC0yNi44LDkuNyAtNDguNywxNy45IC00OC43LDE4LjMgMCwxLjIgMzEuNSwyMS42IDUyLjgsMzQuMiA1NCwzMiAxMjkuOSw2NiAxOTAuMiw4NS4xIGwgOC41LDIuNyAyNywtMC42IGMgMjUuOSwtMC42IDI3LjgsLTAuOCA0OCwtNC42IDQwLjUsLTcuNiA2OC43LC0xNy45IDg5LjIsLTMyLjYgNi4xLC00LjMgMTAuOSwtOC4xIDEwLjcsLTguNCAtMS40LC0xLjQgLTUyLjgsLTE2IC04OS40LC0yNS40IC0xNCwtMy43IC0yNi40LC03IC0yNy41LC03LjUgLTEuMSwtMC41IC02LjEsLTEuOCAtMTEuMSwtMyAtMTAsLTIuMyAtNjQuNCwtMjAuMyAtOTAuNywtMzAgLTMwLjgsLTExLjQgLTcyLjIsLTI4LjUgLTEwNC43LC00My40IGwgLTUuNiwtMi41IHoiCiAgICAgaWQ9InBhdGg4MzkiCiAgICAgaW5rc2NhcGU6Y29ubmVjdG9yLWN1cnZhdHVyZT0iMCIKICAgICBzdHlsZT0iZmlsbDojZWM3YTA4O2ZpbGwtb3BhY2l0eToxO3N0cm9rZTpub25lO3N0cm9rZS13aWR0aDowLjEiIC8+Cjwvc3ZnPgo=","mediatype":"image/svg+xml"}],"install":{"spec":{"deployments":[{"label":{"control-plane":"controller-manager"},"name":"prometheus-exporter-operator-controller-manager","spec":{"replicas":1,"selector":{"matchLabels":{"control-plane":"controller-manager"}},"strategy":{},"template":{"metadata":{"annotations":{"kubectl.kubernetes.io/default-container":"manager"},"labels":{"control-plane":"controller-manager"}},"spec":{"containers":[{"args":["--health-probe-bind-address=:6789","--metrics-bind-address=0.0.0.0:8080","--leader-elect","--leader-election-id=prometheus-exporter-operator"],"env":[{"name":"ANSIBLE_GATHERING","value":"explicit"},{"name":"WATCH_NAMESPACE","valueFrom":{"fieldRef":{"fieldPath":"metadata.annotations['olm.targetNamespaces']"}}}],"image":"quay.io/3scale/prometheus-exporter-operator:v0.9.0-alpha.1","livenessProbe":{"httpGet":{"path":"/healthz","port":6789},"initialDelaySeconds":30,"periodSeconds":20,"timeoutSeconds":5},"name":"manager","ports":[{"containerPort":8080,"name":"http"}],"readinessProbe":{"httpGet":{"path":"/readyz","port":6789},"initialDelaySeconds":5,"periodSeconds":10,"timeoutSeconds":5},"resources":{"limits":{"cpu":"1","memory":"1Gi"},"requests":{"cpu":"10m","memory":"128Mi"}},"securityContext":{"allowPrivilegeEscalation":false,"capabilities":{"drop":["ALL"]}}}],"securityContext":{"runAsNonRoot":true},"serviceAccountName":"prometheus-exporter-operator-controller-manager","terminationGracePeriodSeconds":10}}}}],"permissions":[{"rules":[{"apiGroups":[""],"resources":["configmaps"],"verbs":["get","list","watch","create","update","patch","delete"]},{"apiGroups":["coordination.k8s.io"],"resources":["leases"],"verbs":["get","list","watch","create","update","patch","delete"]},{"apiGroups":[""],"resources":["events"],"verbs":["create","patch"]},{"apiGroups":["apps"],"resources":["deployments"],"verbs":["create","delete","get","list","patch","update","watch"]},{"apiGroups":[""],"resources":["services"],"verbs":["create","delete","get","list","patch","update","watch"]},{"apiGroups":[""],"resources":["secrets"],"verbs":["get","list","watch"]},{"apiGroups":[""],"resources":["configmaps"],"verbs":["get","list","watch"]},{"apiGroups":["monitoring.coreos.com"],"resources":["servicemonitors"],"verbs":["create","delete","get","list","patch","update","watch"]},{"apiGroups":["integreatly.org","grafana.integreatly.org"],"resources":["grafanadashboards"],"verbs":["create","delete","get","list","patch","update","watch"]},{"apiGroups":["monitoring.3scale.net"],"resources":["prometheusexporters","prometheusexporters/status","prometheusexporters/finalizers"],"verbs":["create","delete","get","list","patch","update","watch"]}],"serviceAccountName":"prometheus-exporter-operator-controller-manager"}]},"strategy":"deployment"},"installModes":[{"supported":true,"type":"OwnNamespace"},{"supported":true,"type":"SingleNamespace"},{"supported":true,"type":"MultiNamespace"},{"supported":true,"type":"AllNamespaces"}],"keywords":["monitoring","metrics","observability","prometheus","exporter","grafana","mysql","postgresql","memcached","redis","sphinx","elasticsearch","cloudwatch","blackbox","sendgrid","manticore"],"links":[{"name":"GitHub","url":"https://github.com/3scale-ops/prometheus-exporter-operator"}],"maintainers":[{"email":"3scale-operations@redhat.com","name":"3scale Ops"}],"maturity":"alpha","provider":{"name":"Red Hat","url":"https://www.redhat.com"},"version":"0.9.0-alpha.1"}} relatedImages: -- image: quay.io/3scale/prometheus-exporter-operator-bundle:v0.8.2-alpha.2 +- image: quay.io/3scale/prometheus-exporter-operator-bundle:v0.9.0-alpha.1 name: "" -- image: quay.io/3scale/prometheus-exporter-operator:v0.8.2-alpha.2 +- image: quay.io/3scale/prometheus-exporter-operator:v0.9.0-alpha.1 name: "" schema: olm.bundle diff --git a/catalog/prometheus-exporter-operator/stable-channel.yaml b/catalog/prometheus-exporter-operator/stable-channel.yaml index e2ef8bb..a9c36fa 100644 --- a/catalog/prometheus-exporter-operator/stable-channel.yaml +++ b/catalog/prometheus-exporter-operator/stable-channel.yaml @@ -17,8 +17,6 @@ entries: replaces: prometheus-exporter-operator.v0.7.0 - name: prometheus-exporter-operator.v0.8.1 replaces: prometheus-exporter-operator.v0.8.0 - - name: prometheus-exporter-operator.v0.8.2 - replaces: prometheus-exporter-operator.v0.8.1 name: stable package: prometheus-exporter-operator schema: olm.channel diff --git a/config/manager/kustomization.yaml b/config/manager/kustomization.yaml index 74a80f2..c6bb5c2 100644 --- a/config/manager/kustomization.yaml +++ b/config/manager/kustomization.yaml @@ -8,4 +8,4 @@ kind: Kustomization images: - name: controller newName: quay.io/3scale/prometheus-exporter-operator - newTag: v0.8.2 + newTag: v0.9.0-alpha.1 From ce07d4f6cc6035c5f87e8b3615ef23680d7c1ece Mon Sep 17 00:00:00 2001 From: Rael Garcia Arnes Date: Fri, 22 Nov 2024 12:15:12 +0100 Subject: [PATCH 4/6] release: 0.9.0 --- Makefile | 2 +- bundle.Dockerfile | 3 ++- .../prometheus-exporter-operator.clusterserviceversion.yaml | 6 +++--- bundle/metadata/annotations.yaml | 3 ++- config/manager/kustomization.yaml | 2 +- 5 files changed, 9 insertions(+), 7 deletions(-) diff --git a/Makefile b/Makefile index a01ae96..aaa9dcd 100644 --- a/Makefile +++ b/Makefile @@ -2,7 +2,7 @@ # To re-generate a bundle for another specific version without changing the standard setup, you can: # - use the VERSION as arg of the bundle target (e.g make bundle VERSION=0.0.2) # - use environment variables to overwrite this value (e.g export VERSION=0.0.2) -VERSION ?= 0.9.0-alpha.1 +VERSION ?= 0.9.0 # CHANNELS define the bundle channels used in the bundle. # Add a new line here if you would like to change its default config. (E.g CHANNELS = "candidate,fast,stable") diff --git a/bundle.Dockerfile b/bundle.Dockerfile index 9fc49ea..07c3405 100644 --- a/bundle.Dockerfile +++ b/bundle.Dockerfile @@ -5,7 +5,8 @@ LABEL operators.operatorframework.io.bundle.mediatype.v1=registry+v1 LABEL operators.operatorframework.io.bundle.manifests.v1=manifests/ LABEL operators.operatorframework.io.bundle.metadata.v1=metadata/ LABEL operators.operatorframework.io.bundle.package.v1=prometheus-exporter-operator -LABEL operators.operatorframework.io.bundle.channels.v1=alpha +LABEL operators.operatorframework.io.bundle.channels.v1=alpha,stable +LABEL operators.operatorframework.io.bundle.channel.default.v1=alpha LABEL operators.operatorframework.io.metrics.builder=operator-sdk-v1.24.0 LABEL operators.operatorframework.io.metrics.mediatype.v1=metrics+v1 LABEL operators.operatorframework.io.metrics.project_layout=ansible.sdk.operatorframework.io/v1 diff --git a/bundle/manifests/prometheus-exporter-operator.clusterserviceversion.yaml b/bundle/manifests/prometheus-exporter-operator.clusterserviceversion.yaml index 999844a..2893e16 100644 --- a/bundle/manifests/prometheus-exporter-operator.clusterserviceversion.yaml +++ b/bundle/manifests/prometheus-exporter-operator.clusterserviceversion.yaml @@ -34,7 +34,7 @@ metadata: operators.operatorframework.io/project_layout: ansible.sdk.operatorframework.io/v1 repository: https://github.com/3scale-ops/prometheus-exporter-operator support: Red Hat, Inc. - name: prometheus-exporter-operator.v0.9.0-alpha.1 + name: prometheus-exporter-operator.v0.9.0 namespace: placeholder spec: apiservicedefinitions: {} @@ -125,7 +125,7 @@ spec: valueFrom: fieldRef: fieldPath: metadata.annotations['olm.targetNamespaces'] - image: quay.io/3scale/prometheus-exporter-operator:v0.9.0-alpha.1 + image: quay.io/3scale/prometheus-exporter-operator:v0.9.0 livenessProbe: httpGet: path: /healthz @@ -310,4 +310,4 @@ spec: provider: name: Red Hat url: https://www.redhat.com - version: 0.9.0-alpha.1 + version: 0.9.0 diff --git a/bundle/metadata/annotations.yaml b/bundle/metadata/annotations.yaml index aabb48c..5639002 100644 --- a/bundle/metadata/annotations.yaml +++ b/bundle/metadata/annotations.yaml @@ -4,7 +4,8 @@ annotations: operators.operatorframework.io.bundle.manifests.v1: manifests/ operators.operatorframework.io.bundle.metadata.v1: metadata/ operators.operatorframework.io.bundle.package.v1: prometheus-exporter-operator - operators.operatorframework.io.bundle.channels.v1: alpha + operators.operatorframework.io.bundle.channels.v1: alpha,stable + operators.operatorframework.io.bundle.channel.default.v1: alpha operators.operatorframework.io.metrics.builder: operator-sdk-v1.24.0 operators.operatorframework.io.metrics.mediatype.v1: metrics+v1 operators.operatorframework.io.metrics.project_layout: ansible.sdk.operatorframework.io/v1 diff --git a/config/manager/kustomization.yaml b/config/manager/kustomization.yaml index c6bb5c2..03a37da 100644 --- a/config/manager/kustomization.yaml +++ b/config/manager/kustomization.yaml @@ -8,4 +8,4 @@ kind: Kustomization images: - name: controller newName: quay.io/3scale/prometheus-exporter-operator - newTag: v0.9.0-alpha.1 + newTag: v0.9.0 From 45c2c67afe6b37541281520dc546ef41a88425e4 Mon Sep 17 00:00:00 2001 From: Rael Garcia Date: Fri, 22 Nov 2024 12:30:38 +0100 Subject: [PATCH 5/6] docs: remove stable comment from release-publish target --- Makefile | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/Makefile b/Makefile index aaa9dcd..530af16 100644 --- a/Makefile +++ b/Makefile @@ -319,7 +319,7 @@ bundle-publish: prepare-release bundle-push ## Publish new bundle. catalog-publish: catalog-add-bundle catalog-push catalog-push-latest ## Build and push the catalog image. -release-publish: container-push bundle-publish catalog-publish ## Publish a new stable release (operator, catalog and bundle). +release-publish: container-push bundle-publish catalog-publish ## Publish a new release (operator, catalog and bundle). ################################################### #### Custom Targets to manually test with Kind #### From 6ea4b13562a4ba329c5a5eed80c32c2c919f6e3a Mon Sep 17 00:00:00 2001 From: Rael Garcia Arnes Date: Fri, 22 Nov 2024 12:44:56 +0100 Subject: [PATCH 6/6] docs: update release documentation with latests targets --- docs/release.md | 13 ++++--------- 1 file changed, 4 insertions(+), 9 deletions(-) diff --git a/docs/release.md b/docs/release.md index c3282e1..864e427 100644 --- a/docs/release.md +++ b/docs/release.md @@ -6,13 +6,7 @@ ## Alpha -- If it is an **alpha** release, execute the following target to create appropiate `alpha` bundle files: - -```bash -make prepare-alpha-release -``` - -- Then you can manually execute opeator, bundle and catalog build/push. +Execute following target to generate, build and push the operator, bundle and catalog images. ```bash make release-publish @@ -20,10 +14,11 @@ make release-publish ## Stable -- But if it is an **stable** release, execute the following target to create appropiate `alpha` and `stable` bundle files: +If it is an **stable** release, container images will be built in GitHub Actions, +so you only need to create and commit appropiate bundle files executing: ```bash -make prepare-stable-release +make prepare-release ``` - Then open a [Pull Request](https://github.com/3scale-ops/prometheus-exporter-operator/pulls), and the [Release GitHub Action](https://github.com/3scale-ops/prometheus-exporter-operator/actions/workflows/release.yaml) will automatically detect if it is new release or not, in order to create it by building/pushing new operator and bundle.