OpenTelemetry Bot d680729c09 [chore] Prepare release 0.90.0 (#29543) 1 рік тому
..
internal 2f0089fec4 [chore] update collector core (#29122) 1 рік тому
testdata 3a40682ac1 Warn instead of failing when renaming metrics using metric_relabel_configs (#25888) 1 рік тому
DESIGN.md 424942bda1 [receiver/prometheusreceiver] Fix dead link in DESIGN.md (#12152) 2 роки тому
Makefile d46048ac4d Move prometheusreceiver from collector core to collector contrib (#4847) 3 роки тому
README.md 642e7f7f45 Parse scope information from otel_scope_name, otel_scope_version, and otel_scope_info (#25898) 1 рік тому
config.go f4c44858b5 [all][chore] Moved from interface{} to any for all go code (#29072) 1 рік тому
config_test.go 3a40682ac1 Warn instead of failing when renaming metrics using metric_relabel_configs (#25888) 1 рік тому
doc.go 5133f4ccd6 [chore] use license shortform (#22052) 1 рік тому
factory.go 3a40682ac1 Warn instead of failing when renaming metrics using metric_relabel_configs (#25888) 1 рік тому
factory_test.go 5133f4ccd6 [chore] use license shortform (#22052) 1 рік тому
go.mod d680729c09 [chore] Prepare release 0.90.0 (#29543) 1 рік тому
go.sum 40b485f08a Update core for v0.90.0 release (#29539) 1 рік тому
metadata.yaml 8a4348cb00 [chore] add codeowners to metadata (#24404) 1 рік тому
metrics_receiver.go e790fd51ee [chore] bump prometheus/go-hdb packages (#29314) 1 рік тому
metrics_receiver_helper_test.go bc25618eee [chore] [reveiver/prometheusreceiver] Add unit tests around protobuf negotiation (#29153) 1 рік тому
metrics_receiver_honor_timestamp_test.go bc25618eee [chore] [reveiver/prometheusreceiver] Add unit tests around protobuf negotiation (#29153) 1 рік тому
metrics_receiver_labels_test.go bc25618eee [chore] [reveiver/prometheusreceiver] Add unit tests around protobuf negotiation (#29153) 1 рік тому
metrics_receiver_metric_name_normalize_test.go bc25618eee [chore] [reveiver/prometheusreceiver] Add unit tests around protobuf negotiation (#29153) 1 рік тому
metrics_receiver_non_numerical_test.go bc25618eee [chore] [reveiver/prometheusreceiver] Add unit tests around protobuf negotiation (#29153) 1 рік тому
metrics_receiver_open_metrics_test.go bc25618eee [chore] [reveiver/prometheusreceiver] Add unit tests around protobuf negotiation (#29153) 1 рік тому
metrics_receiver_protobuf_test.go bc25618eee [chore] [reveiver/prometheusreceiver] Add unit tests around protobuf negotiation (#29153) 1 рік тому
metrics_receiver_report_extra_scrape_metrics_test.go 23f286cd67 Translate unit from words to UCUM in the prometheus receiver (#25887) 1 рік тому
metrics_receiver_target_allocator_test.go f4c44858b5 [all][chore] Moved from interface{} to any for all go code (#29072) 1 рік тому
metrics_receiver_test.go bc25618eee [chore] [reveiver/prometheusreceiver] Add unit tests around protobuf negotiation (#29153) 1 рік тому
metrics_reciever_metric_rename_test.go bc25618eee [chore] [reveiver/prometheusreceiver] Add unit tests around protobuf negotiation (#29153) 1 рік тому
scrapeloop-flowchart.png d46048ac4d Move prometheusreceiver from collector core to collector contrib (#4847) 3 роки тому

README.md

Prometheus Receiver

Status
Stability beta: metrics
Distributions core, contrib, aws, grafana, observiq, splunk, sumo
Issues Open issues Closed issues
Code Owners @Aneurysm9, @dashpole

Receives metric data in Prometheus format. See the Design for additional information on this receiver.

⚠️ Warning

Note: This component is currently work in progress. It has several limitations and please don't use it if the following limitations is a concern:

  • Collector cannot auto-scale the scraping yet when multiple replicas of the collector is run.
  • When running multiple replicas of the collector with the same config, it will scrape the targets multiple times.
  • Users need to configure each replica with different scraping configuration if they want to manually shard the scraping.
  • The Prometheus receiver is a stateful component.

Unsupported features

The Prometheus receiver is meant to minimally be a drop-in replacement for Prometheus. However, there are advanced features of Prometheus that we don't support and thus explicitly will return an error for if the receiver's configuration YAML/code contains any of the following

  • alert_config.alertmanagers
  • alert_config.relabel_configs
  • remote_read
  • remote_write
  • rule_files

Getting Started

This receiver is a drop-in replacement for getting Prometheus to scrape your services. It supports the full set of Prometheus configuration in scrape_config, including service discovery. Just like you would write in a YAML configuration file before starting Prometheus, such as with:

Note: Since the collector configuration supports env variable substitution $ characters in your prometheus configuration are interpreted as environment variables. If you want to use $ characters in your prometheus configuration, you must escape them using $$.

prometheus --config.file=prom.yaml

Feature gates:

  • receiver.prometheusreceiver.UseCreatedMetric: Start time for Summary, Histogram and Sum metrics can be retrieved from _created metrics. Currently, this behaviour is disabled by default. To enable it, use the following feature gate option:

    "--feature-gates=receiver.prometheusreceiver.UseCreatedMetric"
    
  • report_extra_scrape_metrics: Extra Prometheus scrape metrics can be reported by setting this parameter to true

You can copy and paste that same configuration under:

receivers:
  prometheus:
    config:

For example:

receivers:
    prometheus:
      config:
        scrape_configs:
          - job_name: 'otel-collector'
            scrape_interval: 5s
            static_configs:
              - targets: ['0.0.0.0:8888']
          - job_name: k8s
            kubernetes_sd_configs:
            - role: pod
            relabel_configs:
            - source_labels: [__meta_kubernetes_pod_annotation_prometheus_io_scrape]
              regex: "true"
              action: keep
            metric_relabel_configs:
            - source_labels: [__name__]
              regex: "(request_duration_seconds.*|response_duration_seconds.*)"
              action: keep

The prometheus receiver also supports additional top-level options:

  • trim_metric_suffixes: [Experimental] When set to true, this enables trimming unit and some counter type suffixes from metric names. For example, it would cause singing_duration_seconds_total to be trimmed to singing_duration. This can be useful when trying to restore the original metric names used in OpenTelemetry instrumentation. Defaults to false.
  • use_start_time_metric: When set to true, this enables retrieving the start time of all counter metrics from the process_start_time_seconds metric. This is only correct if all counters on that endpoint started after the process start time, and the process is the only actor exporting the metric after the process started. It should not be used in "exporters" which export counters that may have started before the process itself. Use only if you know what you are doing, as this may result in incorrect rate calculations. Defaults to false.
  • start_time_metric_regex: The regular expression for the start time metric, and is only applied when use_start_time_metric is enabled. Defaults to process_start_time_seconds.

For example,

receivers:
    prometheus:
      trim_metric_suffixes: true
      use_start_time_metric: true
      start_time_metric_regex: foo_bar_.*
      config:
        scrape_configs:
          - job_name: 'otel-collector'
            scrape_interval: 5s
            static_configs:
              - targets: ['0.0.0.0:8888']

OpenTelemetry Operator

Additional to this static job definitions this receiver allows to query a list of jobs from the OpenTelemetryOperators TargetAllocator or a compatible endpoint.

receivers:
  prometheus:
    target_allocator:
      endpoint: http://my-targetallocator-service
      interval: 30s
      collector_id: collector-1

Exemplars

This receiver accepts exemplars coming in Prometheus format and converts it to OTLP format.

  1. Value is expected to be received in float64 format
  2. Timestamp is expected to be received in ms
  3. Labels with key span_id in prometheus exemplars are set as OTLP span id and labels with key trace_id are set as trace id
  4. Rest of the labels are copied as it is to OTLP format

Resource and Scope

This receiver drops the target_info prometheus metric, if present, and uses attributes on that metric to populate the OpenTelemetry Resource.

It drops otel_scope_name and otel_scope_version labels, if present, from metrics, and uses them to populate the OpenTelemetry Instrumentation Scope name and version. It drops the otel_scope_info metric, and uses attributes (other than otel_scope_name and otel_scope_version) to populate Scope Attributes.