76 releases

new 0.4.13 Feb 16, 2025
0.4.11 Aug 29, 2024
0.4.7 Jun 21, 2024
0.4.4 Jan 18, 2024
0.1.0 Oct 26, 2020

#891 in Asynchronous

Download history 481/week @ 2024-10-28 511/week @ 2024-11-04 310/week @ 2024-11-11 418/week @ 2024-11-18 474/week @ 2024-11-25 339/week @ 2024-12-02 475/week @ 2024-12-09 343/week @ 2024-12-16 360/week @ 2024-12-23 236/week @ 2024-12-30 323/week @ 2025-01-06 302/week @ 2025-01-13 403/week @ 2025-01-20 216/week @ 2025-01-27 637/week @ 2025-02-03 428/week @ 2025-02-10

1,751 downloads per month
Used in 39 crates (31 directly)

ISC license

23KB
354 lines

smolscale

A global, auto-scaling scheduler for [async-task] using work-balancing.

What? Another executor?

smolscale is a work-balancing executor based on [async-task], designed to be a drop-in replacement to smol and async-global-executor. It is designed based on the idea that work-stealing, the usual approach in async executors like async-executor and tokio, is not the right algorithm for scheduling huge amounts of tiny, interdependent work units, which are what message-passing futures end up being. Instead, smolscale uses work-balancing, an approach also found in Erlang, where a global "balancer" thread periodically balances work between workers, but workers do not attempt to steal tasks from each other. This avoids the extremely frequent stealing attempts that work-stealing schedulers generate when applied to async tasks.

smolscale's approach especially excels in two circumstances:

  • When the CPU cores are not fully loaded: Traditional work stealing optimizes for the case where most workers have work to do, which is only the case in fully-loaded scenarios. When workers often wake up and go back to sleep, however, a lot of CPU time is wasted stealing work. smolscale will instead drastically reduce CPU usage in these circumstances --- a async-executor app that takes 80% of CPU time may now take only 20%. Although this does not improve fully-loaded throughput, it significantly reduces power consumption and does increase throughput in circumstances where multiple thread pools compete for CPU time.
  • When a lot of message-passing is happening: Message-passing workloads often involve tasks quickly waking up and going back to sleep. In a work-stealing scheduler, this again floods the scheduler with stealing requests. smolscale can significantly improve throughput, especially compared to executors like async-executor that do not special-case message passing.

License: ISC

Dependencies

~11–40MB
~608K SLoC