Prometheus Message Format
<metric_name>corresponds to the metric field (STRING){<label1>=<value1>,<label2>=<value2>,...}represents the labels field (JSON)<metric_value>maps to the value field (DOUBLE)<timestamp>corresponds to the ts field (TIMESTAMP)
Table schema
| Column | Type | Field type | Description |
|---|---|---|---|
| metric | STRING | Dimension | The name of the Prometheus metric |
| labels | JSON | Dimension | A JSON object containing key-value pairs of Prometheus labels |
| value | DOUBLE | Metric | The numeric value of the metric |
| ts | TIMESTAMP | Date-Time | The timestamp when the metric was recorded, in milliseconds since the Unix epoch |
- The schema created for ingesting Prometheus metrics MUST adhere to the format specified above, particularly with respect to the field names and data types.
- If you require different field names in your Pinot table, you can add transform functions to alias the names.
- However, the incoming data must match this specified schema for the Prometheus Message Decoder to function correctly.
Schema Configuration
Configuration Example
When ingesting a Prometheus Message formatted payload from a stream, the decoder used for the stream must be ai.startree.pinot.plugin.inputformat.prometheus.PrometheusMessageDecoderorg.apache.pinot.plugin.stream.kafka20.KafkaConsumerFactory and
the decoder associated with this stream is ai.startree.pinot.plugin.inputformat.prometheus.PrometheusMessageDecoder".
