Sha256: 2d4b76de0ad64c1d4fbacb8ceff209d1135fdb8879b54627b42f6e403a652107
Contents?: true
Size: 1.35 KB
Versions: 1
Compression:
Stored size: 1.35 KB
Contents
# frozen_string_literal: true module PrometheusExporter::Server class SidekiqStatsCollector < TypeCollector MAX_SIDEKIQ_METRIC_AGE = 60 SIDEKIQ_STATS_GAUGES = { 'dead_size' => 'Size of dead the queue', 'enqueued' => 'Number of enqueued jobs', 'failed' => 'Number of failed jobs', 'processed' => 'Total number of processed jobs', 'processes_size' => 'Number of processes', 'retry_size' => 'Size of the retries queue', 'scheduled_size' => 'Size of the scheduled queue', 'workers_size' => 'Number of jobs actively being processed', }.freeze attr_reader :sidekiq_metrics, :gauges def initialize @sidekiq_metrics = [] @gauges = {} end def type 'sidekiq_stats' end def metrics sidekiq_metrics.map do |metric| SIDEKIQ_STATS_GAUGES.map do |name, help| if (value = metric['stats'][name]) gauge = gauges[name] ||= PrometheusExporter::Metric::Gauge.new("sidekiq_stats_#{name}", help) gauge.observe(value) end end end gauges.values end def collect(object) now = ::Process.clock_gettime(::Process::CLOCK_MONOTONIC) object['created_at'] = now sidekiq_metrics.delete_if { |metric| metric['created_at'] + MAX_SIDEKIQ_METRIC_AGE < now } sidekiq_metrics << object end end end
Version data entries
1 entries across 1 versions & 1 rubygems
Version | Path |
---|---|
prometheus_exporter-2.0.6 | lib/prometheus_exporter/server/sidekiq_stats_collector.rb |