From 622a1770df1baa13c02f155cde3301306c8f8be0 Mon Sep 17 00:00:00 2001 From: Nat Lasseter Date: Mon, 16 Nov 2020 12:22:57 +0000 Subject: Add histogram and summary support --- lib/longboat/collector.rb | 74 ++++++++++++++++++++++++++++++++++++++++------- 1 file changed, 64 insertions(+), 10 deletions(-) (limited to 'lib/longboat') diff --git a/lib/longboat/collector.rb b/lib/longboat/collector.rb index e217ab4..7fd4f6f 100644 --- a/lib/longboat/collector.rb +++ b/lib/longboat/collector.rb @@ -46,27 +46,81 @@ module Longboat res = "" @metrics.each do |name, metric| res << ?\n unless res.empty? + res << "#HELP #{name} #{metric[:help]}\n" unless metric[:help].nil? res << "#TYPE #{name} #{metric[:type]}\n" unless metric[:type].nil? - metric.each do |labels, value| - next if labels == :help - next if labels == :type - - labellist = [] - labels.each do |k, v| - labellist << "#{k}=\"#{v}\"" + case metric[:type] + when "gauge", "counter" + metric.each do |labelset, value| + next if labelset == :help + next if labelset == :type + res << stringify_gaugecounter(name, labelset, value[:value], value[:timestamp]) + end + when "histogram" + metric.each do |labelset, value| + next if labelset == :help + next if labelset == :type + res << stringify_histogram(name, labelset, value[:value], value[:timestamp]) + end + when "summary" + metric.each do |labelset, value| + next if labelset == :help + next if labelset == :type + res << stringify_summary(name, labelset, value[:value], value[:timestamp]) end - labellist = labellist.join(",") - - res << "#{name}{#{labellist}} #{value[:value]} #{(value[:timestamp].to_f * 1000).to_i}\n" end end + res end private + def stringify_gaugecounter(name, labelset, value, timestamp) + labels = prometheus_labels(labelset) + timestamp = (timestamp.to_f * 1000).to_i + + "#{name}{#{labels}} #{value} #{timestamp}\n" + end + + def stringify_histogram(name, labelset, data, timestamp) + res = "" + + data[:buckets].each do |bkt, cnt| + res << stringify_gaugecounter("#{name}_bucket", labelset.merge({le: bkt.to_s}), cnt, timestamp) + end + + res << stringify_gaugecounter("#{name}_bucket", labelset.merge({le: "+Inf"}), data[:count], timestamp) + res << stringify_gaugecounter("#{name}_count", labelset, data[:count], timestamp) + res << stringify_gaugecounter("#{name}_sum", labelset, data[:sum], timestamp) + + res + end + + def stringify_summary(name, labelset, data, timestamp) + res = "" + + data[:quantiles].each do |qtl, val| + res << stringify_gaugecounter(name, labelset.merge({quantile: qtl.to_s}), val, timestamp) + end + + res << stringify_gaugecounter("#{name}_count", labelset, data[:count], timestamp) + res << stringify_gaugecounter("#{name}_sum", labelset, data[:sum], timestamp) + + res + end + + def prometheus_labels(labelset) + labellist = [] + + labelset.each do |k, v| + labellist << "#{k}=\"#{v}\"" + end + + labellist.join(",") + end + def prefix(name) "#{@config[:metric_prefix]}#{name}" end -- cgit v1.2.1