2018-11-09 13:39:43 -05:00
|
|
|
# frozen_string_literal: true
|
|
|
|
|
2018-05-26 00:00:26 -04:00
|
|
|
# This grape_logging module (https://github.com/aserafin/grape_logging) makes it
|
|
|
|
# possible to log how much time an API request was queued by Workhorse.
|
|
|
|
module Gitlab
|
|
|
|
module GrapeLogging
|
|
|
|
module Loggers
|
|
|
|
class QueueDurationLogger < ::GrapeLogging::Loggers::Base
|
|
|
|
attr_accessor :start_time
|
|
|
|
|
|
|
|
def before
|
|
|
|
@start_time = Time.now
|
|
|
|
end
|
|
|
|
|
|
|
|
def parameters(request, _)
|
|
|
|
proxy_start = request.env['HTTP_GITLAB_WORKHORSE_PROXY_START'].presence
|
|
|
|
|
|
|
|
return {} unless proxy_start && start_time
|
|
|
|
|
|
|
|
# Time in milliseconds since gitlab-workhorse started the request
|
|
|
|
duration = (start_time.to_f * 1_000 - proxy_start.to_f / 1_000_000).round(2)
|
|
|
|
|
|
|
|
{ 'queue_duration': duration }
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|