Sha256: e44f2933c582aa8e16e222ccde9d2878d1a8f658f5da934ec530fbffeabc796a
Contents?: true
Size: 1.27 KB
Versions: 13
Compression:
Stored size: 1.27 KB
Contents
# frozen_string_literal: true module Karafka module Web module Tracking # Namespace for all the things related to tracking producers module Producers # Samples for collecting producers related data we're interested in class Sampler < Tracking::Sampler include ::Karafka::Core::Helpers::Time attr_reader :errors # Current schema version # This can be used in the future for detecting incompatible changes and writing # migrations SCHEMA_VERSION = '1.1.0' def initialize super @errors = [] @started_at = float_now end # We cannot report and track the same time, that is why we use mutex here. To make sure # that samples aggregations and counting does not interact with reporter flushing. def track # Prevents deadlocks when something producer related fails in the Web UI reporter return yield(self) if Reporter::MUTEX.owned? Reporter::MUTEX.synchronize do yield(self) end end # Clears the sampler (for use after data dispatch) def clear @errors.clear end end end end end end
Version data entries
13 entries across 13 versions & 1 rubygems