2021-12-08 15:43:59 +01:00
# mknet
2022-09-14 18:22:46 +02:00
mknet is a tool to simulate various network topologies
locally thanks to network namespaces and traffic control (tc).
2021-12-08 15:43:59 +01:00
2022-09-14 18:22:46 +02:00
## Prepare your environment
2021-12-08 15:43:59 +01:00
2022-09-16 15:43:58 +02:00
Get the repository:
2021-12-08 15:43:59 +01:00
```bash
2022-09-14 18:22:46 +02:00
git clone https://git.deuxfleurs.fr/Deuxfleurs/mknet.git
cd mknet
2021-12-08 15:43:59 +01:00
```
2022-09-16 15:43:58 +02:00
Run our configuration script:
2021-12-08 15:43:59 +01:00
2022-09-14 18:22:46 +02:00
```bash
2022-09-16 15:43:58 +02:00
./prepare.py
2022-09-14 18:22:46 +02:00
```
2021-12-08 15:43:59 +01:00
2022-09-16 15:43:58 +02:00
Now, you are ready to launch an experiment:
2021-12-08 15:43:59 +01:00
```bash
2022-09-14 18:22:46 +02:00
sudo -i
2022-09-16 15:43:58 +02:00
source .venv/bin/activate
./mknet scenario ./topo/50ms.yml ./scenarios/garage-s3lat garage-v0.8
2022-09-14 18:22:46 +02:00
```
2021-12-08 15:43:59 +01:00
2022-09-19 14:16:08 +02:00
If a script crash, you must manually destroy the topology:
```
./mknet destroy
```
2022-09-14 18:35:09 +02:00
2022-09-15 17:12:21 +02:00
## Topologies
2021-12-08 15:43:59 +01:00
2022-09-15 17:12:21 +02:00
All topologies:
2022-09-19 12:37:25 +02:00
- `./topo/dc.yml` - A 3 node topology connected with a 1Gbit/s link and a 1ms latency
2022-09-15 17:12:21 +02:00
- `./topo/with-vdsl.yml` - A topology mixing datacenters with fast internal connectivity and an isolated VDSL node
- `./topo/50ms.yml` - An artifical topology simulating nodes with high bandwidth but with a fixed 50ms latency, useful to quantify the impact of latency on a distributed software
- `./topo/multi-dc.yml` - Simulate 3 DC interconnected with 50ms latency WAN network and close to zero latency inside the DC
2022-09-19 12:44:52 +02:00
- `./topo/{1,5,10,50,100}mbps.yml` - Simulate 3 nodes interconnected with a bandwidth bottleneck.
2022-09-15 17:12:21 +02:00
Feel free to write new topologies!
## Scenarios
2022-09-15 17:33:42 +02:00
All scenarios:
- `./scenarios/garage-s3lat [garage-v0.7|garage-v0.8]` - Run s3lat on Garage
2022-09-19 12:37:25 +02:00
- `./scenarios/garage-concurrent [garage-v0.7|garage-v0.8]` - Run s3concurrent on Garage
2022-09-15 17:33:42 +02:00
- `./scenarios/garage-warp [garage-v0.7|garage-v0.8] [default|fast]` - Run warp on Garage. 2 flavors are available: fast and default.
*Scenarios take optional flavors as input that modulate their behavioir. Passing them is not mandatory,
a default one will be selected for you.*
2022-09-15 17:12:21 +02:00
How to run them:
2022-09-14 18:22:46 +02:00
```bash
2022-09-15 17:34:35 +02:00
./mknet scenario < topology > < scenario > [flavors...]
./mknet scenario ./topo/50ms.yml ./scenarios/garage-s3lat garage-v0.8
2021-12-08 15:43:59 +01:00
```
2022-09-15 17:12:21 +02:00
How to write good scenarios:
- If a scenario can be run with multiple different parameters, write one scenario with multiple flavors
- If the logic ran is different, write a new scenario
- A scenario code must remain short and looks like a DSL, abstract the logic in the `fragments/` module
2022-09-14 18:22:46 +02:00
## Manual usage
2021-12-08 15:43:59 +01:00
2022-09-14 18:22:46 +02:00
```bash
./mknet create ./topo/with-vdsl.yml
./mknet run-all ./scenarios/garage-manual
./mknet run dc1:dc1s1 /tmp/mknet-bin/garage* -c /tmp/mknet-store/garage/dc1/dc1s1/garage.toml status
./mknet run-all ./scenarios/clean
./mknet destroy
2021-12-08 15:43:59 +01:00