Telegraf
How to configure Telegraf to send data to Levitate using the Prometheus Remote Write feature
Introduction
Telegraf is an open-source agent that collects metrics and data from various sources and sends them to other services, such as InfluxDB, Graphite, and Prometheus. This document describes how Telegraf can integrate with Levitate.
Levitate accepts remote write metrics in Prometheus / Opentelemetry format. Telegraf supports both push-based and pull-based methods for these formats.
Pre-requisites
- You have created a Levitate cluster by following the getting started guide
- Clone last9-integrations GitHub repository contains the sample code with different approaches discussed in this article
Push via vmagent (recommended)
- A sample application sends metrics to
telegraf
telegraf
has an InfluxDB output plugin, which send metrics tovmagent
vmagent
accepts InfluxDB format as input and outputs Prometheus format metrics to Levitate
You can configure the vmagent
URL as follows in the telegraf config file.
###############################################################################
# OUTPUTS #
###############################################################################
[[outputs.influxdb]]
urls = ["http://vmagent:8429"]
A working sample application can be found here.
This is the recommended approach for pushing metrics from Telegraf to Levitate.
Push via Prometheus Remote Write plugin
- A sample application sends metrics to
telegraf
telegraf
has an HTTP output plugin, which supportsprometheusremotewrite
format to convert input metrics to Prometheus protobuf format and push them to Levitate
The changes to the telegraf config are as follows:
## Data format to output.
data_format = "prometheusremotewrite"
## Additional HTTP headers
[outputs.http.headers]
Content-Type = "application/x-protobuf"
Content-Encoding = "snappy"
X-Prometheus-Remote-Write-Version = "0.1.0"
Here is a sample application with this setup.
Pull via Prometheus Client plugin
- A sample application sends metrics to
telegraf
telegraf
has a Prometheus output plugin, which exposes all input metrics on/metrics
url- These metrics are scraped by
vmagent
which remote writes to Levitate
This approach also requires a change in the outputs section in the telegraf config as follows. The 9273
port is used in the vmagent
config file which scrapes it for metrics.
###############################################################################
# OUTPUTS #
###############################################################################
# Configuration for the Prometheus client to spawn
[[outputs.prometheus_client]]
## Address to listen on.
listen = ":9273"
A complete example using this approach can be found here.
Comparison
Approach | Pros | Cons |
---|---|---|
Push via vmagent | Transparent relay from Telegraf to InfluxDB format to Levitate. | None |
Push via Prometheus remote write | No need to run any additional scraping agent because of the direct push model. | Histogram-based metrics might be impacted if Telegraf pushes partial results in one chunk. This has been mentioned in prometheusremotewrite plugin docs. |
Pull via Client plugin | Metrics are shipped to Levitate using the standard scrape model. | It has an overhead to run vmagent or any other scraping tool additionally. |
Next steps
Create a read token for your Levitate Cluster and follow our guide to Configure Grafana to visualize the time series data getting sent to Levitate.
Troubleshooting
Please get in touch with us on Discord or Email if you have any questions.