An orchestrator for distributed IP tracing
Project description
🌬️ Zeph
Zeph is a reinforcement learning based algorithm for selecting prefixes to probe based on previous measurements in order to maximize the number of nodes and links discovered. Zeph can be used on top of the Iris platform.
🚀 Quickstart
Zeph has a command line interface to configure and run the algorithm.
First, install the Zeph package:
pip install dioptra-zeph
Zeph takes as input a list of /24 (IPv4) or /64 (IPv6) prefixes:
# prefixes.txt
8.8.8.0/24
2001:4860:4860::/64
To start a measurement from scratch:
zeph prefixes.txt
To start from a previous measurement:
zeph prefixes.txt UUID
Zeph relies on iris-client and pych-client for communicating with Iris and ClickHouse. See their respective documentation to know how to specify the credentials.
✨ Generate prefix lists from BGP RIBs
You can create an exhaustive list of /24 prefixes from a BGP RIB dump:
pyasn_util_download.py --latest
# Connecting to ftp://archive.routeviews.org
# Finding most recent archive in /bgpdata/2022.05/RIBS ...
# Downloading ftp://archive.routeviews.org//bgpdata/2022.05/RIBS/rib.20220524.1000.bz2
# 100%, 659KB/s
# Download complete.
zeph-bgp-convert --print-progress rib.20220524.1000.bz2 prefixes.txt
📚 Publications
@article{10.1145/3523230.3523232,
author = {Gouel, Matthieu and Vermeulen, Kevin and Mouchet, Maxime and Rohrer, Justin P. and Fourmaux, Olivier and Friedman, Timur},
title = {Zeph & Iris Map the Internet: A Resilient Reinforcement Learning Approach to Distributed IP Route Tracing},
year = {2022},
issue_date = {January 2022},
publisher = {Association for Computing Machinery},
address = {New York, NY, USA},
volume = {52},
number = {1},
issn = {0146-4833},
url = {https://doi.org/10.1145/3523230.3523232},
doi = {10.1145/3523230.3523232},
journal = {SIGCOMM Comput. Commun. Rev.},
month = {mar},
pages = {2–9},
numpages = {8},
keywords = {active internet measurements, internet topology}
}
🧑💻 Authors
Iris is developed and maintained by the Dioptra group at Sorbonne Université in Paris, France.
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
File details
Details for the file dioptra_zeph-1.3.0.tar.gz
.
File metadata
- Download URL: dioptra_zeph-1.3.0.tar.gz
- Upload date:
- Size: 11.5 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/4.0.2 CPython/3.11.6
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | bbb6f2a8443e02bb2559648e3a0b29628566a3d1eab9a8fea453c7c00f347f40 |
|
MD5 | 04208c71194bb7087c678e8f3dedbdcb |
|
BLAKE2b-256 | a01dfd6046c6b9d14b4d1341f1d6f2277ec5c224a16a054e33650fbc8e6f3b92 |
File details
Details for the file dioptra_zeph-1.3.0-py3-none-any.whl
.
File metadata
- Download URL: dioptra_zeph-1.3.0-py3-none-any.whl
- Upload date:
- Size: 15.3 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/4.0.2 CPython/3.11.6
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | a4c74b0806fdb129d9597f43f243c2f7fb917729f7e34aff1ae0e185966c9aa8 |
|
MD5 | 505918b1eb38ccf947e650ddef09ff1e |
|
BLAKE2b-256 | a699e8633a924bd12175e6652658a564806022adbaca9eaafce5717b97a48b19 |