Sha256: 2276ad9e922acfea504e51c647ef0720da2f5dff8717f42efe53d74e62df06df
Contents?: true
Size: 1.15 KB
Versions: 1
Compression:
Stored size: 1.15 KB
Contents
# frozen_string_literal: true module PrometheusExporter::Server class SidekiqQueueCollector < TypeCollector MAX_SIDEKIQ_METRIC_AGE = 60 SIDEKIQ_QUEUE_GAUGES = { 'backlog_total' => 'Size of the sidekiq queue.', 'latency_seconds' => 'Latency of the sidekiq queue.', }.freeze attr_reader :sidekiq_metrics, :gauges def initialize @sidekiq_metrics = [] @gauges = {} end def type 'sidekiq_queue' end def metrics sidekiq_metrics.map do |metric| labels = metric.fetch("labels", {}) SIDEKIQ_QUEUE_GAUGES.map do |name, help| if (value = metric[name]) gauge = gauges[name] ||= PrometheusExporter::Metric::Gauge.new("sidekiq_queue_#{name}", help) gauge.observe(value, labels) end end end gauges.values end def collect(object) now = ::Process.clock_gettime(::Process::CLOCK_MONOTONIC) object['queues'].each do |queue| queue["created_at"] = now sidekiq_metrics.delete_if { |metric| metric['created_at'] + MAX_SIDEKIQ_METRIC_AGE < now } sidekiq_metrics << queue end end end end
Version data entries
1 entries across 1 versions & 1 rubygems
Version | Path |
---|---|
prometheus_exporter-0.5.2 | lib/prometheus_exporter/server/sidekiq_queue_collector.rb |