A tool that detects at which hop in a traceroute path an IXP fabric has been crossed.
traIXroute is a tool that detects if and where a traceroute path crosses an IXP fabric. It uses multiple criteria to verify IXP crossings in the light of replies from third-party interfaces or inaccuracies in the available data about IP addresses assigned to IXPs. These discrepancies mislead simple heuristics based solely on the IP address prefixes allocated to IXPs. The detection uses data from PeeringDB, Packet Clearing House and RouteViews. In addition, traIXroute uses in the background the standard traceroute tool or the scamper tool, which implements the Paris traceroute technique to deal with inaccurate paths due to load balancers . It is open source under GPLv3.
The heuristics used by traIXroute and their evaluation are described in the following paper:
- G. Nomikos, X. Dimitropoulos. “traIXroute: Detecting IXPs in traceroute paths”. In Proceedings of the Passive and Active Measurements Conference (PAM‘16) 31 March - 1 April 2016, Heraklion, Greece.
- G. Nomikos, X. Dimitropoulos. “Detecting IXPs in Traceroute Paths Using traIXroute”. RIPE Labs, 3 Aug 2016.
traIXroute enhances for the first time its features interoperating with the Remote Peering Jedi tool. For now, only data for DE-CIX (Frankfurt), Any2 (Los Angeles), AMS-IX, France-IX, LINX and MSK-IX are included.
The program has been tested on Linux and Mac OS X. Detailed installation instructions can be found in the INSTALL file in the repository. You can install all the necessary packages running:
The latest version is available on pypi, the Python Package Index:
$ pip3 install traixroute $ scamper-install (To enable probes using scamper) $ traixroute (To build the configuration files in the home directory) $ traixroute --help
It is also possible to download the latest archive from github:
$ curl -L https://github.com/gnomikos/traIXroute/archive/v2.3.tar.gz | tar zx $ sh traIXroute-2.3/setup/install.sh $ ./traIXroute-2.3/bin/traixroute
If using git:
$ git clone https://github.com/gnomikos/traIXroute.git $ sh traIXroute/setup/install.sh $ ./traIXroute/bin/traixroute
In case you run Mac OS X, ensure you have installed the Xcode command line developer tools before. To install run:
$ xcode-select --install
A software update popup window will appear. You need to install only the command line developer tools by clicking the “Install” button and then agree to the Terms of Service. This process will download and install the Command Line Tools package.
If you have problems, please contact George Nomikos (gnomikos [at] ics.forth.gr).
- Python 3 — traIXroute requires Python 3.5 or greater.
- Scamper — A tool provided by CAIDA for probing the Internet in parallel, so that bulk data can be collected in a timely fashion.
- Traceroute — A diagnostic tool for measuring Internet paths and their per hop delay.
- Click here for other dependencies.
Documentation can be found here. The documentation covers the available command line options, how to extend or overwrite the data from PeeringDB and the Packet Clearing House with user-provided data, how to customize or extend traIXroute detection rules, and a diagram of its modules.
The source code of traIXroute is released under the GNU General Public License, version 3. A copy can be found in the LICENSE file.
Copyright © traIXroute, 2016.
The research that led to traIXroute was supported by the European Research Council (ERC) Grant 338402 - The NetVolution Project (www.netvolution.eu).
|||Augustin, B., Friedman, T. and Teixeira, R., “Multipath tracing with Paris traceroute.” In End-to-End Monitoring Techniques and Services, 2007. Workshop on, pp. 1-8. IEEE, 2007.|
Release history Release notifications
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
|Filename, size & hash SHA256 hash help||File type||Python version||Upload date|
|traixroute-2.3-py3-none-any.whl (3.4 MB) Copy SHA256 hash SHA256||Wheel||py3|
|traixroute-2.3.tar.gz (3.2 MB) Copy SHA256 hash SHA256||Source||None|