Sha256: 2f0ac34c16c437b30b6248eca5627eb376088a2b7563d8f3297ba1c63f33350a

Contents?: true

Size: 1.26 KB

Versions: 51

Compression:

Stored size: 1.26 KB

Contents

# 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.

module NewRelic
  module Agent
    module LogOnce
      NUM_LOG_ONCE_KEYS = 1000

      def log_once(level, key, *msgs)
        @already_logged_lock.synchronize do
          return if @already_logged.include?(key)

          if @already_logged.size >= NUM_LOG_ONCE_KEYS && key.kind_of?(String)
            # The reason for preventing too many keys in `logged` is for
            # memory concerns.
            # The reason for checking the type of the key is that we always want
            # to allow symbols to log, since there are very few of them.
            # The assumption here is that you would NEVER pass dynamically-created
            # symbols, because you would never create symbols dynamically in the
            # first place, as that would already be a memory leak in most Rubies,
            # even if we didn't hang on to them all here.
            return
          end

          @already_logged[key] = true
        end

        self.send(level, *msgs)
      end

      def clear_already_logged
        @already_logged_lock.synchronize do
          @already_logged = {}
        end
      end
    end
  end
end

Version data entries

51 entries across 51 versions & 2 rubygems

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