Sha256: 663d2fce5d6c05f9ca36a0c69585f47e928f3dd34c79614af6ca65dd8055a4ac

Contents?: true

Size: 1.98 KB

Versions: 9

Compression:

Stored size: 1.98 KB

Contents

# frozen_string_literal: true

module PrometheusExporter::Server
  class SidekiqCollector < TypeCollector

    def type
      "sidekiq"
    end

    def collect(obj)
      default_labels = { job_name: obj['name'] }
      custom_labels = obj['custom_labels']
      labels = custom_labels.nil? ? default_labels : default_labels.merge(custom_labels)

      ensure_sidekiq_metrics
      if obj["dead"]
        @sidekiq_dead_jobs_total.observe(1, labels)
      else
        @sidekiq_job_duration_seconds.observe(obj["duration"], labels)
        @sidekiq_jobs_total.observe(1, labels)
        @sidekiq_restarted_jobs_total.observe(1, labels) if obj["shutdown"]
        @sidekiq_failed_jobs_total.observe(1, labels) if !obj["success"] && !obj["shutdown"]
      end
    end

    def metrics
      if @sidekiq_jobs_total
        [
          @sidekiq_job_duration_seconds,
          @sidekiq_jobs_total,
          @sidekiq_restarted_jobs_total,
          @sidekiq_failed_jobs_total,
          @sidekiq_dead_jobs_total,
        ]
      else
        []
      end
    end

    protected

    def ensure_sidekiq_metrics
      if !@sidekiq_jobs_total

        @sidekiq_job_duration_seconds =
        PrometheusExporter::Metric::Counter.new(
          "sidekiq_job_duration_seconds", "Total time spent in sidekiq jobs.")

        @sidekiq_jobs_total =
        PrometheusExporter::Metric::Counter.new(
          "sidekiq_jobs_total", "Total number of sidekiq jobs executed.")

        @sidekiq_restarted_jobs_total =
        PrometheusExporter::Metric::Counter.new(
          "sidekiq_restarted_jobs_total", "Total number of sidekiq jobs that we restarted because of a sidekiq shutdown.")

        @sidekiq_failed_jobs_total =
        PrometheusExporter::Metric::Counter.new(
          "sidekiq_failed_jobs_total", "Total number of failed sidekiq jobs.")

        @sidekiq_dead_jobs_total =
        PrometheusExporter::Metric::Counter.new(
          "sidekiq_dead_jobs_total", "Total number of dead sidekiq jobs.")
      end
    end
  end
end

Version data entries

9 entries across 9 versions & 1 rubygems

Version Path
prometheus_exporter-0.5.1 lib/prometheus_exporter/server/sidekiq_collector.rb
prometheus_exporter-0.5.0 lib/prometheus_exporter/server/sidekiq_collector.rb
prometheus_exporter-0.4.17 lib/prometheus_exporter/server/sidekiq_collector.rb
prometheus_exporter-0.4.16 lib/prometheus_exporter/server/sidekiq_collector.rb
prometheus_exporter-0.4.15 lib/prometheus_exporter/server/sidekiq_collector.rb
prometheus_exporter-0.4.14 lib/prometheus_exporter/server/sidekiq_collector.rb
prometheus_exporter-0.4.13 lib/prometheus_exporter/server/sidekiq_collector.rb
prometheus_exporter-0.4.12 lib/prometheus_exporter/server/sidekiq_collector.rb
prometheus_exporter-0.4.11 lib/prometheus_exporter/server/sidekiq_collector.rb