mirror of
https://gitlab.com/veloren/veloren.git
synced 2024-08-30 18:12:32 +00:00
03af9937cf
- completly switch to Bytes, even in api. speed up TCP by fak 2 - improve benchmarks - speed up mpsc metrics - gracefully handle shutdown by interpreting Ok(0) as tokio::tcpstream closed now. - fix hotloop in participants by adding `Some(n)` to fix endless handing. - fix closing bug by closing streams after `recv_mgr` is shutdown even if now shutdown is triggered locally. - fix prometheus - no longer throw when a `Stream` is dropped while participant still receives a msg for it. - fix the bandwith handling, TCP network send speed is up to 1.5GiB/s while recv is 150MiB/s - add documentation - tmp require rt-multi-threaded in client for tokio, to not fail cargo check this is prob stable, i tested over 1 hour. after that some optimisations in priomgr. and impl. propper bandwith. Speed is up to 2GB/s write and 150MB/s recv on a single core sync add documentation
68 lines
2.0 KiB
TOML
68 lines
2.0 KiB
TOML
[package]
|
|
name = "veloren-network"
|
|
version = "0.3.0"
|
|
authors = ["Marcel Märtens <marcel.cochem@googlemail.com>"]
|
|
edition = "2018"
|
|
|
|
# See more keys and their definitions at https://doc.rust-lang.org/cargo/reference/manifest.html
|
|
|
|
[features]
|
|
metrics = ["prometheus", "network-protocol/metrics"]
|
|
compression = ["lz-fear"]
|
|
|
|
default = ["metrics","compression"]
|
|
|
|
[dependencies]
|
|
|
|
network-protocol = { package = "veloren-network-protocol", path = "protocol" }
|
|
|
|
#serialisation
|
|
bincode = "1.3.1"
|
|
serde = { version = "1.0" }
|
|
#sending
|
|
crossbeam-channel = "0.5"
|
|
tokio = { version = "1.2", default-features = false, features = ["io-util", "macros", "rt", "net", "time"] }
|
|
tokio-stream = { version = "0.1.2", default-features = false }
|
|
#tracing and metrics
|
|
tracing = { version = "0.1", default-features = false, features = ["attributes"]}
|
|
prometheus = { version = "0.11", default-features = false, optional = true }
|
|
#async
|
|
futures-core = { version = "0.3", default-features = false }
|
|
futures-util = { version = "0.3", default-features = false, features = ["std"] }
|
|
async-channel = "1.5.1" #use for .close() channels
|
|
#mpsc channel registry
|
|
lazy_static = { version = "1.4", default-features = false }
|
|
rand = { version = "0.8" }
|
|
#stream flags
|
|
bitflags = "1.2.1"
|
|
lz-fear = { version = "0.1.1", optional = true }
|
|
# async traits
|
|
async-trait = "0.1.42"
|
|
bytes = "^1"
|
|
|
|
[dev-dependencies]
|
|
tracing-subscriber = { version = "0.2.3", default-features = false, features = ["env-filter", "fmt", "chrono", "ansi", "smallvec"] }
|
|
tokio = { version = "1.2", default-features = false, features = ["io-std", "fs", "rt-multi-thread"] }
|
|
futures-util = { version = "0.3", default-features = false, features = ["sink", "std"] }
|
|
clap = { version = "2.33", default-features = false }
|
|
shellexpand = "2.0.0"
|
|
serde = { version = "1.0", features = ["derive"] }
|
|
prometheus-hyper = "0.1.1"
|
|
criterion = { version = "0.3.4", features = ["default", "async_tokio"] }
|
|
|
|
[[bench]]
|
|
name = "speed"
|
|
harness = false
|
|
|
|
[[example]]
|
|
name = "fileshare"
|
|
|
|
[[example]]
|
|
name = "network-speed"
|
|
|
|
[[example]]
|
|
name = "chat"
|
|
|
|
[[example]]
|
|
name = "tcp_loadtest"
|