[Author Prev][Author Next][Thread Prev][Thread Next][Author Index][Thread Index]

[or-cvs] [torflow/master 1/2] Add somewhat support for displaying exit port stats.



Author: Mike Perry <mikeperry-git@xxxxxxxxxx>
Date: Mon, 6 Dec 2010 13:23:07 -0800
Subject: Add somewhat support for displaying exit port stats.
Commit: 0a6f91390e5437836a395398b7f7d0db23faa900

Somewhat hackish, but gets the job done. Also updates statssplitter to use
atagar's new control port authentication helper routines.
---
 NetworkScanners/statsplitter.py |   80 +++++++++++++++++++++++++++++++++++----
 1 files changed, 72 insertions(+), 8 deletions(-)

diff --git a/NetworkScanners/statsplitter.py b/NetworkScanners/statsplitter.py
index 6d0b835..2b088d1 100755
--- a/NetworkScanners/statsplitter.py
+++ b/NetworkScanners/statsplitter.py
@@ -2,6 +2,7 @@
 import sys
 import socket
 import math
+import re
 
 sys.path.append("../")
 #from TorCtl import *
@@ -23,12 +24,11 @@ def cleanup(c, f):
   
 
 s = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
-s.connect((control_host,control_port))
-c = Connection(s)
+c = TorCtl.connect("127.0.0.1",9051)
 c.debug(file("control.log", "w"))
-c.authenticate(control_pass)
 #c.authenticate_cookie(file("/home/torperf/tor-data1/control_auth_cookie", "r"))
 FUDValue = c.get_option("FetchUselessDescriptors")[0][1]
+ExtraInfoValue = c.get_option("DownloadExtraInfo")[0][1]
 c.set_option("FetchUselessDescriptors", "1") 
 atexit.register(cleanup, *(c, FUDValue))
 nslist = c.get_network_status()
@@ -212,11 +212,10 @@ def check_entropy(rlist, clipping_point):
   print "Consensus Exit entropy: " + str(-exit_entropy)
 
   print ""
-  print "Guard Weights: E: "+str(ggen.guard_weight)+" M: "+str(mgen.guard_weight)+" X: "+str(egen.guard_weight)
-  print "Exit Weights: E: "+str(ggen.exit_weight)+" M: "+str(mgen.exit_weight)+" X: "+str(egen.exit_weight)
-  print "Guard+Exit Weights: E: "+str(ggen.guard_weight*ggen.exit_weight)+" M: "+str(mgen.guard_weight*mgen.exit_weight)+" X: "+str(egen.guard_weight*egen.exit_weight)
-
-  print ""
+#  print "Guard Weights: E: "+str(ggen.guard_weight)+" M: "+str(mgen.guard_weight)+" X: "+str(egen.guard_weight)
+#  print "Exit Weights: E: "+str(ggen.exit_weight)+" M: "+str(mgen.exit_weight)+" X: "+str(egen.exit_weight)
+#  print "Guard+Exit Weights: E: "+str(ggen.guard_weight*ggen.exit_weight)+" M: "+str(mgen.guard_weight*mgen.exit_weight)+" X: "+str(egen.guard_weight*egen.exit_weight)
+#  print ""
 
   print "Nodes: "+str(nodes)+", Exits: "+str(exits)+" Total bw: "+str(round(bw/(1024.0*1024),2))+", Exit Bw: "+str(round(exit_bw/(1024.0*1024),2))
   print "Clipped: "+str(clipped)+", bw: "+str(round(clipped_bw/(1024.0*1024),2))
@@ -387,9 +386,74 @@ def check_slices():
   for i in xrange(0,100,10):
     check(i,i+10)
 
+def is_default_policy(r):
+  # XXX: Hack. Just checks for "accept *:*" in the last line.
+  if r.exitpolicy[-1].ip == 0 and r.exitpolicy[-1].netmask == 0 and \
+     r.exitpolicy[-1].port_low == 0 and r.exitpolicy[-1].port_high == 65535 \
+     and r.exitpolicy[-1].match:
+    return True
+  return False
+
+def split_port_list(line):
+  ret = {}
+  tot=0
+  ports = line.split(",")
+  for p in ports:
+    pair = p.split("=")
+    ret[pair[0]]=int(pair[1])
+    tot+=int(pair[1])
+  if tot:
+    keys = ret.keys()
+    for p in keys:
+      ret[p] = round((100.0*ret[p])/tot,1)
+  else:
+    return (tot, None)
+  return (tot, ret)
+
+def display_port_list(r, which, tot, port_list):
+  if not port_list: return
+  keys = port_list.keys()
+  keys.sort(lambda y,x: int((port_list[x] - port_list[y])*100))
+  if is_default_policy(r):
+    name = "Default exit "+r.nickname
+  else:
+    name = "Misc Exit "+r.nickname
+
+  print name+" "+which+" "+str(round(tot/(1024.0*1024.0),1))+"M"
+  out = "   "
+  for k in keys[:6]:
+    out += str(k)+": "+str(port_list[k])+"% "
+  print out
+
+def check_port_bytes(sorted_rlist, top_n):
+  displayed=0
+  for r in sorted_rlist[0:50]:
+    if displayed > top_n: return
+    if r.extra_info_digest and "Exit" in r.flags:
+      try:
+        extra_info = c.sendAndRecv("GETINFO extra-info/digest/" +
+                              r.extra_info_digest + "\r\n")[0][2]
+      except TorCtl.ErrorReply:
+        print "Not all extra info docs present. Missing one for router "+r.idhex+"="+r.nickname
+      if "exit-kibibytes-written" in extra_info:
+        displayed += 1
+        g = re.search("exit-kibibytes-read (\S+)", extra_info).group(1)
+        (tot, port_list) = split_port_list(g)
+        display_port_list(r, "read", tot, port_list)
+        g = re.search("exit-kibibytes-written (\S+)", extra_info).group(1)
+        (tot, port_list) = split_port_list(g)
+        display_port_list(r, "wrote", tot, port_list)
+        print
+
 check_slices()
 
 tot_bw = check(0, 100)
 check_ratios(sorted_rlist)
 
 check_entropy(sorted_rlist, 0.05*tot_bw)
+
+if ExtraInfoValue == "0":
+  print "DownloadExtraInfo must be set in order to display per-port stats."
+  print "\n"
+else:
+  check_port_bytes(sorted_rlist, 10)
-- 
1.7.1