/ws-tool

High perform & easy to use websocket client/server

Primary LanguageRustApache License 2.0Apache-2.0

ws-tool

An easy to use websocket client/server toolkit, supporting blocking/async IO.

feature matrix

IO type split proxy(auth) tls buffered stream deflate use as client use as server
blocking 🚧wip
async 🚧wip

It's tested by autobaha test suit. see examples/autobahn-client

pretty good performance

Roughly compare with EchoSever example, tungstenite, both async and blocking version of ws-tool echo serve win in single client(more then 10) with 1m payload size.

My test machine is i9-12900k and 32GB, 3200MHz ddr4, use uWebSocket provided client example as perf client

server ws-tool ws-tool async uWebSocket tungstenite
msg/sec 5150± 5150± 3200± 2850±

usage

Every example can be run with

cargo run --example <example_name> --all-features

command.

See examples/server for building a websocket echo server with self signed certs.

examples/echo demonstrate how to connect to a wss server.

examples/binance show how to connect via proxy

run autobaha testsuit

start test server

./script/start_autobahn_server.sh

run test on other terminal

cargo run --example autobahn_client --all-features

report files should be under test_reports dir.

autobahn test report

click to expand report

report

TODO

  • add proxy auth config
  • support custom https proxy cert
  • split client into writer & reader
  • add buffered stream

REF