Commit graph

60 commits

Author SHA1 Message Date
Joakim Frostegård
8dfd49af0d cli helpers: in run function, take function as argument instead 2020-04-09 17:56:20 +02:00
Joakim Frostegård
ac52668a3d add crate cli_helpers with option and config parsing; use in aquatic
Putting cli functionality into its own crate will allow using it
from aquatic_bench and possibly other programs.
2020-04-09 16:55:40 +02:00
Joakim Frostegård
b457df26e3 aquatic annonunce handler: downgrade TorrentMap ref instead of new .get 2020-04-09 11:46:06 +02:00
Joakim Frostegård
32edee9bbb aquatic: add #[inline] to handle_readable_socket and handlers
Also update aquatic_bench comment with new bench results
2020-04-09 10:14:53 +02:00
Joakim Frostegård
2fd732efc6 aquatic: handlers: pass rng's as function arguments 2020-04-09 09:53:18 +02:00
Joakim Frostegård
bd16cdd709 aquatic: event loop: don't preallocate request/response vectors
It's better to just allocate when needed.
2020-04-09 09:34:39 +02:00
Joakim Frostegård
eddd353621 aquatic: when statistics.interval == 0, skip adding to stats atomics 2020-04-08 22:00:52 +02:00
Joakim Frostegård
5d2e4412b3 aquatic: create function in tasks.rs for statistics printing 2020-04-08 21:55:16 +02:00
Joakim Frostegård
58fbf8b7fe aquatic: add comments to many config fields 2020-04-08 21:50:23 +02:00
Joakim Frostegård
e3b29723a4 aquatic: when config recv_buffer_size is zero, don't set on socket 2020-04-08 21:45:25 +02:00
Joakim Frostegård
ad68dda9f5 aquatic: remove unnecessary fields from Peer; general clean up 2020-04-08 21:40:36 +02:00
Joakim Frostegård
31c8864658 aquatic: put max_scrape_torrents, max_response_peers in NetworkConfig 2020-04-08 21:32:05 +02:00
Joakim Frostegård
7239e9c047 aquatic: add and use NetworkConfig.peer_announce_interval 2020-04-08 21:30:57 +02:00
Joakim Frostegård
ca9d15c7a9 aquatic: move some fields from Config into new NetworkConfig 2020-04-08 21:27:12 +02:00
Joakim Frostegård
fa60eddcc4 aquatic: add CleaningConfig and StatisticsConfig to Config, use them 2020-04-08 21:22:45 +02:00
Joakim Frostegård
766606cc08 aquatic: announce handler: improve safety by small margin 2020-04-08 20:26:39 +02:00
Joakim Frostegård
789783cfe4 aquatic scrape handler: preallocate stats vec better 2020-04-08 20:23:31 +02:00
Joakim Frostegård
910accad31 announce handler: keep mutable access to torrent map less time 2020-04-08 13:32:18 +02:00
Joakim Frostegård
afa4ad318f aquatic stats print: fix newline printing issue 2020-04-08 11:56:30 +02:00
Joakim Frostegård
d896b6cf29 aquatic: print entire socket errors 2020-04-08 11:49:47 +02:00
Joakim Frostegård
52078ab1ad aquatic: print bandwidth used (based on bytes received and sent) 2020-04-08 11:43:18 +02:00
Joakim Frostegård
a865f4a1ae Add inline markers; simplify ip address conversion in request_from_bytes 2020-04-08 11:21:00 +02:00
Joakim Frostegård
a99688a5a2 benchmark byte conversion as well; bittorrent_udp: use buffers 2020-04-07 20:19:28 +02:00
Joakim Frostegård
51590a3d6c aquatic: print stats about number of peers per torrent 2020-04-07 16:57:34 +02:00
Joakim Frostegård
3b52acbd20 aquatic: print num requests per readable poll event 2020-04-07 15:36:19 +02:00
Joakim Frostegård
3ca22c9f3f aquatic: take into account how many peers announcing peer wants back 2020-04-07 14:50:33 +02:00
Joakim Frostegård
00513209ad aquatic: move socket creation into run_event_loop function 2020-04-07 14:19:02 +02:00
Joakim Frostegård
40583b32a3 aquatic server conf: increase default recv_buffer_size 2020-04-07 14:11:26 +02:00
Joakim Frostegård
f348013abb aquatic: create new socket for each worker thread, don't clone one
This is the point of SO_REUSEPORT.
2020-04-07 14:09:29 +02:00
Joakim Frostegård
74e3a51fbe aquatic: add and use Config.poll_event_capacity 2020-04-07 13:50:10 +02:00
Joakim Frostegård
f5700bfa18 aquatic: add and use num_threads setting 2020-04-07 13:37:07 +02:00
Joakim Frostegård
19277831c8 aquatic: count received requests / sent responses, print on interval 2020-04-07 13:22:28 +02:00
Joakim Frostegård
e4dfe2852c aquatic: add Config struct, use in code 2020-04-06 20:14:24 +02:00
Joakim Frostegård
ad1fa5b833 aquatic: run_event_loop: extract inner logic to own function 2020-04-06 19:58:00 +02:00
Joakim Frostegård
8426e8f3f7 on invalid requests, return error response; simplify Request type 2020-04-06 19:43:49 +02:00
Joakim Frostegård
51f2fcea45 turn of mimalloc security features, seemingly improving performance 2020-04-06 14:38:59 +02:00
Joakim Frostegård
165214018c Move benchmarks to seperate crate "aquatic_bench" 2020-04-06 12:49:54 +02:00
Joakim Frostegård
a627594c3a bench_handlers: parially extract setup portions for better profiling 2020-04-06 12:39:32 +02:00
Joakim Frostegård
8c57b3c4fe bench_handlers: run several test rounds, print averages 2020-04-06 03:43:06 +02:00
Joakim Frostegård
9d66a5e7d0 Use mimalloc instead of system allocator 2020-04-06 02:42:23 +02:00
Joakim Frostegård
d601025286 cleaning tasks: run shrink_to_fit on connection and torrent maps 2020-04-05 19:22:41 +02:00
Joakim Frostegård
70b5795818 bench: announce: test more requests 2020-04-05 18:29:28 +02:00
Joakim Frostegård
81cb03403d extract_response_peers: use faster method, improve testing 2020-04-05 18:29:08 +02:00
Joakim Frostegård
3c411bdbf4 announce handler: extract_response_peers: optimize 2020-04-05 16:37:35 +02:00
Joakim Frostegård
aa771f6a68 announce handler: init SmallRng outside of extract_response_peers 2020-04-05 16:31:02 +02:00
Joakim Frostegård
09cb31a4c9 rename handler.rs to handlers.rs 2020-04-05 16:23:51 +02:00
Joakim Frostegård
f3f196bd0d refactor benchmarks into one bin: bench_handlers 2020-04-05 16:17:47 +02:00
Joakim Frostegård
ab457aaf82 bench: add pareto plot util; use other shape in bench; refactor 2020-04-05 16:00:48 +02:00
Joakim Frostegård
5d462f808d bench_announce_scrape: use Vec::with_capacity for responses 2020-04-05 14:44:06 +02:00
Joakim Frostegård
9943e49d0e bench_announce_scrape: clean up a bit, fix logic error 2020-04-05 14:40:22 +02:00