debian-mirror-gitlab/lib/api/sidekiq_metrics.rb

66 lines
1.6 KiB
Ruby
Raw Normal View History

2018-12-05 23:21:45 +05:30
# frozen_string_literal: true
2016-06-22 15:30:34 +05:30
require 'sidekiq/api'
module API
2020-07-28 23:09:34 +05:30
class SidekiqMetrics < Grape::API::Instance
2016-06-22 15:30:34 +05:30
before { authenticated_as_admin! }
helpers do
def queue_metrics
Sidekiq::Queue.all.each_with_object({}) do |queue, hash|
hash[queue.name] = {
backlog: queue.size,
latency: queue.latency.to_i
}
end
end
def process_metrics
Sidekiq::ProcessSet.new.map do |process|
{
hostname: process['hostname'],
pid: process['pid'],
tag: process['tag'],
started_at: Time.at(process['started_at']),
queues: process['queues'],
labels: process['labels'],
concurrency: process['concurrency'],
busy: process['busy']
}
end
end
def job_stats
stats = Sidekiq::Stats.new
{
processed: stats.processed,
failed: stats.failed,
2019-12-26 22:10:19 +05:30
enqueued: stats.enqueued,
dead: stats.dead_size
2016-06-22 15:30:34 +05:30
}
end
end
2017-08-17 22:00:37 +05:30
desc 'Get the Sidekiq queue metrics'
2016-06-22 15:30:34 +05:30
get 'sidekiq/queue_metrics' do
{ queues: queue_metrics }
end
2017-08-17 22:00:37 +05:30
desc 'Get the Sidekiq process metrics'
2016-06-22 15:30:34 +05:30
get 'sidekiq/process_metrics' do
{ processes: process_metrics }
end
2017-08-17 22:00:37 +05:30
desc 'Get the Sidekiq job statistics'
2016-06-22 15:30:34 +05:30
get 'sidekiq/job_stats' do
{ jobs: job_stats }
end
2017-08-17 22:00:37 +05:30
desc 'Get the Sidekiq Compound metrics. Includes queue, process, and job statistics'
2016-06-22 15:30:34 +05:30
get 'sidekiq/compound_metrics' do
{ queues: queue_metrics, processes: process_metrics, jobs: job_stats }
end
end
end