-
Notifications
You must be signed in to change notification settings - Fork 5
/
Copy pathstats.py
56 lines (48 loc) · 1.94 KB
/
stats.py
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
47
48
49
50
51
52
53
54
55
56
import requests
from prettytable import PrettyTable
import sys
def get_stats_tables(url=None):
url = url or "http://localhost:8888"
try:
request = requests.get(url)
if not request.ok:
raise requests.ConnectionError
data = request.json()
except requests.ConnectionError:
print("Error connecting to stats URL: %s" % url)
sys.exit(1)
except TypeError:
print("Error decoding JSON at stats URL: %s" % url)
sys.exit(1)
global_table = PrettyTable(
["Total Success", "Total Failures", "Average Query Time", "Total Runtime", "Estimated Queries Per Hour"])
global_table.add_row(
[data["total_successful_queries"], data["total_failed_queries"], data["average_query_time"],
data["total_runtime"],
data["queries_per_hour"]])
individual_table = PrettyTable(
["Thread", "Impala Host", "Total Success", "Total Failures", "Average Time", "Running Query Time",
"Estimated Queries Per Hour"])
for i in data.keys():
if i.startswith("Thread"):
running_query_time = ""
if data[i]["currently_running_query"]:
running_query_time = data[i]["currently_running_query_time"]
individual_table.add_row(
[i, data[i]["impala_host"], data[i]["successful"], data[i]["failures"], data[i]["average_query_time"],
running_query_time, data[i]["queries_per_hour"]])
return {"global": global_table, "individual": individual_table}
def print_stats(stats):
print("=" * 10 + " Global Stats " + "=" * 10)
print(stats["global"])
print("\n\n")
print("=" * 10 + " Individual Stats" + "=" * 10)
print(stats["individual"])
if __name__ == "__main__":
url = None
if len(sys.argv) > 1:
if sys.argv[1].startswith("http"):
url = sys.argv[1]
else:
url = "http://" + sys.argv[1]
print_stats(get_stats_tables(url=url))