diff --git a/docs/operator/CHANGELOG.md b/docs/operator/CHANGELOG.md index 422c67d287..3229eca08f 100644 --- a/docs/operator/CHANGELOG.md +++ b/docs/operator/CHANGELOG.md @@ -17,13 +17,19 @@ aliases: ## Next release **Update note: [vmcluster](./api.md#vmcluster): remove fields `VMClusterSpec.VMInsert.Name`, `VMClusterSpec.VMStorage.Name`, `VMClusterSpec.VMSelect.Name`, they're marked as deprecated since v0.21.0. See [this pull request](https://github.com/VictoriaMetrics/operator/pull/907).** +- [operator](./README.md): Changes error handling for reconcile. Operator sends `Events` into kubernetes API, if any error happened during object reconcile. See this [issue](https://github.com/VictoriaMetrics/operator/issues/900) for details. - [operator](./README.md): updates base Docker image and prometheus_client to versions with with CVE fixes -- [operator](./README.md): adds reconcile retries on conflict for `Service` reconcilation. See this [issue](https://github.com/VictoriaMetrics/operator/issues/901) for details. +- [operator](./README.md): adds reconcile retries on conflicts. See this [issue](https://github.com/VictoriaMetrics/operator/issues/901) for details. - [operator](./README.md): allows adjust `Service` generated by operator with `useAsDefault` option set to `true` for `serviceSpec` field. See this [issue](https://github.com/VictoriaMetrics/operator/issues/904) for details. - [vmagent](./api.md#vmagent): change service for `statefulMode` to the `headless` instead of `clusterIP`. See this [issue](https://github.com/VictoriaMetrics/operator/issues/917) for details. - [vmservicescrape&vmpodscrape](./api.md#vmservicescrape): add `attach_metadata` option under VMServiceScrapeSpec&VMPodScrapeSpec, the same way like prometheus serviceMonitor&podMonitor do. See [this issue](https://github.com/VictoriaMetrics/operator/issues/893) for details. - [vmalertmanagerconfig](./api.md#vmalertmanagerconfig): fix struct field tags under `Sigv4Config`. - [vmalertmanager](./api.md#vmalertmanager): bump default alertmanager version to [v0.27.0](https://github.com/prometheus/alertmanager/releases/tag/v0.27.0), which supports new receivers like `msteams_configs`. +- [vmscrapeconfig](./api.md#vmscrapeconfig): add crd VMScrapeConfig, which can define a scrape config using any of the service discovery options supported in victoriametrics. +- [vmprobe](./api.md#vmprobe): add field `proxy_url`, see [this issue](https://github.com/VictoriaMetrics/operator/issues/731) for details. +- scrape CRDs: add field `series_limit`, which can be used to limit the number of unique time series a single scrape target can expose. +- scrape CRDs: fix scrape_config filed `disable_keep_alive`, before it's misconfigured as `disable_keepalive` and won't work. +- scrape CRDs: deprecated option `relabel_debug` and `metric_relabel_debug`, they were deprecated since [v1.85.0](https://github.com/VictoriaMetrics/VictoriaMetrics/releases/tag/v1.85.0). ## [v0.43.](https://github.com/VictoriaMetrics/operator/releases/tag/v0.42.3) - 12 Mar 2024 diff --git a/docs/operator/api.md b/docs/operator/api.md index 36cc7e3ac9..05ea374c5a 100644 --- a/docs/operator/api.md +++ b/docs/operator/api.md @@ -870,6 +870,8 @@ VMAgentSpec defines the desired state of VMAgent | nodeScrapeNamespaceSelector | NodeScrapeNamespaceSelector defines Namespaces to be selected for VMNodeScrape discovery. Works in combination with Selector. NamespaceSelector nil - only objects at VMAgent namespace. Selector nil - only objects at NamespaceSelector namespaces. If both nil - behaviour controlled by selectAllByDefault | *[metav1.LabelSelector](https://kubernetes.io/docs/reference/generated/kubernetes-api/v1.27/#labelselector-v1-meta) | false | | staticScrapeSelector | StaticScrapeSelector defines PodScrapes to be selected for target discovery. Works in combination with NamespaceSelector. If both nil - match everything. NamespaceSelector nil - only objects at VMAgent namespace. Selector nil - only objects at NamespaceSelector namespaces. | *[metav1.LabelSelector](https://kubernetes.io/docs/reference/generated/kubernetes-api/v1.27/#labelselector-v1-meta) | false | | staticScrapeNamespaceSelector | StaticScrapeNamespaceSelector defines Namespaces to be selected for VMStaticScrape discovery. Works in combination with NamespaceSelector. NamespaceSelector nil - only objects at VMAgent namespace. Selector nil - only objects at NamespaceSelector namespaces. If both nil - behaviour controlled by selectAllByDefault | *[metav1.LabelSelector](https://kubernetes.io/docs/reference/generated/kubernetes-api/v1.27/#labelselector-v1-meta) | false | +| scrapeConfigSelector | ScrapeConfigSelector defines VMScrapeConfig to be selected for target discovery. Works in combination with NamespaceSelector. | *[metav1.LabelSelector](https://kubernetes.io/docs/reference/generated/kubernetes-api/v1.27/#labelselector-v1-meta) | false | +| scrapeConfigNamespaceSelector | ScrapeConfigNamespaceSelector defines Namespaces to be selected for VMScrapeConfig discovery. Works in combination with Selector. NamespaceSelector nil - only objects at VMAgent namespace. Selector nil - only objects at NamespaceSelector namespaces. If both nil - behaviour controlled by selectAllByDefault | *[metav1.LabelSelector](https://kubernetes.io/docs/reference/generated/kubernetes-api/v1.27/#labelselector-v1-meta) | false | | inlineScrapeConfig | InlineScrapeConfig As scrape configs are appended, the user is responsible to make sure it is valid. Note that using this feature may expose the possibility to break upgrades of VMAgent. It is advised to review VMAgent release notes to ensure that no incompatible scrape configs are going to break VMAgent after the upgrade. it should be defined as single yaml file. inlineScrapeConfig: \|\n - job_name: \"prometheus\"\n static_configs:\n - targets: [\"localhost:9090\"] | string | false | | additionalScrapeConfigs | AdditionalScrapeConfigs As scrape configs are appended, the user is responsible to make sure it is valid. Note that using this feature may expose the possibility to break upgrades of VMAgent. It is advised to review VMAgent release notes to ensure that no incompatible scrape configs are going to break VMAgent after the upgrade. | *[v1.SecretKeySelector](https://kubernetes.io/docs/reference/generated/kubernetes-api/v1.27/#secretkeyselector-v1-core) | false | | arbitraryFSAccessThroughSMs | ArbitraryFSAccessThroughSMs configures whether configuration based on a service scrape can access arbitrary files on the file system of the VMAgent container e.g. bearer token files. | [ArbitraryFSAccessThroughSMsConfig](#arbitraryfsaccessthroughsmsconfig) | false | @@ -892,6 +894,7 @@ VMAgentSpec defines the desired state of VMAgent | nodeScrapeRelabelTemplate | NodeScrapeRelabelTemplate defines relabel config, that will be added to each VMNodeScrape. it's useful for adding specific labels to all targets | []*[RelabelConfig](#relabelconfig) | false | | staticScrapeRelabelTemplate | StaticScrapeRelabelTemplate defines relabel config, that will be added to each VMStaticScrape. it's useful for adding specific labels to all targets | []*[RelabelConfig](#relabelconfig) | false | | probeScrapeRelabelTemplate | ProbeScrapeRelabelTemplate defines relabel config, that will be added to each VMProbeScrape. it's useful for adding specific labels to all targets | []*[RelabelConfig](#relabelconfig) | false | +| scrapeConfigRelabelTemplate | ScrapeConfigRelabelTemplate defines relabel config, that will be added to each VMScrapeConfig. it's useful for adding specific labels to all targets | []*[RelabelConfig](#relabelconfig) | false | | minScrapeInterval | MinScrapeInterval allows limiting minimal scrape interval for VMServiceScrape, VMPodScrape and other scrapes If interval is lower than defined limit, `minScrapeInterval` will be used. | *string | false | | maxScrapeInterval | MaxScrapeInterval allows limiting maximum scrape interval for VMServiceScrape, VMPodScrape and other scrapes If interval is higher than defined limit, `maxScrapeInterval` will be used. | *string | false | | terminationGracePeriodSeconds | TerminationGracePeriodSeconds period for container graceful termination | *int64 | false | @@ -1514,6 +1517,7 @@ Endpoint defines a scrapeable endpoint serving Prometheus metrics. | scrape_interval | ScrapeInterval is the same as Interval and has priority over it. one of scrape_interval or interval can be used | string | false | | scrapeTimeout | Timeout after which the scrape is ended | string | false | | sampleLimit | SampleLimit defines per-endpoint limit on number of scraped samples that will be accepted. | uint64 | false | +| seriesLimit | SeriesLimit defines per-scrape limit on number of unique time series a single target can expose during all the scrapes on the time window of 24h. | uint64 | false | | oauth2 | OAuth2 defines auth configuration | *[OAuth2](#oauth2) | false | | authorization | Authorization with http header Authorization | *[Authorization](#authorization) | false | | tlsConfig | TLSConfig configuration to use when scraping the endpoint | *[TLSConfig](#tlsconfig) | false | @@ -1624,10 +1628,10 @@ VMScrapeParams defines scrape target configuration that compatible only with Vic | Field | Description | Scheme | Required | | ----- | ----------- | ------ | -------- | -| relabel_debug | | *bool | false | -| metric_relabel_debug | | *bool | false | +| relabel_debug | deprecated since [v1.85](https://github.com/VictoriaMetrics/VictoriaMetrics/releases/tag/v1.85.0), will be removed in next release | *bool | false | +| metric_relabel_debug | deprecated since [v1.85](https://github.com/VictoriaMetrics/VictoriaMetrics/releases/tag/v1.85.0), will be removed in next release | *bool | false | | disable_compression | | *bool | false | -| disable_keep_alive | | *bool | false | +| disable_keep_alive | disable_keepalive allows disabling HTTP keep-alive when scraping targets. By default, HTTP keep-alive is enabled, so TCP connections to scrape targets could be re-used. See https://docs.victoriametrics.com/vmagent.html#scrape_config-enhancements | *bool | false | | no_stale_markers | | *bool | false | | stream_parse | | *bool | false | | scrape_align_interval | | *string | false | @@ -1674,6 +1678,7 @@ VMServiceScrapeSpec defines the desired state of VMServiceScrape | selector | Selector to select Endpoints objects by corresponding Service labels. | [metav1.LabelSelector](https://kubernetes.io/docs/reference/generated/kubernetes-api/v1.27/#labelselector-v1-meta) | false | | namespaceSelector | Selector to select which namespaces the Endpoints objects are discovered from. | [NamespaceSelector](#namespaceselector) | false | | sampleLimit | SampleLimit defines per-scrape limit on number of scraped samples that will be accepted. | uint64 | false | +| seriesLimit | SeriesLimit defines per-scrape limit on number of unique time series a single target can expose during all the scrapes on the time window of 24h. | uint64 | false | | attach_metadata | AttachMetadata configures metadata attaching from service discovery | [AttachMetadata](#attachmetadata) | false | [Back to TOC](#table-of-contents) @@ -1704,6 +1709,7 @@ PodMetricsEndpoint defines a scrapeable endpoint of a Kubernetes Pod serving Pro | scrape_interval | ScrapeInterval is the same as Interval and has priority over it. one of scrape_interval or interval can be used | string | false | | scrapeTimeout | Timeout after which the scrape is ended | string | false | | sampleLimit | SampleLimit defines per-podEndpoint limit on number of scraped samples that will be accepted. | uint64 | false | +| seriesLimit | SeriesLimit defines per-scrape limit on number of unique time series a single target can expose during all the scrapes on the time window of 24h. | uint64 | false | | honorLabels | HonorLabels chooses the metric's labels on collisions with target labels. | bool | false | | honorTimestamps | HonorTimestamps controls whether vmagent respects the timestamps present in scraped data. | *bool | false | | metricRelabelConfigs | MetricRelabelConfigs to apply to samples before ingestion. | []*[RelabelConfig](#relabelconfig) | false | @@ -1756,6 +1762,7 @@ VMPodScrapeSpec defines the desired state of VMPodScrape | selector | Selector to select Pod objects. | [metav1.LabelSelector](https://kubernetes.io/docs/reference/generated/kubernetes-api/v1.27/#labelselector-v1-meta) | false | | namespaceSelector | Selector to select which namespaces the Endpoints objects are discovered from. | [NamespaceSelector](#namespaceselector) | false | | sampleLimit | SampleLimit defines per-scrape limit on number of scraped samples that will be accepted. | uint64 | false | +| seriesLimit | SeriesLimit defines per-scrape limit on number of unique time series a single target can expose during all the scrapes on the time window of 24h. | uint64 | false | | attach_metadata | AttachMetadata configures metadata attaching from service discovery | [AttachMetadata](#attachmetadata) | false | [Back to TOC](#table-of-contents) @@ -2099,6 +2106,7 @@ VMNodeScrapeSpec defines specification for VMNodeScrape. | proxyURL | ProxyURL eg http://proxyserver:2195 Directs scrapes to proxy through this endpoint. | *string | false | | selector | Selector to select kubernetes Nodes. | [metav1.LabelSelector](https://kubernetes.io/docs/reference/generated/kubernetes-api/v1.27/#labelselector-v1-meta) | false | | sampleLimit | SampleLimit defines per-scrape limit on number of scraped samples that will be accepted. | uint64 | false | +| seriesLimit | SeriesLimit defines per-scrape limit on number of unique time series a single target can expose during all the scrapes on the time window of 24h. | uint64 | false | | vm_scrape_params | VMScrapeParams defines VictoriaMetrics specific scrape parametrs | *[VMScrapeParams](#vmscrapeparams) | false | [Back to TOC](#table-of-contents) @@ -2348,6 +2356,7 @@ TargetEndpoint defines single static target endpoint. | params | Optional HTTP URL parameters | map[string][]string | false | | follow_redirects | FollowRedirects controls redirects for scraping. | *bool | false | | sampleLimit | SampleLimit defines per-scrape limit on number of scraped samples that will be accepted. | uint64 | false | +| seriesLimit | SeriesLimit defines per-scrape limit on number of unique time series a single target can expose during all the scrapes on the time window of 24h. | uint64 | false | | interval | Interval at which metrics should be scraped | string | false | | scrape_interval | ScrapeInterval is the same as Interval and has priority over it. one of scrape_interval or interval can be used | string | false | | scrapeTimeout | Timeout after which the scrape is ended | string | false | @@ -2398,6 +2407,7 @@ VMStaticScrapeSpec defines the desired state of VMStaticScrape. | jobName | JobName name of job. | string | false | | targetEndpoints | A list of target endpoints to scrape metrics from. | []*[TargetEndpoint](#targetendpoint) | true | | sampleLimit | SampleLimit defines per-scrape limit on number of scraped samples that will be accepted. | uint64 | false | +| seriesLimit | SeriesLimit defines per-scrape limit on number of unique time series a single target can expose during all the scrapes on the time window of 24h. | uint64 | false | [Back to TOC](#table-of-contents) @@ -2452,12 +2462,14 @@ VMProbeSpec contains specification parameters for a Probe. | params | Optional HTTP URL parameters | map[string][]string | false | | follow_redirects | FollowRedirects controls redirects for scraping. | *bool | false | | sampleLimit | SampleLimit defines per-scrape limit on number of scraped samples that will be accepted. | uint64 | false | +| seriesLimit | SeriesLimit defines per-scrape limit on number of unique time series a single target can expose during all the scrapes on the time window of 24h. | uint64 | false | | bearerTokenFile | File to read bearer token for scraping targets. | string | false | | bearerTokenSecret | Secret to mount to read bearer token for scraping targets. The secret needs to be in the same namespace as the service scrape and accessible by the victoria-metrics operator. | *[v1.SecretKeySelector](https://kubernetes.io/docs/reference/generated/kubernetes-api/v1.27/#secretkeyselector-v1-core) | false | | basicAuth | BasicAuth allow an endpoint to authenticate over basic authentication More info: https://prometheus.io/docs/operating/configuration/#endpoints | *[BasicAuth](#basicauth) | false | | oauth2 | OAuth2 defines auth configuration | *[OAuth2](#oauth2) | false | | authorization | Authorization with http header Authorization | *[Authorization](#authorization) | false | | tlsConfig | TLSConfig configuration to use when scraping the endpoint | *[TLSConfig](#tlsconfig) | false | +| proxyURL | ProxyURL eg http://proxyserver:2195 Directs scrapes to proxy through this endpoint. | *string | false | | vm_scrape_params | VMScrapeParams defines VictoriaMetrics specific scrape parametrs | *[VMScrapeParams](#vmscrapeparams) | false | [Back to TOC](#table-of-contents) diff --git a/docs/operator/migration.md b/docs/operator/migration.md index 4f7911a437..4ecda3a2af 100644 --- a/docs/operator/migration.md +++ b/docs/operator/migration.md @@ -24,6 +24,7 @@ Or you can use VictoriaMetrics CRDs: - `VMRule` (instead of `PrometheusRule`) - defines alerting or recording rules. [See details](./resources/vmrule.md). - `VMProbe` (instead of `Probe`) - defines a probing configuration for targets with blackbox exporter. [See details](./resources/vmprobe.md). - `VMAlertmanagerConfig` (instead of `AlertmanagerConfig`) - defines a configuration for AlertManager. [See details](./resources/vmalertmanagerconfig.md). +- `VMScrapeConfig` (instead of `ScrapeConfig`) - define a scrape config using any of the service discovery options supported in victoriametrics. Note that Prometheus CRDs are not supplied with the VictoriaMetrics operator, so you need to [install them separately](https://github.com/prometheus-operator/prometheus-operator/releases). @@ -33,8 +34,8 @@ and version `monitoring.coreos.com/v1alpha1` for kind `AlertmanagerConfig`. The default behavior of the operator is as follows: -- It **converts** all existing Prometheus `ServiceMonitor`, `PodMonitor`, `PrometheusRule` and `Probe` objects into corresponding VictoriaMetrics Operator objects. -- It **syncs** updates (including labels) from Prometheus `ServiceMonitor`, `PodMonitor`, `PrometheusRule` and `Probe` objects to corresponding VictoriaMetrics Operator objects. +- It **converts** all existing Prometheus `ServiceMonitor`, `PodMonitor`, `PrometheusRule`, `Probe` and `ScrapeConfig` objects into corresponding VictoriaMetrics Operator objects. +- It **syncs** updates (including labels) from Prometheus `ServiceMonitor`, `PodMonitor`, `PrometheusRule`, `Probe` and `ScrapeConfig` objects to corresponding VictoriaMetrics Operator objects. - It **DOES NOT delete** converted objects after original ones are deleted. With this configuration removing prometheus-operator API objects wouldn't delete any converted objects. So you can safely migrate or run two operators at the same time. @@ -55,6 +56,7 @@ VM_ENABLEDPROMETHEUSCONVERTER_PODMONITOR=false VM_ENABLEDPROMETHEUSCONVERTER_SERVICESCRAPE=false VM_ENABLEDPROMETHEUSCONVERTER_PROMETHEUSRULE=false VM_ENABLEDPROMETHEUSCONVERTER_PROBE=false +VM_ENABLEDPROMETHEUSCONVERTER_SCRAPECONFIG=false ``` For [victoria-metrics-operator helm-chart](https://github.com/VictoriaMetrics/helm-charts/blob/master/charts/victoria-metrics-operator/README.md) you can use following way: @@ -130,6 +132,7 @@ Annotation `operator.victoriametrics.com/ignore-prometheus-updates` can be set o - [VMRule](./resources/vmrule.md) - [VMProbe](./resources/vmprobe.md) - [VMAlertmanagerConfig](./resources/vmalertmanagerconfig.md) +- [VMScrapeConfig](./resources/vmscrapeconfig.md) And annotation doesn't make sense for [VMStaticScrape](./resources/vmstaticscrape.md) and [VMNodeScrape](./resources/vmnodescrape.md) because these objects are not created as a result of conversion. @@ -170,6 +173,7 @@ Annotation `operator.victoriametrics.com/merge-meta-strategy` can be set on one - [VMRule](./resources/vmrule.md) - [VMProbe](./resources/vmprobe.md) - [VMAlertmanagerConfig](./resources/vmalertmanagerconfig.md) +- [VMScrapeConfig](./resources/vmscrapeconfig.md) And annotation doesn't make sense for [VMStaticScrape](./resources/vmstaticscrape.md) and [VMNodeScrape](./resources/vmnodescrape.md) because these objects are not created as a result of conversion. diff --git a/docs/operator/resources/README.md b/docs/operator/resources/README.md index be511f3331..98e7235926 100644 --- a/docs/operator/resources/README.md +++ b/docs/operator/resources/README.md @@ -30,6 +30,7 @@ Metrics Operator introduces. - [VMStaticScrape](./vmstaticscrape.md) - [VMSingle](./vmsingle.md) - [VMUser](./vmuser.md) +- [VMScrapeConfig](./vmscrapeconfig.md) Here is the scheme of relations between the custom resources: @@ -119,6 +120,7 @@ Page for every custom resource contains examples section: - [VMStaticScrape examples](./vmstaticscrape.md#examples) - [VMSingle examples](./vmsingle.md#examples) - [VMUser examples](./vmuser.md#examples) +- [VMScrapeConfig examples](./vmscrapeconfig.md#examples) In addition, you can find examples of the custom resources for VIctoriMetrics operator in the **[examples directory](https://github.com/VictoriaMetrics/operator/tree/master/config/examples) of operator repository**. diff --git a/docs/operator/resources/vmagent.md b/docs/operator/resources/vmagent.md index 45c6176322..b8d15d80dc 100644 --- a/docs/operator/resources/vmagent.md +++ b/docs/operator/resources/vmagent.md @@ -53,6 +53,7 @@ Also, you can check out the [examples](#examples) section. - [VMNodeScrape](./vmnodescrape.md), - [VMStaticScrape](./vmstaticscrape.md), - [VMProbe](./vmprobe.md). +- `VMScrapeConfig`(./vmscrapeconfig.md) These objects tell VMAgent from which targets and how to collect metrics and generate part of [VMAgent](./vmagent.md) scrape configuration. @@ -65,6 +66,7 @@ Selectors are defined with suffixes - `NamespaceSelector` and `Selector` for eac - `probeNamespaceSelector` and `probeSelector` for selecting [VMProbe](./vmprobe.md) objects, - `staticScrapeNamespaceSelector` and `staticScrapeSelector` for selecting [VMStaticScrape](./vmstaticscrape.md) objects, - `nodeScrapeNamespaceSelector` and `nodeScrapeSelector` for selecting [VMNodeScrape](./vmnodescrape.md) objects. +- `scrapeConfigNamespaceSelector` and `scrapeConfigSelector` for selecting [VMScrapeConfig](./vmscrapeconfig.md) objects. It allows configuring objects access control across namespaces and different environments. Specification of selectors you can see in [this doc](https://kubernetes.io/docs/reference/generated/kubernetes-api/v1.27/#labelselector-v1-meta). diff --git a/docs/operator/resources/vmalert.md b/docs/operator/resources/vmalert.md index 74ee3320aa..0e43ff4942 100644 --- a/docs/operator/resources/vmalert.md +++ b/docs/operator/resources/vmalert.md @@ -51,7 +51,7 @@ spec: ruleNamespaceSelector: {} ``` -[VMRUle](./vmrule.md) objects generate part of `VMAlert` configuration. +[VMRule](./vmrule.md) objects generate part of `VMAlert` configuration. For filtering rules `VMAlert` uses selectors `ruleNamespaceSelector` and `ruleSelector`. It allows configuring rules access control across namespaces and different environments. diff --git a/docs/operator/resources/vmscrapeconfig.md b/docs/operator/resources/vmscrapeconfig.md new file mode 100644 index 0000000000..64a304e09c --- /dev/null +++ b/docs/operator/resources/vmscrapeconfig.md @@ -0,0 +1,50 @@ +--- +sort: 15 +weight: 15 +title: VMServiceScrape +menu: + docs: + parent: "operator-custom-resources" + weight: 15 +aliases: + - /operator/resources/vmscrapeconfig.html +--- + +# VMScrapeConfig + +The `VMScrapeConfig` CRD allows to define a scrape config using [any of the service discovery options supported in victoriametrics](https://docs.victoriametrics.com/sd_configs/). + +`VMScrapeConfig` object generates part of [VMAgent](./vmagent.md) configuration with Prometheus-compatible scrape targets. + +## Specification + +You can see the full actual specification of the `VMScrapeConfig` resource in +the **[API docs -> VMScrapeConfig](../api.md#vmscrapeconfig)**. + +Also, you can check out the [examples](#examples) section. + +## Migration from Prometheus + +The `VMScrapeConfig` CRD from VictoriaMetrics Operator is a drop-in replacement +for the Prometheus `ScrapeConfig` from prometheus-operator. + +More details about migration from prometheus-operator you can read in [this doc](../migration.md). + +## Examples + +```yaml +apiVersion: operator.victoriametrics.com/v1beta1 +kind: VMScrapeConfig +metadata: + name: mongodb +spec: + consulSDConfigs: + - server: https://consul-dns:8500 + services: + - mongodb + relabelConfigs: + - action: replace + sourceLabels: + - __meta_consul_service + targetLabel: job +``` diff --git a/docs/operator/vars.md b/docs/operator/vars.md index 2b3d56172c..b9ce5045d1 100644 --- a/docs/operator/vars.md +++ b/docs/operator/vars.md @@ -10,7 +10,7 @@ menu: # Auto Generated vars for package config - updated at Wed Apr 10 20:35:21 UTC 2024 + updated at Fri Apr 12 17:47:32 UTC 2024 | varible name | variable default value | variable required | variable description | @@ -112,6 +112,7 @@ menu: | VM_ENABLEDPROMETHEUSCONVERTER_PROMETHEUSRULE | true | false | - | | VM_ENABLEDPROMETHEUSCONVERTER_PROBE | true | false | - | | VM_ENABLEDPROMETHEUSCONVERTER_ALERTMANAGERCONFIG | true | false | - | +| VM_ENABLEDPROMETHEUSCONVERTER_SCRAPECONFIG | true | false | - | | VM_FILTERCHILDLABELPREFIXES | - | false | - | | VM_FILTERCHILDANNOTATIONPREFIXES | - | false | - | | VM_PROMETHEUSCONVERTERADDARGOCDIGNOREANNOTATIONS | false | false | adds compare-options and sync-options for prometheus objects converted by operatorit helps to properly use converter with ArgoCD |