telegraf/plugins/parsers/prometheusremotewrite
Yu Long edb7f30521
feat(parser.prometheusremotewrite): Add dense metric version to better support histograms (#16493)
2025-03-06 18:11:27 -06:00
..
testcases feat(parser.prometheusremotewrite): Add dense metric version to better support histograms (#16493) 2025-03-06 18:11:27 -06:00
README.md feat(parser.prometheusremotewrite): Add dense metric version to better support histograms (#16493) 2025-03-06 18:11:27 -06:00
metric_v1.go feat(parser.prometheusremotewrite): Add dense metric version to better support histograms (#16493) 2025-03-06 18:11:27 -06:00
metric_v2.go feat(parser.prometheusremotewrite): Add dense metric version to better support histograms (#16493) 2025-03-06 18:11:27 -06:00
parser.go feat(parser.prometheusremotewrite): Add dense metric version to better support histograms (#16493) 2025-03-06 18:11:27 -06:00
parser_test.go feat(parser.prometheusremotewrite): Add dense metric version to better support histograms (#16493) 2025-03-06 18:11:27 -06:00

README.md

Prometheus Remote Write Parser Plugin

Converts prometheus remote write samples directly into Telegraf metrics. It can be used with http_listener_v2. There are no additional configuration options for Prometheus Remote Write Samples.

Configuration

[[inputs.http_listener_v2]]
  ## Address and port to host HTTP listener on
  service_address = ":1234"

  ## Paths to listen to.
  paths = ["/receive"]

  ## Data format to consume.
  data_format = "prometheusremotewrite"

  ## Metric version to use, either 1 or 2
  # metric_version = 2

Example Input

prompb.WriteRequest{
        Timeseries: []*prompb.TimeSeries{
            {
                Labels: []*prompb.Label{
                    {Name: "__name__", Value: "go_gc_duration_seconds"},
                    {Name: "instance", Value: "localhost:9090"},
                    {Name: "job", Value: "prometheus"},
                    {Name: "quantile", Value: "0.99"},
                },
                Samples: []prompb.Sample{
                    {Value: 4.63, Timestamp: time.Date(2020, 4, 1, 0, 0, 0, 0, time.UTC).UnixNano()},
                },
            },
        },
    }

Example Output (v1)

go_gc_duration_seconds,instance=localhost:9090,job=prometheus,quantile=0.99 value=4.63 1614889298859000000

Example Output (v2)

prometheus_remote_write,instance=localhost:9090,job=prometheus,quantile=0.99 go_gc_duration_seconds=4.63 1614889298859000000

For alignment with the InfluxDB v1.x Prometheus Remote Write Spec