Sha256: 02449030773ba7f170996179f69bcd66dc0fc74e75dc6e6ec3bc458350a56e34
Contents?: true
Size: 1.82 KB
Versions: 4
Compression:
Stored size: 1.82 KB
Contents
# frozen_string_literal: true module ElasticAPM # @api private module Spies # @api private class SidekiqSpy ACTIVE_JOB_WRAPPER = 'ActiveJob::QueueAdapters::SidekiqAdapter::JobWrapper' # @api private class Middleware def call(_worker, job, queue) name = SidekiqSpy.name_for(job) transaction = ElasticAPM.start_transaction(name, 'Sidekiq') ElasticAPM.set_label(:queue, queue) yield transaction&.done :success rescue ::Exception => e ElasticAPM.report(e, handled: false) transaction&.done :error raise ensure ElasticAPM.end_transaction end end def self.name_for(job) klass = job['class'] case klass when ACTIVE_JOB_WRAPPER job['wrapped'] else klass end end def install_middleware Sidekiq.configure_server do |config| config.server_middleware do |chain| chain.add Middleware end end end def install_processor require 'sidekiq/processor' Sidekiq::Processor.class_eval do alias start_without_apm start alias terminate_without_apm terminate def start result = start_without_apm # Already running from Railtie if Rails if ElasticAPM.running? ElasticAPM.agent.config.logger = Sidekiq.logger else ElasticAPM.start end result end def terminate terminate_without_apm ElasticAPM.stop end end end def install install_processor install_middleware end end register 'Sidekiq', 'sidekiq', SidekiqSpy.new end end
Version data entries
4 entries across 4 versions & 1 rubygems