diff --git a/.gitignore b/.gitignore index 1a6109a..f558a7e 100644 --- a/.gitignore +++ b/.gitignore @@ -1,4 +1,3 @@ - # Binaries for programs and plugins *.exe *.exe~ @@ -13,3 +12,6 @@ bin *.swo *~ kubeconfig + +# tmp folder +tmp diff --git a/Makefile b/Makefile index f282bfd..4c5ef30 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-alpha.1 +VERSION ?= 0.8.2-alpha.2 # 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/manifests/prometheus-exporter-operator.clusterserviceversion.yaml b/bundle/manifests/prometheus-exporter-operator.clusterserviceversion.yaml index 2cff51e..ab1ba30 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-alpha.1 + name: prometheus-exporter-operator.v0.8.2-alpha.2 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-alpha.1 + image: quay.io/3scale/prometheus-exporter-operator:v0.8.2-alpha.2 livenessProbe: httpGet: path: /healthz @@ -310,4 +310,4 @@ spec: provider: name: Red Hat url: https://www.redhat.com - version: 0.8.2-alpha.1 + version: 0.8.2-alpha.2 diff --git a/catalog/prometheus-exporter-operator/alpha-channel.yaml b/catalog/prometheus-exporter-operator/alpha-channel.yaml index 2a7115e..58f2a48 100644 --- a/catalog/prometheus-exporter-operator/alpha-channel.yaml +++ b/catalog/prometheus-exporter-operator/alpha-channel.yaml @@ -19,6 +19,8 @@ entries: replaces: prometheus-exporter-operator.v0.8.0 - name: prometheus-exporter-operator.v0.8.2-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: alpha package: prometheus-exporter-operator schema: olm.channel 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.8.2-alpha.2.clusterserviceversion.yaml new file mode 100644 index 0000000..1b9d387 --- /dev/null +++ b/catalog/prometheus-exporter-operator/objects/prometheus-exporter-operator.v0.8.2-alpha.2.clusterserviceversion.yaml @@ -0,0 +1,32 @@ +--- +image: quay.io/3scale/prometheus-exporter-operator-bundle:v0.8.2-alpha.2 +name: prometheus-exporter-operator.v0.8.2-alpha.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-alpha.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-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"}} +relatedImages: +- image: quay.io/3scale/prometheus-exporter-operator-bundle:v0.8.2-alpha.2 + name: "" +- image: quay.io/3scale/prometheus-exporter-operator:v0.8.2-alpha.2 + name: "" +schema: olm.bundle diff --git a/config/manager/kustomization.yaml b/config/manager/kustomization.yaml index 928a462..6ad9408 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-alpha.1 + newTag: v0.8.2-alpha.2 diff --git a/examples/README.md b/examples/README.md index 56f7951..024a1de 100644 --- a/examples/README.md +++ b/examples/README.md @@ -14,77 +14,86 @@ Once the deployed prometheus-exporter operator is up and running and watching fo ## Memcached -* Official doc: https://github.com/prometheus/memcached_exporter +- Official doc: https://github.com/prometheus/memcached_exporter ### Deploy example -* Create `memcached-exporter` example ([example-DB](memcached/memcached-db-service.yaml), [example-CR](memcached/memcached-cr.yaml)): + +- Create `memcached-exporter` example ([example-DB](memcached/memcached-db-service.yaml), [example-CR](memcached/memcached-cr.yaml)): + ```bash $ make memcached-create ``` -* Once tested, delete created objects: + +- Once tested, delete created objects: + ```bash $ make memcached-delete ``` ## Redis -* Official doc: https://github.com/oliver006/redis_exporter +- Official doc: https://github.com/oliver006/redis_exporter ### Deploy example -* Create `redis-exporter` example ([example-DB](redis/redis-db-service.yaml), [example-CR](redis/redis-cr.yaml), [example-CR-2](redis/redis-cr-2.yaml)): +- Create `redis-exporter` example ([example-DB](redis/redis-db-service.yaml), [example-CR](redis/redis-cr.yaml), [example-CR-2](redis/redis-cr-2.yaml)): + ```bash $ make redis-create ``` -* Once tested, delete created objects: + +- Once tested, delete created objects: + ```bash $ make redis-delete ``` ## MySQL -* Official doc: https://github.com/prometheus/mysqld_exporter +- Official doc: https://github.com/prometheus/mysqld_exporter ### CR needed extra object -* **The Secret should have been previously created as the operator expects it**: - * **[mysql-secret-example](mysql/mysql-secret.yaml) (Remember to set object name on CR field `dbConnectionStringSecretName`)** +- **The Secret should have been previously created as the operator expects it**: + - **[mysql-secret-example](mysql/mysql-secret.yaml) (Remember to set object name on CR field `dbConnectionStringSecretName`)** ### Permission requirements -* In addition, a database user with specific grants is needed *(this is just an example, go to the official doc for the latest information)*: +- In addition, a database user with specific grants is needed _(this is just an example, go to the official doc for the latest information)_: ```sql CREATE USER 'exporter'@'%' IDENTIFIED BY 'XXXXXXXX' WITH MAX_USER_CONNECTIONS 3; GRANT PROCESS, REPLICATION CLIENT, SELECT ON *.* TO 'exporter'@'%'; ``` -> **NOTE** ->
It is recommended to set a max connection limit for the user to avoid overloading the server with monitoring scrapes under heavy load. +> **NOTE** >
It is recommended to set a max connection limit for the user to avoid overloading the server with monitoring scrapes under heavy load. ### Deploy example -* Create `mysql-exporter` example ([example-secret](mysql/mysql-secret.yaml), [example-DB](mysql/mysql-db-service.yaml), [example-CR](mysql/mysql-cr.yaml)): +- Create `mysql-exporter` example ([example-secret](mysql/mysql-secret.yaml), [example-DB](mysql/mysql-db-service.yaml), [example-CR](mysql/mysql-cr.yaml)): + ```bash $ make mysql-create ``` -* Once tested, delete created objects: + +- Once tested, delete created objects: + ```bash $ make mysql-delete ``` ## PostgreSQL -* Official doc: https://github.com/wrouesnel/postgres_exporter +- Official doc: https://github.com/prometheus-community/postgres_exporter ### CR needed extra object -* **The Secret should have been previously created as the operator expects it**: - * **[postgresql-secret-example](postgresql/postgresql-secret.yaml) (Remember to set the object name on the CR field `dbConnectionStringSecretName`)** +- **The Secret should have been previously created as the operator expects it**: + - **[postgresql-secret-example](postgresql/postgresql-secret.yaml) (Remember to set the object name on the CR field `dbConnectionStringSecretName`)** ### Permission requirements -* In addition, a database user with specific grants is needed*(this is just an example, go to official doc for latest information)*. To be able to collect metrics from `pg_stat_activity` and `pg_stat_replication` as `non-superuser` you have to create views as a `superuser`, and assign permissions separately to those. In PostgreSQL, views run with the permissions of the user that created them so they can act as security barriers *(this is just an example, go to official doc for latest information)*: +- In addition, a database user with specific grants is needed*(this is just an example, go to official doc for latest information)*. To be able to collect metrics from `pg_stat_activity` and `pg_stat_replication` as `non-superuser` you have to create views as a `superuser`, and assign permissions separately to those. In PostgreSQL, views run with the permissions of the user that created them so they can act as security barriers _(this is just an example, go to official doc for latest information)_: ```sql CREATE USER postgres_exporter PASSWORD 'password'; @@ -107,145 +116,165 @@ CREATE VIEW postgres_exporter.pg_stat_replication AS GRANT SELECT ON postgres_exporter.pg_stat_replication TO postgres_exporter; ``` -> **NOTE** ->
Remember to use `postgres` database name in the connection string: +> **NOTE** >
Remember to use `postgres` database name in the connection string: +> > ``` > DATA_SOURCE_NAME=postgresql://postgres_exporter:password@localhost:5432/postgres?sslmode=disable > ``` ### Deploy example -* Create `postgresql-exporter` example ([example-secret](postgresql/postgresql-secret.yaml), [example-DB](postgresql/postgresql-db-service.yaml), [example-CR](postgresql/postgresql-cr.yaml)): +- Create `postgresql-exporter` example ([example-secret](postgresql/postgresql-secret.yaml), [example-DB](postgresql/postgresql-db-service.yaml), [example-CR](postgresql/postgresql-cr.yaml)): + ```bash $ make postgresql-create ``` -* Once tested, delete created objects: + +- Once tested, delete created objects: + ```bash $ make postgresql-delete ``` ## Sphinx -* Official doc: https://github.com/foxdalas/sphinx_exporter +- Official doc: https://github.com/foxdalas/sphinx_exporter ### Deploy example -* **Make sure you have a Sphinx instance available, and dbHost/dbPort are correctly set on CR example file** -* Create `sphinx-exporter` example ([example-CR](sphinx/sphinx-cr.yaml)): +- **Make sure you have a Sphinx instance available, and dbHost/dbPort are correctly set on CR example file** +- Create `sphinx-exporter` example ([example-CR](sphinx/sphinx-cr.yaml)): + ```bash $ make sphinx-create ``` -* Once tested, delete created objects: + +- Once tested, delete created objects: + ```bash $ make sphinx-delete ``` ## Manticore -* Official doc: https://github.com/manticoresoftware/manticoresearch-prometheus +- Official doc: https://github.com/manticoresoftware/manticoresearch-prometheus ### Deploy example -* **Make sure you have a Manticore instance available, and dbHost/dbPort are correctly set on CR example file** -* Create `manticore-exporter` example ([example-CR](manticore/manticore-cr.yaml)): +- **Make sure you have a Manticore instance available, and dbHost/dbPort are correctly set on CR example file** +- Create `manticore-exporter` example ([example-CR](manticore/manticore-cr.yaml)): + ```bash $ make manticore-create ``` -* Once tested, delete created objects: + +- Once tested, delete created objects: + ```bash $ make manticore-delete ``` ## Elasticsearch -* Official doc: https://github.com/justwatchcom/elasticsearch_exporter +- Official doc: https://github.com/prometheus-community/elasticsearch_exporter ### Deploy example -* **Make sure you have an Elasticsearch cluster available and that dbHost/dbPort are correctly set on CR example file** -* Create `elasticsearch-exporter` example ([example-CR](elasticsearch/es-cr.yaml)): +- **Make sure you have an Elasticsearch cluster available and that dbHost/dbPort are correctly set on CR example file** +- Create `elasticsearch-exporter` example ([example-CR](elasticsearch/es-cr.yaml)): + ```bash $ make elasticsearch-create ``` -* Once tested, delete created objects: + +- Once tested, delete created objects: + ```bash $ make elasticsearch-delete ``` ## AWS CloudWatch -* Official doc: https://github.com/prometheus/cloudwatch_exporter -> **NOTE** ->
The metrics from some services like `AWSClientVPN` are reported to AWS CloudWatch every **5 minutes** (instead of default **1 minute**), because they are not critical services like databases (RDS/EC) where details are more important. So on thoses cases, scrapping AWS Cloudwatch metrics every 1 minute makes no sense, so it is better to specify the var `period_seconds: 300` (instead of default `period_seconds: 60`) in the metric definition in the configmap. In addition, for those cases reporting metrics every 5 minutes, empty spaces (null values) could appear empty in the prometheus time series database, so in order to configure alerts, you can use queries like `max_over_time(aws_clientvpn_crl_days_to_expiry_average[10m]) < 2`, which takes max value within last 10 minutes, so we guarantee there is always a value that can fire an alert that won't disappear from time to time although alert might not be really recovered. +- Official doc: https://github.com/prometheus/cloudwatch_exporter + > **NOTE** >
The metrics from some services like `AWSClientVPN` are reported to AWS CloudWatch every **5 minutes** (instead of default **1 minute**), because they are not critical services like databases (RDS/EC) where details are more important. So on thoses cases, scrapping AWS Cloudwatch metrics every 1 minute makes no sense, so it is better to specify the var `period_seconds: 300` (instead of default `period_seconds: 60`) in the metric definition in the configmap. In addition, for those cases reporting metrics every 5 minutes, empty spaces (null values) could appear empty in the prometheus time series database, so in order to configure alerts, you can use queries like `max_over_time(aws_clientvpn_crl_days_to_expiry_average[10m]) < 2`, which takes max value within last 10 minutes, so we guarantee there is always a value that can fire an alert that won't disappear from time to time although alert might not be really recovered. ### CR needed extra objects -* **The Secret/ConfigMap should have been previously created as the operator expects them**: - * **[cw-secret-example](cloudwatch/cloudwatch-secret.yaml) (Remember to set the object name on the CR field `awsCredentialsSecretName`)** - * **[cw-configmap-example](cloudwatch/cloudwatch-configmap.yaml) (Remember to set the object name on the CR field `configurationConfigmapName`)** +- **The Secret/ConfigMap should have been previously created as the operator expects them**: + - **[cw-secret-example](cloudwatch/cloudwatch-secret.yaml) (Remember to set the object name on the CR field `awsCredentialsSecretName`)** + - **[cw-configmap-example](cloudwatch/cloudwatch-configmap.yaml) (Remember to set the object name on the CR field `configurationConfigmapName`)** ### Permission requirements -* In addition, the created IAM user requires some specific IAM permissions: - * `cloudwatch:ListMetrics` - * `cloudwatch:GetMetricStatistics` - * `tag:GetResources` +- In addition, the created IAM user requires some specific IAM permissions: + - `cloudwatch:ListMetrics` + - `cloudwatch:GetMetricStatistics` + - `tag:GetResources` ### Deploy example -* Create `cloudwatch-exporter` example ([example-secret](cloudwatch/cloudwatch-secret.yaml), [example-configmap](cloudwatch/cloudwatch-configmap.yaml), [example-CR](cloudwatch/cloudwatch-cr.yaml)): +- Create `cloudwatch-exporter` example ([example-secret](cloudwatch/cloudwatch-secret.yaml), [example-configmap](cloudwatch/cloudwatch-configmap.yaml), [example-CR](cloudwatch/cloudwatch-cr.yaml)): + ```bash $ make cloudwatch-create ``` -* Once tested, delete the created objects: + +- Once tested, delete the created objects: + ```bash $ make cloudwatch-delete ``` ## Probe -* Official doc: https://github.com/prometheus/blackbox_exporter +- Official doc: https://github.com/prometheus/blackbox_exporter ### CR needed extra object -* **The ConfigMap should have been previously created as the operator expects it**: - * **[probe-configmap-example](probe/probe-configmap.yaml) (Remember to set the object name on the CR field `configurationConfigmapName`)** -* **The optional Secret (replacing previous ConfigMap) should have been previously created as the operator expects it (in case config includes sensitive data and so you prefer to use a Secret** - * **[probe-secret-example](probe/probe-secret.yaml) (Remember to set the object name on the CR field `configurationSecretName` replacing previous `configurationConfigmapName`)** +- **The ConfigMap should have been previously created as the operator expects it**: + - **[probe-configmap-example](probe/probe-configmap.yaml) (Remember to set the object name on the CR field `configurationConfigmapName`)** +- **The optional Secret (replacing previous ConfigMap) should have been previously created as the operator expects it (in case config includes sensitive data and so you prefer to use a Secret** + - **[probe-secret-example](probe/probe-secret.yaml) (Remember to set the object name on the CR field `configurationSecretName` replacing previous `configurationConfigmapName`)** -> **NOTE** ->
To deploy a probe exporter (blackbox exporter) it is just needed the configmap (or secret) with blackbox modules configuration, and a single `PrometheusExporter` custom resource of type `probe`. But then, in order to be able to scrape different targets, you need to deploy for every endpoint that you want to monitor, a prometheus `Probe` resource with the `prober.url` pointing to the deployed probe exporter service `prometheus-exporter-probe-${CR_NAME}.${NAMESPACE}.svc:9115`, and then configure the specific module and target. +> **NOTE** >
To deploy a probe exporter (blackbox exporter) it is just needed the configmap (or secret) with blackbox modules configuration, and a single `PrometheusExporter` custom resource of type `probe`. But then, in order to be able to scrape different targets, you need to deploy for every endpoint that you want to monitor, a prometheus `Probe` resource with the `prober.url` pointing to the deployed probe exporter service `prometheus-exporter-probe-${CR_NAME}.${NAMESPACE}.svc:9115`, and then configure the specific module and target. ### Target Probe extra objects - * **[probe-target-probe-example](probe/probe-target-probe.yaml) (Remember to set the `prober.url` pointing to the deployed probe exporter service `prometheus-exporter-probe-${CR_NAME}.${NAMESPACE}.svc:9115`)** + +- **[probe-target-probe-example](probe/probe-target-probe.yaml) (Remember to set the `prober.url` pointing to the deployed probe exporter service `prometheus-exporter-probe-${CR_NAME}.${NAMESPACE}.svc:9115`)** ### Deploy example -* Create `probe-exporter` example ([example-configmap](probe/probe-configmap.yaml), [example-CR](probe/probe-cr.yaml), [example-target-probe](probe/probe-target-probe.yaml)): +- Create `probe-exporter` example ([example-configmap](probe/probe-configmap.yaml), [example-CR](probe/probe-cr.yaml), [example-target-probe](probe/probe-target-probe.yaml)): + ```bash $ make probe-create ``` -* Once tested, delete the created objects: + +- Once tested, delete the created objects: + ```bash $ make probe-delete ``` ## Sendgrid -* Official doc: https://github.com/chatwork/sendgrid-stats-exporter +- Official doc: https://github.com/chatwork/sendgrid-stats-exporter ### CR needed extra object -* **The Secret should have been previously created as the operator expects it**: - * **[sendgrid-secret-example](sendgrid/sendgrid-secret.yaml) (Remember to set the object name on the CR field `sendgridCredentialsSecretName`)** +- **The Secret should have been previously created as the operator expects it**: + - **[sendgrid-secret-example](sendgrid/sendgrid-secret.yaml) (Remember to set the object name on the CR field `sendgridCredentialsSecretName`)** ### Deploy example -* Create `sendgrid-exporter` example ([example-secret](sendgrid/sendgrid-secret.yaml), [example-CR](sendgrid/sendgrid-cr.yaml)): +- Create `sendgrid-exporter` example ([example-secret](sendgrid/sendgrid-secret.yaml), [example-CR](sendgrid/sendgrid-cr.yaml)): + ```bash $ make sendgrid-create ``` -* Once tested, delete the created objects: + +- Once tested, delete the created objects: + ```bash $ make sendgrid-delete -``` \ No newline at end of file +``` diff --git a/roles/prometheusexporter/exporters/cloudwatch/vars.yml b/roles/prometheusexporter/exporters/cloudwatch/vars.yml index a63dd72..99e7582 100644 --- a/roles/prometheusexporter/exporters/cloudwatch/vars.yml +++ b/roles/prometheusexporter/exporters/cloudwatch/vars.yml @@ -1,8 +1,7 @@ --- - # Exporter image_name: "prom/cloudwatch-exporter" -image_version: "cloudwatch_exporter-0.11.0" +image_version: "v0.16.0" port: 9106 liveness_probe_timeout_seconds: 45 liveness_probe_period_seconds: 60 @@ -20,7 +19,6 @@ resources_limits_memory: "256Mi" # Custom aws_credentials_secret_name: "prometheus-exporter-{{ type }}-{{ ansible_operator_meta.name }}" configuration_configmap_name: "prometheus-exporter-{{ type }}-{{ ansible_operator_meta.name }}" - ###### Example of Secret # # If you don't specify CR field awsCredentialsSecretName, it will be used default Secret name "prometheus-exporter-cloudwatch-{{ CR_NAME }}" diff --git a/roles/prometheusexporter/exporters/es/container.yml.j2 b/roles/prometheusexporter/exporters/es/container.yml.j2 index 7ad67fb..484a53f 100644 --- a/roles/prometheusexporter/exporters/es/container.yml.j2 +++ b/roles/prometheusexporter/exporters/es/container.yml.j2 @@ -1,4 +1,3 @@ -command: - - "/bin/elasticsearch_exporter" +args: - "--es.uri={{ db_host }}:{{ db_port }}" - "--es.all" \ No newline at end of file diff --git a/roles/prometheusexporter/exporters/es/vars.yml b/roles/prometheusexporter/exporters/es/vars.yml index bb766f4..af67909 100644 --- a/roles/prometheusexporter/exporters/es/vars.yml +++ b/roles/prometheusexporter/exporters/es/vars.yml @@ -1,8 +1,7 @@ --- - # Exporter -image_name: "justwatch/elasticsearch_exporter" -image_version: "1.1.0" +image_name: "quay.io/prometheuscommunity/elasticsearch-exporter" +image_version: "v1.8.0" port: 9114 liveness_probe_timeout_seconds: 10 liveness_probe_period_seconds: 15 diff --git a/roles/prometheusexporter/exporters/manticore/vars.yml b/roles/prometheusexporter/exporters/manticore/vars.yml index fab9a50..7148147 100644 --- a/roles/prometheusexporter/exporters/manticore/vars.yml +++ b/roles/prometheusexporter/exporters/manticore/vars.yml @@ -1,8 +1,7 @@ --- - # Exporter image_name: "manticoresearch/prometheus-exporter" -image_version: "6.2.13.0" +image_version: "6.3.2.0" port: 8081 liveness_probe_timeout_seconds: 3 liveness_probe_period_seconds: 15 diff --git a/roles/prometheusexporter/exporters/memcached/vars.yml b/roles/prometheusexporter/exporters/memcached/vars.yml index b010481..e5ee711 100644 --- a/roles/prometheusexporter/exporters/memcached/vars.yml +++ b/roles/prometheusexporter/exporters/memcached/vars.yml @@ -1,8 +1,7 @@ --- - # Exporter image_name: "prom/memcached-exporter" -image_version: "v0.6.0" +image_version: "v0.15.0" port: 9150 liveness_probe_timeout_seconds: 3 liveness_probe_period_seconds: 15 diff --git a/roles/prometheusexporter/exporters/mysql/vars.yml b/roles/prometheusexporter/exporters/mysql/vars.yml index 89ff2d7..81a4762 100644 --- a/roles/prometheusexporter/exporters/mysql/vars.yml +++ b/roles/prometheusexporter/exporters/mysql/vars.yml @@ -1,8 +1,7 @@ --- - # Exporter image_name: "prom/mysqld-exporter" -image_version: "v0.12.1" +image_version: "v0.14.0" # v0.15 and above introduces breaking changes, replacing connection string secret with a .my.cnf based configuration port: 9104 liveness_probe_timeout_seconds: 3 liveness_probe_period_seconds: 15 @@ -19,7 +18,6 @@ resources_limits_memory: "64Mi" # Custom db_connection_string_secret_name: "prometheus-exporter-{{ type }}-{{ ansible_operator_meta.name }}" - ###### Example of Secret # # If you don't specify CR field dbConnectionStringSecretName, it will be used default Secret name "prometheus-exporter-mysql-{{ CR_NAME }}" diff --git a/roles/prometheusexporter/exporters/postgresql/vars.yml b/roles/prometheusexporter/exporters/postgresql/vars.yml index 8ec8b32..9c52b5a 100644 --- a/roles/prometheusexporter/exporters/postgresql/vars.yml +++ b/roles/prometheusexporter/exporters/postgresql/vars.yml @@ -1,8 +1,7 @@ --- - # Exporter -image_name: "wrouesnel/postgres_exporter" -image_version: "v0.8.0" +image_name: "quay.io/prometheuscommunity/postgres-exporter" +image_version: "v0.16.0" port: 9187 liveness_probe_timeout_seconds: 3 liveness_probe_period_seconds: 15 @@ -19,7 +18,6 @@ resources_limits_memory: "64Mi" # Custom db_connection_string_secret_name: "prometheus-exporter-{{ type }}-{{ ansible_operator_meta.name }}" - ###### Example of Secret # # If you don't specify CR field dbConnectionStringSecretName, it will be used default Secret name "prometheus-exporter-postgresql-{{ CR_NAME }}" diff --git a/roles/prometheusexporter/exporters/probe/vars.yml b/roles/prometheusexporter/exporters/probe/vars.yml index 6a29b52..87a5cc0 100644 --- a/roles/prometheusexporter/exporters/probe/vars.yml +++ b/roles/prometheusexporter/exporters/probe/vars.yml @@ -2,7 +2,7 @@ # Exporter image_name: "quay.io/prometheus/blackbox-exporter" -image_version: "v0.22.0" +image_version: "v0.25.0" port: 9115 liveness_probe_timeout_seconds: 3 liveness_probe_period_seconds: 15 diff --git a/roles/prometheusexporter/exporters/redis/vars.yml b/roles/prometheusexporter/exporters/redis/vars.yml index f4b73f9..070fcdf 100644 --- a/roles/prometheusexporter/exporters/redis/vars.yml +++ b/roles/prometheusexporter/exporters/redis/vars.yml @@ -1,8 +1,7 @@ --- - # Exporter image_name: "oliver006/redis_exporter" -image_version: "v1.44.0" +image_version: "v1.66.0" port: 9121 liveness_probe_timeout_seconds: 3 liveness_probe_period_seconds: 15 @@ -20,7 +19,6 @@ resources_limits_memory: "64Mi" # Custom db_host: "backend-redis" db_port: 6379 - ## Optional: # Example 3scale backend: #db_check_keys: "resque:queue:stats,resque:queue:priority,resque:queue:main,resque:failed" diff --git a/roles/prometheusexporter/exporters/sendgrid/vars.yml b/roles/prometheusexporter/exporters/sendgrid/vars.yml index 4aaa01e..1d5027c 100644 --- a/roles/prometheusexporter/exporters/sendgrid/vars.yml +++ b/roles/prometheusexporter/exporters/sendgrid/vars.yml @@ -1,8 +1,7 @@ --- - # Exporter image_name: "chatwork/sendgrid-stats-exporter" -image_version: "0.0.9" +image_version: "v0.0.10" port: 9154 liveness_probe_timeout_seconds: 3 liveness_probe_period_seconds: 15 @@ -22,7 +21,6 @@ sendgrid_credentials_secret_name: "prometheus-exporter-{{ type }}-{{ ansible_ope sendgrid_accumulated_metrics: "True" sendgrid_location: "" sendgrid_time_offset: "0" - ###### Example of Secret # # If you don't specify CR field sendgridCredentialsSecretName, it will be used default Secret name "prometheus-exporter-sendgrid-{{ CR_NAME }}" diff --git a/roles/prometheusexporter/exporters/sphinx/vars.yml b/roles/prometheusexporter/exporters/sphinx/vars.yml index 888ecde..6f27577 100644 --- a/roles/prometheusexporter/exporters/sphinx/vars.yml +++ b/roles/prometheusexporter/exporters/sphinx/vars.yml @@ -1,8 +1,7 @@ --- - # Exporter image_name: "foxdalas/sphinx-exporter" -image_version: "master" +image_version: "v0.3.0" port: 9247 liveness_probe_timeout_seconds: 3 liveness_probe_period_seconds: 15