metrics/prometheus.v

102 lines
2.3 KiB
Coq
Raw Permalink Normal View History

2022-12-26 21:49:07 +01:00
module metrics
import strings
import io
pub struct PrometheusExporter {
mut:
prefix string
2022-12-30 09:55:39 +01:00
collector &MetricsCollector = unsafe { nil }
2022-12-26 21:49:07 +01:00
}
pub fn new_prometheus_exporter() PrometheusExporter {
return PrometheusExporter{}
2022-12-26 21:49:07 +01:00
}
pub fn (mut e PrometheusExporter) load(prefix string, collector &MetricsCollector) {
2022-12-30 09:55:39 +01:00
unsafe {
e.collector = collector
}
e.prefix = prefix
}
[inline]
fn join_two_array(arr [2]string) string {
return '${arr[0]}="${arr[1]}"'
}
pub fn (e &PrometheusExporter) serialize_metric(metric Metric) string {
if metric.labels.len == 0 {
2023-02-08 10:45:43 +01:00
return '${e.prefix}${metric.name}'
}
2023-02-08 10:45:43 +01:00
return '${e.prefix}${metric.name}{${metric.labels.map(join_two_array(it)).join(',')}}'
2022-12-26 21:49:07 +01:00
}
pub fn (mut e PrometheusExporter) export_to_string() !string {
mut builder := strings.new_builder(64)
e.export_to_writer(mut builder)!
return builder.str()
}
pub fn (mut e PrometheusExporter) export_to_writer(mut writer io.Writer) ! {
for counter in e.collector.counters() {
val := e.collector.counter_get(counter) or { return error("This can't happen.") }
2023-02-08 10:45:43 +01:00
line := '${e.serialize_metric(counter)} ${val}\n'
2022-12-26 21:49:07 +01:00
writer.write(line.bytes())!
}
for gauge in e.collector.gauges() {
val := e.collector.gauge_get(gauge) or { return error("This can't happen.") }
2023-02-08 10:45:43 +01:00
line := '${e.serialize_metric(gauge)} ${val}\n'
2022-12-26 21:49:07 +01:00
writer.write(line.bytes())!
}
for hist in e.collector.histograms() {
hist_data := e.collector.histogram_get(hist) or { return error("This can't happen.") }
2022-12-26 21:49:07 +01:00
mut m := Metric{
...hist
name: '${hist.name}_count'
}
2023-02-08 10:45:43 +01:00
writer.write('${e.serialize_metric(m)} ${hist_data.total_count}\n'.bytes())!
2022-12-26 21:49:07 +01:00
m = Metric{
...hist
name: '${hist.name}_sum'
}
2023-02-08 10:45:43 +01:00
writer.write('${e.serialize_metric(m)} ${hist_data.sum}\n'.bytes())!
2022-12-26 21:49:07 +01:00
mut le_labels := [][2]string{}
le_labels.prepend(hist.labels)
le_labels << ['le', '']!
for j, bucket in hist_data.buckets {
2022-12-26 21:49:07 +01:00
le_labels[le_labels.len - 1][1] = bucket.str()
m = Metric{
name: '${hist.name}_bucket'
labels: le_labels
}
writer.write('${e.serialize_metric(m)} ${hist_data.bucket_counts[j]}\n'.bytes())!
2022-12-26 21:49:07 +01:00
}
2023-01-04 10:31:48 +01:00
// Always output the +Inf bucket
le_labels[le_labels.len - 1][1] = '+Inf'
if hist_data.buckets.len > 0 {
m = Metric{
name: '${hist.name}_bucket'
labels: le_labels
}
2023-01-04 10:31:48 +01:00
2023-02-08 10:45:43 +01:00
writer.write('${e.serialize_metric(m)} ${hist_data.total_count}\n'.bytes())!
}
2022-12-26 21:49:07 +01:00
}
}