Sha256: 7ed9df8f65f0000abe1063154dcd8b7034bffbbff50ede5c2d348aece79f5353

Contents?: true

Size: 1.89 KB

Versions: 26

Compression:

Stored size: 1.89 KB

Contents

# -*- ruby -*-
# This file is distributed under New Relic's license terms.
# See https://github.com/newrelic/newrelic-ruby-agent/blob/main/LICENSE for complete details.
# frozen_string_literal: true

require 'newrelic_rpm' unless defined?(NewRelic)
require 'new_relic/agent' unless defined?(NewRelic::Agent)
require 'new_relic/agent/event_aggregator'
require 'new_relic/agent/priority_sampled_buffer'

module NewRelic
  module Agent
    class TransactionEventAggregator < EventAggregator
      named :TransactionEventAggregator
      capacity_key :'transaction_events.max_samples_stored'
      enabled_key :'transaction_events.enabled'
      buffer_class PrioritySampledBuffer

      def record(priority: nil, event: nil, &blk)
        unless event || priority && blk
          raise ArgumentError, 'Expected priority and block, or event'
        end

        return unless enabled?

        @lock.synchronize do
          @buffer.append(priority: priority, event: event, &blk)
          notify_if_full
        end
      end

      private

      def after_harvest(metadata)
        return unless enabled?

        record_sampling_rate(metadata)
      end

      def record_sampling_rate(metadata) # THREAD_LOCAL_ACCESS
        NewRelic::Agent.logger.debug('Sampled %d / %d (%.1f %%) requests this cycle, %d / %d (%.1f %%) since startup' % [
          metadata[:captured],
          metadata[:seen],
          (metadata[:captured].to_f / metadata[:seen] * 100.0),
          metadata[:captured_lifetime],
          metadata[:seen_lifetime],
          (metadata[:captured_lifetime].to_f / metadata[:seen_lifetime] * 100.0)
        ])

        engine = NewRelic::Agent.instance.stats_engine
        engine.tl_record_supportability_metric_count('TransactionEventAggregator/requests', metadata[:seen])
        engine.tl_record_supportability_metric_count('TransactionEventAggregator/samples', metadata[:captured])
      end
    end
  end
end

Version data entries

26 entries across 26 versions & 1 rubygems

Version Path
newrelic_rpm-9.17.0 lib/new_relic/agent/transaction_event_aggregator.rb
newrelic_rpm-9.16.1 lib/new_relic/agent/transaction_event_aggregator.rb
newrelic_rpm-9.16.0 lib/new_relic/agent/transaction_event_aggregator.rb
newrelic_rpm-9.15.0 lib/new_relic/agent/transaction_event_aggregator.rb
newrelic_rpm-9.14.0 lib/new_relic/agent/transaction_event_aggregator.rb
newrelic_rpm-9.13.0 lib/new_relic/agent/transaction_event_aggregator.rb
newrelic_rpm-9.12.0 lib/new_relic/agent/transaction_event_aggregator.rb
newrelic_rpm-9.11.0 lib/new_relic/agent/transaction_event_aggregator.rb
newrelic_rpm-9.10.2 lib/new_relic/agent/transaction_event_aggregator.rb
newrelic_rpm-9.10.1 lib/new_relic/agent/transaction_event_aggregator.rb
newrelic_rpm-9.10.0 lib/new_relic/agent/transaction_event_aggregator.rb
newrelic_rpm-9.9.0 lib/new_relic/agent/transaction_event_aggregator.rb
newrelic_rpm-9.8.0 lib/new_relic/agent/transaction_event_aggregator.rb
newrelic_rpm-9.7.1 lib/new_relic/agent/transaction_event_aggregator.rb
newrelic_rpm-9.7.0 lib/new_relic/agent/transaction_event_aggregator.rb
newrelic_rpm-9.6.0 lib/new_relic/agent/transaction_event_aggregator.rb
newrelic_rpm-9.5.0 lib/new_relic/agent/transaction_event_aggregator.rb
newrelic_rpm-9.4.2 lib/new_relic/agent/transaction_event_aggregator.rb
newrelic_rpm-9.4.1 lib/new_relic/agent/transaction_event_aggregator.rb
newrelic_rpm-9.4.0 lib/new_relic/agent/transaction_event_aggregator.rb