Sha256: af2c67e0bbcc8358d1e988e8f3236e9280de7c4ea21cce8b4cd893a09a8cd2d2

Contents?: true

Size: 1.13 KB

Versions: 2

Compression:

Stored size: 1.13 KB

Contents

# frozen_string_literal: true
module PrometheusExporter::Server
  class SidekiqQueueCollector < TypeCollector
    MAX_METRIC_AGE = 60

    SIDEKIQ_QUEUE_GAUGES = {
      'backlog' => 'Size of the sidekiq queue.',
      'latency_seconds' => 'Latency of the sidekiq queue.',
    }.freeze

    attr_reader :sidekiq_metrics, :gauges

    def initialize
      @sidekiq_metrics = MetricsContainer.new(ttl: MAX_METRIC_AGE)
      @gauges = {}
    end

    def type
      'sidekiq_queue'
    end

    def metrics
      SIDEKIQ_QUEUE_GAUGES.each_key { |name| gauges[name]&.reset! }

      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)
      object['queues'].each do |queue|
        queue["labels"].merge!(object['custom_labels']) if object['custom_labels']
        @sidekiq_metrics << queue
      end
    end
  end
end

Version data entries

2 entries across 2 versions & 1 rubygems

Version Path
prometheus_exporter-2.1.1 lib/prometheus_exporter/server/sidekiq_queue_collector.rb
prometheus_exporter-2.1.0 lib/prometheus_exporter/server/sidekiq_queue_collector.rb