Sha256: 86c9c9541a64a27ae9da82abd7d95355ae41e69dfc06fa5f511b7f7e916528f5
Contents?: true
Size: 1.51 KB
Versions: 2
Compression:
Stored size: 1.51 KB
Contents
# encoding: utf-8 # 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 module NewRelic::Agent module InfiniteTracing class RecordStatusHandler def initialize(client, enumerator) @client = client @enumerator = enumerator @messages_seen = nil @lock = Mutex.new @lock.synchronize { @worker = start_handler } end def messages_seen @messages_seen ? @messages_seen.messages_seen : 0 end def start_handler Worker.new(self.class.name) do begin @enumerator.each do |response| break if response.nil? || response.is_a?(Exception) @lock.synchronize do @messages_seen = response NewRelic::Agent.logger.debug("gRPC Infinite Tracer Observer saw #{messages_seen} messages") end end NewRelic::Agent.logger.debug("gRPC Infinite Tracer Observer closed the stream") @client.handle_close rescue => error @client.handle_error(error) end end rescue => error NewRelic::Agent.logger.error("gRPC Worker Error", error) end def stop return if @worker.nil? @lock.synchronize do NewRelic::Agent.logger.debug("gRPC Stopping Response Handler") @worker.stop @worker = nil end end end end end
Version data entries
2 entries across 2 versions & 1 rubygems
Version | Path |
---|---|
newrelic-infinite_tracing-8.10.1 | lib/infinite_tracing/record_status_handler.rb |
newrelic-infinite_tracing-8.10.0 | lib/infinite_tracing/record_status_handler.rb |