Crate async_global_executor
source ·Expand description
A global executor built on top of async-executor and async_io
The global executor is lazily spawned on first use. It spawns as many threads
as the number of cpus by default. You can override this using the
ASYNC_GLOBAL_EXECUTOR_THREADS
environment variable.
Examples
// spawn a task on the multi-threaded executor
let task1 = async_global_executor::spawn(async {
1 + 2
});
// spawn a task on the local executor (same thread)
let task2 = async_global_executor::spawn_local(async {
3 + 4
});
let task = future::zip(task1, task2);
// run the executor
async_global_executor::block_on(async {
assert_eq!(task.await, (3, 7));
});
Structs
- Configuration to init the thread pool for the multi-threaded global executor.
- A spawned task.
Functions
- Runs the global and the local executor on the current thread
- Init the global executor, spawning as many threads as the number or cpus or the value specified by the
ASYNC_GLOBAL_EXECUTOR_THREADS
environment variable if specified. - Init the global executor, spawning as many threads as specified or the value specified by the specified environment variable.
- Spawns a task onto the multi-threaded global executor.
- Runs blocking code on a thread pool.
- Spawns a task onto the local executor.
- Spawn more executor threads, up to configured max value.
- Stop the current executor thread, if we exceed the configured min value
- Stop one of the executor threads, down to configured min value