class ElasticAPM::Instrumenter
@api private
def current_transaction
def current_transaction @transaction_info.current end
def current_transaction=(transaction)
def current_transaction=(transaction) @transaction_info.current = transaction end
def flush_transactions
def flush_transactions return if @pending_transactions.empty? debug 'Sending %i transactions', @pending_transactions.length @agent.enqueue_transactions @pending_transactions @last_sent_transactions = Time.now.utc @pending_transactions = [] true end
def initialize(config, agent, subscriber_class: Subscriber)
def initialize(config, agent, subscriber_class: Subscriber) @config = config @agent = agent @transaction_info = TransactionInfo.new @subscriber = subscriber_class.new(config) @pending_transactions = [] @last_sent_transactions = Time.now.utc end
def inspect
def inspect '<ElasticAPM::Instrumenter ' \ "current_transaction=#{current_transaction.inspect}" \ '>' end
def set_custom_context(context)
def set_custom_context(context) transaction.context.custom.merge!(context) end
def set_tag(key, value)
def set_tag(key, value) transaction.context.tags[key] = value.to_s end
def set_user(user)
def set_user(user) transaction.context.user = Context::User.new(config, user) end
def should_flush_transactions?
def should_flush_transactions? interval = config.flush_interval return true if interval.nil? return true if @pending_transactions.length >= config.max_queue_size Time.now.utc - @last_sent_transactions >= interval end
def span(*args, &block)
def span(*args, &block) transaction.span(*args, &block) end
def start
def start @subscriber.register! end
def stop
def stop current_transaction.release if current_transaction @subscriber.unregister! end
def submit_transaction(transaction)
def submit_transaction(transaction) @pending_transactions << transaction if config.debug_transactions debug('Submitted transaction:') { Util.inspect_transaction transaction } end return unless should_flush_transactions? flush_transactions end
def transaction(*args)
def transaction(*args) if (transaction = current_transaction) yield transaction if block_given? return transaction end sample = rand <= config.transaction_sample_rate if args.last.is_a? Hash args.last[:sampled] = sample else args.push(sampled: sample) end transaction = Transaction.new self, *args self.current_transaction = transaction return transaction unless block_given? begin yield transaction ensure self.current_transaction = nil transaction.done end transaction end