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

[or-cvs] r11163: Initial commit of a README about op-addon.py (torflow/trunk)



Author: renner
Date: 2007-08-18 08:41:30 -0400 (Sat, 18 Aug 2007)
New Revision: 11163

Added:
   torflow/trunk/op-addon-README
Log:

  Initial commit of a README about op-addon.py



Added: torflow/trunk/op-addon-README
===================================================================
--- torflow/trunk/op-addon-README	                        (rev 0)
+++ torflow/trunk/op-addon-README	2007-08-18 12:41:30 UTC (rev 11163)
@@ -0,0 +1,227 @@
+* For instructions on how to get OP-Addon, go to section 8
+* Installation instructions and prerequisites can be found in section 9
+
+###############################################################################
+
+1. Introduction:
+  
+  OP-Addon is intended for any people who are researching or experimenting with
+  circuit creation mechanisms and path selection in Tor, as well as for 
+  ambitious Tor users, who want to optimize their performance in user-tasks or
+  otherwise customize the method of path selection at their own risk. 
+  
+  It is a controller for Tor (clients), written in Python, that can be applied
+  to any locally running onion proxy that has a control port configured. By
+  making use of the Tor control protocol, it replaces Tor's default path 
+  selection and circuit management by highly configurable and customizable 
+  mechanisms. The user can freely configure the desired method of path 
+  selection, while the created paths can either be analyzed regarding their 
+  performance, or used to handle user streams, e.g. for browsing the web.
+
+  The only performance test that is currently included, is a method of 
+  measuring Tor latencies, that is based on violating the exit policy of the 
+  last hop in a path. Using this method, it is possible to measure latencies 
+  of complete n-hop circuits, as well as of single links between Tor routers
+  (see sections 5. & 6.).
+  
+  If you do not know what this is all about, and plan to implement your own 
+  application that creates circuits in a customized way or new measurings or
+  performance tests, please refer to section 7. The following sections will
+  explain the available features of OP-Addon that can be enabled and configured
+  using configuration options that are grouped in several sections 
+  ('pathrc.example' contains a commented example configuration).
+
+2. General configurations (sections HOST_PORT and CIRC_MANAGEMENT):
+
+  In any case you will need to provide the host and port, where Tor is 
+  listening for control connections (defaults are 127.0.0.1 and 9051). Control
+  port authentication will be added, as soon as I found a convenient way for
+  doing it. The option 'idle_circuits' lets the user specify a number of 
+  circuits that shall be created preemptively and available at every time. This
+  can be set to any integer value between 0 and n. If you set it to 0, OP-Addon
+  will create a circuit, as soon as there is an incoming stream from any 
+  application.
+
+3. Testing and user mode (section TESTING):
+
+  In a very basic configuration, OP-Addon will simply create the configured
+  number of circuits, and wait for incoming streams from applications to attach
+  them. However, if a user only wants to measure latencies of circuits, without
+  using them for anonymizing any traffic, she can make use of 'testing_mode'.
+  When 'testing_mode' is set to 'yes', one can specify 'num_rtt_test' (int), as
+  the number of latency tests that should be performed on each successfully 
+  created circuit before actively closing it again. The mean value of the 
+  results of these measurings is written to a file, together with the setup
+  duration of the specific circuit. Further 'num_records' specifies the total
+  number of circuits that is to be tested, before stopping the actual 
+  application. 'Testing_mode' is not useful for transporting user traffic, 
+  since circuits often dissapear unexpectedly, after 'num_rtt_tests' rounds
+  of measurings are finished.
+
+  If 'testing_mode' is set to 'no', we are in user mode. In user mode, OP-Addon
+  simply maintains the specified amount of circuits, created with the 
+  configured method at every time, waiting to handle incoming user streams. One
+  can optionally specify, that the circuits shall be 'pinged' with any 
+  configurable frequency (see 5.), so a ranked list of the circuits will be 
+  maintained. Incoming user streams are then attached to the first suitable 
+  circuit on this list. In both of the modes, OP-Addon will record statistics
+  on the created circuits to a file, including the median and mean setup 
+  duration, min/max values and the number of failures that occurred during 
+  circuit setups, as well as on already established circuits.
+
+4. Path selection configuration (sections NODE_SELECTION and GEOIP):
+  
+  ** NOTE THAT MAKING USE OF CUSTOMIZED METHODS OF PATH SELECTION FOR 
+     ANONYMIZING TCP-TRAFFIC MAY WEAKEN YOUR ANONYMITY AND SECURITY 
+     COMPARED TO THE METHODS USED IN THE DEFAULT IMPLEMENTATION! **
+
+  The employed method of path selection can be freely configured using the 
+  options from the sections NODE_SELECTION and GEOIP. Internally this is done
+  by combining arbitrary restrictions on the selection of single nodes, as well
+  as on complete paths. It is possible to choose from different node generators
+  and node/path restrictions by changing options in the configuration. Some of
+  the implemented restrictions make use of geolocation-data (using the geoip 
+  library for Python from http://www.maxmind.com) to consider the location of 
+  routers while choosing. This can be used to ensure a specific geographic 
+  (non-)diversity of the routers in a path. But it is also possible to apply 
+  any non-geographic restrictions, like explicitly specifying an exit node to 
+  be used, or the length of the generated paths, as an example of a path 
+  restriction. The following is a list of already implemented generators and 
+  restrictions that can be configured using the following options from the 
+  config-file:
+
+  General:
+    * pathlen: specify the number of hops to be used in paths 
+    * min_bw: specify a minimum bandwidth
+    * exit_node: specify an exit node explicitly by nickname or IDhex
+    * use_guards: choose guards on the entry positions (yes|no)
+ 
+  NodeGenerators:
+    * uniform: choose uniformly (yes|no), can be combined with
+    * ordered_exits: choose exits from an ordered list
+    * uniform=no: choose by weighting advertised bandwidths
+
+  GeoIP:    
+    * unique_country:       
+      - 'yes' will enforce distinct countries for all hops in a path 
+      - 'no' will put all hops in the same country, 
+      - comment out means do not care    
+    * entry_, middle_, exit_country: specify countries for positions
+    * max_crossings: 
+      - 1-n specifies the max number of continent hops in a single path
+      - 0 will choose all hops on different continents
+
+  To extend the path selection features or to add new restrictions to be 
+  applied to single nodes or complete paths, one can easily design and 
+  implement new Node or PathRestrictions using the existing interfaces from 
+  TorFlow.
+
+5. Latency measurements (section RTT):
+
+  It is possible to use OP-Addon to measure latencies of complete circuits, as
+  well as of single links between routers. By setting 'measure_circs' to 'yes',
+  OP-Addon will ping the complete circuits that are currently available with a 
+  frequency that is specified by 'frequency' (in seconds given as float).
+  Additionally an initial interval needs to be specified, that shall be waited,
+  before triggering the first ping. Since most of the circuit creations need 
+  less then 6 seconds, something like 10 seconds will be a safe value. Further
+  OP-Addon can be configured to close a circuit after n timeouts experienced
+  during measurement, where n is configured using 'timeout_limit'.
+
+  Measurements of RTTs are done by sending a relay connect cell, heading to a
+  destination that the exit policy of last router in the path will surely deny. 
+  This destination is set in 'ping_dummy_*' options and the values in 
+  pathrc.example are working well (127.0.0.1 and port 100). Since OP-Addon will
+  try to connect somewhere over Tor, also the Tor SOCKS-host and -port need to 
+  be specified (mostly 127.0.0.1 and 9050).
+
+6. Circuit creation based on measured latencies (section MODEL):
+
+  Because of the leaky-pipe circuit topology in Tor, it is possible to address
+  every hop in a created circuit as the exit node for a stream. OP-Addon 
+  implements a technique to measure and store RTTs of single links between 
+  routers, by using every hop in a path as the exit once. The subtracted 
+  results of this measurements are stored in a graph model that represents the
+  currently known subnet of a client. Setting 'network_model' to 'yes' will 
+  enable this measurings and optionally circuit creation from the network model.
+  The 'max_rtt' option lets users specify a maximum rtt value to choose only 
+  paths below this threshhold (seconds given as float, e.g. 0.5). The actual
+  selection from all suitable paths, that can currently be found in the model,
+  is done in a probabilistic way, weighting path proposals by their 
+  (summed up) latencies, combined with the minimum advertised bandwidth of the
+  routers in the path. Using another option ('min_proposals'), OP-Addon will
+  begin to create circuits from the model only if there are 'min_proposals'
+  suitable path proposals found, satisfying the configured rtt-threshhold.
+
+  If the intension is to grow a network model only, without creating circuits
+  based on it, set 'min_ratio' to 1. 'min_ratio' defines the ratio of available
+  circuits that were *not* created based on measurings. Setting it to 0.5 will
+  enforce that at most 50% of the circuits in the pool were created from the 
+  model at every time. This can ensure steady growing of the network model, 
+  while already choosing paths from it for building circuits. Setting 
+  'min_ratio' to 0 will lead to circuits created from the model only. This 
+  might be useful, if one wants to use a model, but not to extend or refresh it 
+  anymore. The regular circuits are created using the parameters defined in 
+  section 4.
+
+###############################################################################
+
+7. Implementing custom tests and measurings:
+
+  Anybody who wants/needs to implement his/her own custom measurings or 
+  performance tests, probably will need to write an event handler that extends
+  from the existing classes in PathSupport.py, similar to the PingHandler 
+  contained in OP-Addon. Therefore consider CircuitHandler, which is a class
+  that simply maintains a pool of circuits of configurable size, created with 
+  any given method depending on the configuration. The StreamHandler class is 
+  extending from the CircuitHandler and generally handles the attaching of 
+  streams to circuits from the pool. You therefore might want to extend from 
+  the StreamHandler for implementing your own tests.
+
+###############################################################################
+
+8. Instructions to get OP-Addon:
+
+  OP-Addon is part of the 'TorFlow' project that is hosted within the Tor
+  subversion. To check out the latest revision, 'cd' to the directory where
+  you want to install and type:
+
+    svn checkout https://tor-svn.freehaven.net/svn/torflow/trunk torflow
+
+###############################################################################
+
+9. Prerequisites and instructions to run OP-Addon:
+
+  Note that Linux is the only operating system, that OP-Addon was tested on 
+  until now, but it might also run on other platforms. Let me know, if you 
+  experimented with Windows or any other OS.
+
+  To run OP-Addon, you will need a Python interpreter and a running Tor client 
+  with the ControlPort set (control port authentication is currently not yet 
+  supported). Note that if you plan to measure latencies of single links 
+  between routers, you need to compile the Tor client from source and to apply
+  a patch that allows to measure the latency from the proxy to the first hop 
+  ('one-hop.diff' is included in the distribution in the '/tordiffs'-folder).
+ 
+  To make use of the complete functionalities, it is further necessary to 
+  install the following Python libraries:
+
+    - GeoIP     [http://www.maxmind.com/app/python]
+    - NetworkX  [https://networkx.lanl.gov]
+    - SocksiPy  [get it from http://socksipy.sourceforge.net/]
+
+  On Debian systems, the first two libraries can be installed by simply running:
+
+    apt-get install python-geoip networkx
+
+  To run OP-Addon, simply 'cd' to the installation directory and start the 
+  script by calling:
+
+    ./op-addon.py [config-file]
+
+  If no config-file is given, OP-Addon will try to find 'pathrc.example', 
+  which is included in the distribution. It is intended to be copied and 
+  modified though.
+
+###############################################################################
+(c) 2007 Johannes Renner (renner <AT> i4.informatik.rwth-aachen.de)