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