diff options
author | Steven Murdoch <Steven.Murdoch@cl.cam.ac.uk> | 2009-01-22 12:49:04 +0000 |
---|---|---|
committer | Steven Murdoch <Steven.Murdoch@cl.cam.ac.uk> | 2009-01-22 12:49:04 +0000 |
commit | 15d3c285034c105f826481f9e104a268651492bb (patch) | |
tree | 759606c9787ebe6d9617da6a78a6906d0c2f9655 /doc | |
parent | 1ac3e2abce5b49f07fc9fdc35d50aadd4928e097 (diff) | |
download | tor-15d3c285034c105f826481f9e104a268651492bb.tar.gz tor-15d3c285034c105f826481f9e104a268651492bb.zip |
New section "Minimzing latency of paths" in performance optimization paper
svn:r18227
Diffstat (limited to 'doc')
-rw-r--r-- | doc/design-paper/performance.tex | 27 |
1 files changed, 26 insertions, 1 deletions
diff --git a/doc/design-paper/performance.tex b/doc/design-paper/performance.tex index 748eaa3f24..95d868b94a 100644 --- a/doc/design-paper/performance.tex +++ b/doc/design-paper/performance.tex @@ -51,6 +51,31 @@ \maketitle +\section{Minimzing latency of paths} + +Currently Tor selects paths purely by the random selection of nodes, biased by node bandwidth. +This will sometimes cause high latency circuits due to multiple ocean crossings or otherwise congested links. +An alternative approach would be to not only bias selection of nodes based on bandwidth, but to also bias the selection of hops based on expected latency. + +One option would be to predict the latency of hops based on geolocation of the node IP address. +This approach has the advantage of not requiring any additional measurement database to be published. +However, it does assume that the geolocation database is accurate and that physical distance between hops is an accurate estimator for latency. + +A second option would be to actually measure hop latency, and publish the database. +Nodes could do this themselves and include the results in their descriptor. +Alternatively, a central authority could perform the measurements and publish the results. +Performing these measurements would be a $O(n^2)$ problem, where $n$ is the number of nodes, so does not scale well. + +Publishing a latency database would also increase the size of the directory that each client must download. +If na\"{\i}vely implemented, the database would scale with $O(n^2)$. +However, a more efficient versions could be created, such as by dimension reduction, creating a map in which the distance between any two nodes is an approximation of the latency of a hop between them. +Delta compression could be used if the map changes slowly. + +Reducing the number of potential paths would also have anonymity consequences, and these would need to be carefully considered. +For example, an attacker who wishes to monitor traffic could create several nodes, on distinct /16 subnets, but with low latency between them. +A Tor client trying to minimize latency would be more likely to select these nodes for both entry than exit than it would otherwise. +This particular problem could be mitigated by selecting entry and exit node as normal, and only using latency measurements to select the middle node. + \section{Considering exit policy in node selection} When selecting an exit node for a circuit, a Tor client will build a list of all exit nodes which can carry the desired stream, then select from them with a probability weighted by each node's capacity\footnote{The actual algorithm is slightly more complex, in particular exit nodes which are also guard nodes will be weighted less, and there is also preemptive circuit creation}. @@ -170,7 +195,7 @@ The exception is a padding cell, which has no circuit ID and a zero length paylo \subsection*{Acknowledgements} -% Mike Perry +% Mike Perry provided many of the ideas discussed here \end{document} |