-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathtimings.pike
23 lines (23 loc) · 1.04 KB
/
timings.pike
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
//Calculate off a full matrix of timings for a given origin
//Run this on every available origin to show the timings.
__async__ int main() {
string origin = gethostname() || "?";
write("%-8s | %-8s | %-8s | Time | Time | Time\n", "Origin", "Bot", "Database");
foreach (({"sikorsky", "gideon"}), string host) {
Protocols.HTTP.Promise.Result res = await(Protocols.HTTP.Promise.get_url(sprintf("https://%s.mustardmine.com/serverstatus?which", host)));
mapping data = Standards.JSON.decode_utf8(res->get());
sscanf(data->responder, "%s.", string bot);
sscanf(data->db_fast, "%s.", string fastdb);
sscanf(data->db_live, "%s.", string livedb);
foreach (({"pingro", "pingrw"}), string endpoint) { //Add more if needed
string url = sprintf("https://%s.mustardmine.com/%s", host, endpoint);
write("%-8s | %-8s | %-8s", origin, bot, endpoint == "pingro" ? fastdb : livedb);
for (int i = 0; i < 3; ++i) {
System.Timer tm = System.Timer();
await(Protocols.HTTP.Promise.get_url(url));
write(" | %.3f", tm->peek());
}
write("\n");
}
}
}