Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/xddxdd/route-chain
A small app to generate a long path in traceroute.
https://github.com/xddxdd/route-chain
Last synced: 3 months ago
JSON representation
A small app to generate a long path in traceroute.
- Host: GitHub
- URL: https://github.com/xddxdd/route-chain
- Owner: xddxdd
- License: unlicense
- Created: 2020-09-26T16:45:34.000Z (over 4 years ago)
- Default Branch: master
- Last Pushed: 2023-09-09T09:04:21.000Z (over 1 year ago)
- Last Synced: 2024-08-02T01:17:31.166Z (6 months ago)
- Language: C
- Homepage:
- Size: 56.6 KB
- Stars: 25
- Watchers: 5
- Forks: 1
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# Route Chain
A small app to generate a long path in traceroute.
## Usage
Run `make` to compile the app.
Optionally run `make install` to copy the app to `/usr/local/bin`.
Run `./route-chain 192.168.0.1/24 192.0.0.1/24 fc00::/64 fd00::/64`.
Any number of CIDRs is accepted as parameter.
Then run `traceroute 192.0.0.10` (or any address in the CIDRs above), and you will get:
```bash
traceroute to 192.0.0.10 (192.0.0.10), 30 hops max, 60 byte packets
1 192.0.0.2 0.105 ms 0.048 ms 0.039 ms
2 192.0.0.3 0.037 ms 0.036 ms 0.037 ms
3 192.0.0.4 0.036 ms 0.039 ms 0.039 ms
4 192.0.0.5 0.043 ms 0.037 ms 0.037 ms
5 192.0.0.6 0.036 ms 0.038 ms 0.049 ms
6 192.0.0.7 0.036 ms 0.060 ms 0.042 ms
7 192.0.0.8 0.038 ms 0.052 ms 0.041 ms
8 192.0.0.9 0.036 ms 0.037 ms 0.037 ms
9 192.0.0.10 0.037 ms 0.037 ms 0.036 ms
```## Internals
This app is made with speed and efficiency in mind. Specifically:
1. Only 2 memory copies per packet:
- One necessary copy from TUN device to app's memory region (for receiving)
- All packet processing happen without extra copies
- One necessary copy from app's memory region to TUN device (for sending)
2. Reserved space for IP/ICMP header for response packets
- Used for responding Destination Unreachable messages
- No need to move data around
3. Incremental checksum updates where possible
- Used for responding to Pings, only minimal updates needed
4. And it's multithreaded!
- CPU count automatically detected, multiqueue TUN/TAP used## License
Just do whatever you want.