-
Notifications
You must be signed in to change notification settings - Fork 4
/
Copy pathtwemstats.rb
46 lines (40 loc) · 1.27 KB
/
twemstats.rb
1
2
3
4
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
40
41
42
43
44
45
46
#!/opt/rbenv/shims/ruby
require 'socket'
require 'json'
stats = {}
s_stats = {}
req_stats = {}
res_stats = {}
cur_conn = 0
total = 0
exit! if ARGV[0].nil?
conn = TCPSocket.new '0.0.0.0', 22222
while stream = conn.gets
stats = JSON.parse(stream)
end
# Collect stats
stats.map { |x|
x.map { |cluster|
if cluster.instance_of? Hash
if cluster['client_connections'].to_i > 0
cur_conn = cluster['client_connections'].to_i
cluster.map { |s_key,s_val|
if s_val.instance_of? Hash
num_of_times_server_was_ejected = ((s_val['server_err'] + s_val['server_timedout'] + s_val['server_eof']) / ARGV[0].to_i)
s_stats.merge!(s_key => num_of_times_server_was_ejected)
req_stats.merge!(s_key => (s_val['request_bytes'] / s_val['requests']))
res_stats.merge!(s_key => (s_val['response_bytes'] / s_val['responses']))
end
}
end
end
}
}
# Print stats
max_size = (s_stats.max_by { |k,v| v }.last > 0) ? s_stats.max_by { |k,v| v }.last : 1
s_stats.map { |srv,count|
print "#{srv.split('.').first} E=#{count} (#{(100 * count) / max_size}%), ReqS=#{req_stats[srv]} ResS=#{res_stats[srv]}\n"
total += count
}
print "Total ejection count: #{total}\n"
print "Total current connections: #{cur_conn}\n"