Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

refactor(perf): use libp2p-request-response #3646

Merged
merged 41 commits into from
May 28, 2023
Merged
Show file tree
Hide file tree
Changes from 37 commits
Commits
Show all changes
41 commits
Select commit Hold shift + click to select a range
e4afb8e
Have at most one stream in-flight
mxinden Mar 20, 2023
1c5384d
Implement single connection requests per second benchmark
mxinden Mar 20, 2023
2bc92fe
Use `colored` crate for log output
mxinden Mar 20, 2023
9dffaf7
Implement connections per second benchmark
mxinden Mar 20, 2023
bff4279
Add ping latency benchmark
mxinden Mar 20, 2023
dfa1e57
Fix units
mxinden Mar 20, 2023
ed6dd3f
Print benchmark output according to json schema
mxinden Mar 24, 2023
6778a6f
Merge branch 'master' of https://github.com/libp2p/rust-libp2p into perf
mxinden Apr 5, 2023
bebb7e7
Update data schema
mxinden Apr 8, 2023
a01ff2c
Introduce custom benchmark
mxinden Apr 11, 2023
8cef2d6
Fix forwarding upload and download bytes
mxinden Apr 11, 2023
095ceb6
Wait for remote to close read side
mxinden Apr 11, 2023
0019366
Provide option to pass secret key seed
mxinden Apr 12, 2023
2a68630
Follow go implementation entry point convention
mxinden Apr 12, 2023
d3c3ad4
Change to tokio runtime
thomaseizinger Apr 13, 2023
285a175
Fix DNS imports
mxinden Apr 13, 2023
cc064f5
Use nodelay don't reuse port
mxinden Apr 14, 2023
4cde5b5
Increase read buffer
mxinden Apr 14, 2023
3aec5e5
Set TCP nodelay on server
mxinden Apr 14, 2023
cef0f23
Merge server and client into single entry point
mxinden Apr 24, 2023
66a28b3
Run n times on same connection
mxinden Apr 24, 2023
da5cc28
Fix info log
mxinden Apr 24, 2023
90964ff
Use request-response and adjust to new flags
mxinden May 1, 2023
e984af6
Debug log level
mxinden May 1, 2023
59dd784
request-response closes for us
mxinden May 1, 2023
9d49f26
Bump timeouts
mxinden May 1, 2023
613e684
Log on info
mxinden May 1, 2023
f515473
Fix compilation
mxinden May 1, 2023
59d8f3f
Remove n-times flag
mxinden May 11, 2023
1d18761
Merge branch 'master' of https://github.com/libp2p/rust-libp2p into perf
mxinden May 11, 2023
08e4276
Provide ip:port
mxinden May 12, 2023
647d76c
Remove schema
mxinden May 19, 2023
c4c84e7
Differentiate by up- and download time
mxinden May 19, 2023
fa6886c
Remove Benchmark trait
mxinden May 19, 2023
488f007
Use serde camelCase
mxinden May 19, 2023
ec52392
Log with millis to debug RTT
mxinden May 26, 2023
15e3642
Merge branch 'master' of https://github.com/libp2p/rust-libp2p into perf
mxinden May 26, 2023
e343e5a
Use `swarm` to contruct server
mxinden May 28, 2023
539eb3d
Fix clippy
mxinden May 28, 2023
095f920
Merge branch 'master' of https://github.com/libp2p/rust-libp2p into perf
mxinden May 28, 2023
6bb18a5
Use tls instead of noise
mxinden May 28, 2023
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
6 changes: 5 additions & 1 deletion Cargo.lock

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

14 changes: 9 additions & 5 deletions protocols/perf/Cargo.toml
Original file line number Diff line number Diff line change
Expand Up @@ -12,21 +12,25 @@ categories = ["network-programming", "asynchronous"]

[dependencies]
anyhow = "1"
async-std = { version = "1.9.0", features = ["attributes"] }
async-trait = "0.1"
clap = { version = "4.3.0", features = ["derive"] }
env_logger = "0.10.0"
futures = "0.3.28"
instant = "0.1.12"
libp2p-core = { workspace = true }
libp2p-dns = { workspace = true, features = ["async-std"] }
libp2p-dns = { workspace = true, features = ["tokio"] }
libp2p-identity = { workspace = true }
libp2p-noise = { workspace = true }
libp2p-quic = { workspace = true, features = ["async-std"] }
libp2p-swarm = { workspace = true, features = ["macros", "async-std"] }
libp2p-tcp = { workspace = true, features = ["async-io"] }
libp2p-quic = { workspace = true, features = ["tokio"] }
libp2p-request-response = { workspace = true }
libp2p-swarm = { workspace = true, features = ["macros", "tokio"] }
libp2p-tcp = { workspace = true, features = ["tokio"] }
libp2p-yamux = { workspace = true }
log = "0.4"
serde = { version = "1.0", features = ["derive"] }
serde_json = "1.0"
thiserror = "1.0"
tokio = { version = "1.27.0", features = ["full"] }
void = "1"

[dev-dependencies]
Expand Down
10 changes: 3 additions & 7 deletions protocols/perf/Dockerfile
Original file line number Diff line number Diff line change
Expand Up @@ -9,14 +9,10 @@ RUN --mount=type=cache,target=./target \
cargo build --release --package libp2p-perf

RUN --mount=type=cache,target=./target \
mv ./target/release/perf-server /usr/local/bin/perf-server

RUN --mount=type=cache,target=./target \
mv ./target/release/perf-client /usr/local/bin/perf-client
mv ./target/release/perf /usr/local/bin/perf

FROM debian:bullseye-slim

COPY --from=builder /usr/local/bin/perf-server /usr/local/bin/perf-server
COPY --from=builder /usr/local/bin/perf-client /usr/local/bin/perf-client
COPY --from=builder /usr/local/bin/perf /app/perf

ENTRYPOINT [ "perf-server"]
ENTRYPOINT [ "/app/perf" ]
140 changes: 0 additions & 140 deletions protocols/perf/src/bin/perf-client.rs

This file was deleted.

128 changes: 0 additions & 128 deletions protocols/perf/src/bin/perf-server.rs

This file was deleted.

Loading