Class: Thrifter::ClientMetrics

Inherits:
Object
  • Object
show all
Defined in:
lib/thrifter/middleware/client_metrics.rb

Instance Method Summary collapse

Instance Method Details

#call(rpc) ⇒ Object



5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
# File 'lib/thrifter/middleware/client_metrics.rb', line 5

def call(rpc)
  statsd.increment 'rpc.outgoing'

  response = statsd.time "rpc.latency" do #{rpc.name do
    app.call rpc
  end

  statsd.increment 'rpc.success'

  response
rescue Thrift::TransportException => ex
  statsd.increment 'rpc.error'
  statsd.increment 'rpc.error.transport'
  raise ex
rescue Thrift::ProtocolException => ex
  statsd.increment 'rpc.error'
  statsd.increment 'rpc.error.protocol'
  raise ex
rescue Thrift::ApplicationException => ex
  statsd.increment 'rpc.error'
  statsd.increment 'rpc.error.application'
  raise ex
rescue Timeout::Error => ex
  statsd.increment 'rpc.error'
  statsd.increment 'rpc.error.timeout'
  raise ex
rescue Thrifter::RetryError  => ex
  statsd.increment 'rpc.error'
  statsd.increment 'rpc.error.retry'
  raise ex
rescue => ex
  statsd.increment 'rpc.error'
  statsd.increment 'rpc.error.other'
  raise ex
end