Sha256: 00357bb805af8f218d7e8d82b5e8da45ba12f9286e1d78e525f8d082c9103886

Contents?: true

Size: 1.86 KB

Versions: 18

Compression:

Stored size: 1.86 KB

Contents

# -*- ruby -*-
# encoding: utf-8
# This file is distributed under New Relic's license terms.
# See https://github.com/newrelic/rpm/blob/master/LICENSE for complete details.

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 :'analytics_events.max_samples_stored'
      enabled_key :'analytics_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

18 entries across 18 versions & 1 rubygems

Version Path
newrelic_rpm-6.11.0.365 lib/new_relic/agent/transaction_event_aggregator.rb
newrelic_rpm-6.10.0.364 lib/new_relic/agent/transaction_event_aggregator.rb
newrelic_rpm-6.9.0.363 lib/new_relic/agent/transaction_event_aggregator.rb
newrelic_rpm-6.8.0.360 lib/new_relic/agent/transaction_event_aggregator.rb
newrelic_rpm-6.7.0.359 lib/new_relic/agent/transaction_event_aggregator.rb
newrelic_rpm-6.6.0.358 lib/new_relic/agent/transaction_event_aggregator.rb
newrelic_rpm-6.5.0.357 lib/new_relic/agent/transaction_event_aggregator.rb
newrelic_rpm-6.4.0.356 lib/new_relic/agent/transaction_event_aggregator.rb
newrelic_rpm-6.3.0.355 lib/new_relic/agent/transaction_event_aggregator.rb
newrelic_rpm-6.2.0.354 lib/new_relic/agent/transaction_event_aggregator.rb
newrelic_rpm-6.1.0.352 lib/new_relic/agent/transaction_event_aggregator.rb
newrelic_rpm-6.0.0.351 lib/new_relic/agent/transaction_event_aggregator.rb
newrelic_rpm-5.7.0.350 lib/new_relic/agent/transaction_event_aggregator.rb
newrelic_rpm-5.6.0.349 lib/new_relic/agent/transaction_event_aggregator.rb
newrelic_rpm-5.5.0.348 lib/new_relic/agent/transaction_event_aggregator.rb
newrelic_rpm-5.4.0.347 lib/new_relic/agent/transaction_event_aggregator.rb
newrelic_rpm-5.3.0.346 lib/new_relic/agent/transaction_event_aggregator.rb
newrelic_rpm-5.2.0.345 lib/new_relic/agent/transaction_event_aggregator.rb