-
-
Notifications
You must be signed in to change notification settings - Fork 561
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
feat(rust): add
tcp-test
tool to measure portal properties
- Loading branch information
1 parent
aa35abe
commit 87ef083
Showing
10 changed files
with
772 additions
and
9 deletions.
There are no files selected for viewing
Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.
Oops, something went wrong.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,14 @@ | ||
[package] | ||
name = "tcp-test" | ||
version = "0.1.0" | ||
edition = "2021" | ||
license = "Apache-2.0" | ||
publish = false | ||
readme = "README.md" | ||
|
||
[dependencies] | ||
clap = { version = "4", features = ["derive", "cargo", "env"] } | ||
rcgen = { version = "0.13", features = ["pem", "aws_lc_rs"], default-features = false } | ||
rustls = { version = "0.23" } | ||
tokio = { version = "1", features = ["full"] } | ||
tokio-rustls = { version = "0.26", features = ["aws-lc-rs"] } |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,89 @@ | ||
This tool is useful to test the portal capabilities and operates as a **generic** TCP client and server. | ||
It also implements (unsafe) TLS, which is useful for performance comparison. | ||
|
||
# Deployment | ||
|
||
Can be easily deployed via ssh using the `deploy` script: | ||
```bash | ||
$ ./deploy user@host | ||
``` | ||
|
||
# Actions | ||
|
||
# latency | ||
Measures the latency of a TCP packets to a given host and port. | ||
It must be used with an echo server. | ||
|
||
```bash | ||
$ tcp-test echo 1234 | ||
Listening on 0.0.0.0:1234 | ||
|
||
$ tcp-test latency 127.0.0.1:1234 | ||
Connection + First RTT: 0ms 440us, Second RTT: 0ms 143us | ||
Connection + First RTT: 0ms 192us, Second RTT: 0ms 160us | ||
Connection + First RTT: 0ms 276us, Second RTT: 0ms 162us | ||
Connection + First RTT: 0ms 326us, Second RTT: 0ms 155us | ||
Connection + First RTT: 0ms 227us, Second RTT: 0ms 172us | ||
Connection + First RTT: 0ms 250us, Second RTT: 0ms 111us | ||
Connection + First RTT: 0ms 461us, Second RTT: 0ms 122us | ||
Connection + First RTT: 0ms 326us, Second RTT: 0ms 116us | ||
Connection + First RTT: 0ms 320us, Second RTT: 0ms 104us | ||
Connection + First RTT: 0ms 270us, Second RTT: 0ms 101us | ||
Average - Connection + First RTT: 0ms 309us, Second RTT: 0ms 135us | ||
``` | ||
|
||
# flood | ||
Floods a given host and port with connections until it fails or reaches the provided maximum. | ||
It's meant to measure the maximum number of connections a portal can handle. | ||
It must be used with an echo server. | ||
|
||
Example: | ||
```bash | ||
$ tcp-test echo 1234 | ||
Listening on 0.0.0.0:1234 | ||
|
||
$ tcp-test flood 127.0.0.1:1234 | ||
Failed to connect: Os { code: 49, kind: AddrNotAvailable, message: "Can't assign requested address" } | ||
Flooded 16344 connections | ||
Pinging each... | ||
All connections succeeded | ||
``` | ||
# throughput | ||
Measures the throughput of a TCP connection to a given host and port. | ||
It can be used to measure the throughput of a portal, especially to compare a portal against TLS. | ||
Can be used in conjunction with a null server for results similar to `iperf3`, but echo can also be | ||
used for a full bandwidth test. | ||
```bash | ||
$ tcp-test null 1234 | ||
Listening on 0.0.0.0:1234 | ||
|
||
$ tcp-test throughput 127.0.0.1:1234 | ||
Outgoing Throughput: 70.44 Gbps | ||
Outgoing Throughput: 75.12 Gbps | ||
Outgoing Throughput: 75.44 Gbps | ||
Outgoing Throughput: 78.43 Gbps | ||
Outgoing Throughput: 71.89 Gbps | ||
Outgoing Throughput: 69.80 Gbps | ||
Outgoing Throughput: 75.13 Gbps | ||
^C | ||
``` | ||
## echo | ||
It starts a TCP server that listens to on a given port and **echoes back** any data it receives. | ||
It's meant to be used in conjunction with the other actions. | ||
```bash | ||
$ tcp-test echo 1234 | ||
Listening on 0.0.0.0:1234 | ||
``` | ||
# null | ||
It starts a TCP server that listens to on a given port and **discards** any data it receives. | ||
It's meant to be used in conjunction with the other actions. | ||
```bash | ||
$ tcp-test null 1234 | ||
Listening on 0.0.0.0:1234 | ||
``` |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,40 @@ | ||
#!/bin/bash | ||
|
||
# This scripts deploys a tcp test client and an ockam client to a remote machine accessible via ssh. | ||
|
||
set -e | ||
|
||
cd "$(dirname "$0")"/../../ | ||
|
||
if [ "$#" -lt 1 ]; then | ||
echo "usage: $0 <[username@]host> [-p port]" | ||
exit 1 | ||
fi | ||
|
||
SSH_ENDPOINT="$1" | ||
SSH_PORT=22 | ||
|
||
if [ "$#" -eq 3 ] && [ "$2" == "-p" ]; then | ||
SSH_PORT="$3" | ||
fi | ||
|
||
function ssh { | ||
/usr/bin/env ssh -q -o StrictHostKeyChecking=no -o UserKnownHostsFile=/dev/null -o LogLevel=QUIET -o ConnectTimeout=5 "${SSH_ENDPOINT}" -p ${SSH_PORT} "$@" | ||
} | ||
|
||
function scp { | ||
/usr/bin/env scp -q -o StrictHostKeyChecking=no -o UserKnownHostsFile=/dev/null -o LogLevel=QUIET -o ConnectTimeout=5 -P ${SSH_PORT} "$@" | ||
} | ||
|
||
TARGET_ARCHITECTURE=$(ssh uname -m) | ||
|
||
# always use cross-compilation to avoid reliance on new and unsupported glibc versions | ||
DOCKER_DEFAULT_PLATFORM=linux/amd64 cross build --bin=tcp-test --bin=ockam -F aws-lc --release --target "${TARGET_ARCHITECTURE}-unknown-linux-gnu" | ||
echo "uploading..." | ||
|
||
scp \ | ||
"target/${TARGET_ARCHITECTURE}-unknown-linux-gnu/release/ockam" \ | ||
"target/${TARGET_ARCHITECTURE}-unknown-linux-gnu/release/tcp-test" \ | ||
"${SSH_ENDPOINT}:" | ||
|
||
ssh sudo mv ockam tcp-test /usr/local/bin/ |
Oops, something went wrong.