Sha256: 8a669e469c016fd1df1bb5bb60ba36bf72f5040dfac649a00c2c7d9e65111dc3
Contents?: true
Size: 1.6 KB
Versions: 2
Compression:
Stored size: 1.6 KB
Contents
# frozen_string_literal: true module PrometheusExporter::Server class PumaCollector < TypeCollector MAX_PUMA_METRIC_AGE = 30 PUMA_GAUGES = { workers: "Number of puma workers.", booted_workers: "Number of puma workers booted.", old_workers: "Number of old puma workers.", running_threads: "Number of puma threads currently running.", request_backlog: "Number of requests waiting to be processed by a puma thread.", thread_pool_capacity: "Number of puma threads available at current scale.", max_threads: "Number of puma threads at available at max scale.", } def initialize @puma_metrics = MetricsContainer.new(ttl: MAX_PUMA_METRIC_AGE) @puma_metrics.filter = -> (new_metric, old_metric) do new_metric["pid"] == old_metric["pid"] && new_metric["hostname"] == old_metric["hostname"] end end def type "puma" end def metrics return [] if @puma_metrics.length == 0 metrics = {} @puma_metrics.map do |m| labels = {} if m["phase"] labels.merge!(phase: m["phase"]) end if m["custom_labels"] labels.merge!(m["custom_labels"]) end if m["metric_labels"] labels.merge!(m["metric_labels"]) end PUMA_GAUGES.map do |k, help| k = k.to_s if v = m[k] g = metrics[k] ||= PrometheusExporter::Metric::Gauge.new("puma_#{k}", help) g.observe(v, labels) end end end metrics.values end def collect(obj) @puma_metrics << obj end end end
Version data entries
2 entries across 2 versions & 1 rubygems
Version | Path |
---|---|
prometheus_exporter-2.1.1 | lib/prometheus_exporter/server/puma_collector.rb |
prometheus_exporter-2.1.0 | lib/prometheus_exporter/server/puma_collector.rb |