[−][src]Struct tokio::runtime::Builder
Builds Tokio Runtime with custom configuration values.
Methods can be chained in order to set the configuration values. The
Runtime is constructed by calling build
.
New instances of Builder
are obtained via Builder::new_multi_thread
or Builder::new_current_thread
.
See function level documentation for details on the various configuration settings.
Examples
use tokio::runtime::Builder; fn main() { // build runtime let runtime = Builder::new_multi_thread() .worker_threads(4) .thread_name("my-custom-name") .thread_stack_size(3 * 1024 * 1024) .build() .unwrap(); // use runtime ... }
Implementations
impl Builder
[src]
pub fn new_current_thread() -> Builder
[src]
Returns a new builder with the current thread scheduler selected.
Configuration methods can be chained on the return value.
To spawn non-Send
tasks on the resulting runtime, combine it with a
LocalSet
.
pub fn new_multi_thread() -> Builder
[src]
Returns a new builder with the multi thread scheduler selected.
Configuration methods can be chained on the return value.
pub fn enable_all(&mut self) -> &mut Selfⓘ
[src]
Enables both I/O and time drivers.
Doing this is a shorthand for calling enable_io
and enable_time
individually. If additional components are added to Tokio in the future,
enable_all
will include these future components.
Examples
use tokio::runtime; let rt = runtime::Builder::new_multi_thread() .enable_all() .build() .unwrap();
pub fn worker_threads(&mut self, val: usize) -> &mut Selfⓘ
[src]
Sets the number of worker threads the Runtime
will use.
This can be any number above 0 though it is advised to keep this value on the smaller side.
Default
The default value is the number of cores available to the system.
Panic
When using the current_thread
runtime this method will panic, since
those variants do not allow setting worker thread counts.
Examples
Multi threaded runtime with 4 threads
use tokio::runtime; // This will spawn a work-stealing runtime with 4 worker threads. let rt = runtime::Builder::new_multi_thread() .worker_threads(4) .build() .unwrap(); rt.spawn(async move {});
Current thread runtime (will only run on the current thread via Runtime::block_on
)
use tokio::runtime; // Create a runtime that _must_ be driven from a call // to `Runtime::block_on`. let rt = runtime::Builder::new_current_thread() .build() .unwrap(); // This will run the runtime and future on the current thread rt.block_on(async move {});
Panic
This will panic if val
is not larger than 0
.
pub fn max_blocking_threads(&mut self, val: usize) -> &mut Selfⓘ
[src]
Specifies the limit for additional threads spawned by the Runtime.
These threads are used for blocking operations like tasks spawned
through spawn_blocking
. Unlike the worker_threads
, they are not
always active and will exit if left idle for too long. You can change
this timeout duration with thread_keep_alive
.
The default value is 512.
Panic
This will panic if val
is not larger than 0
.
Upgrading from 0.x
In old versions max_threads
limited both blocking and worker threads, but the
current max_blocking_threads
does not include async worker threads in the count.
pub fn thread_name(&mut self, val: impl Into<String>) -> &mut Selfⓘ
[src]
Sets name of threads spawned by the Runtime
's thread pool.
The default name is "tokio-runtime-worker".
Examples
let rt = runtime::Builder::new_multi_thread() .thread_name("my-pool") .build();
pub fn thread_name_fn<F>(&mut self, f: F) -> &mut Selfⓘ where
F: Fn() -> String + Send + Sync + 'static,
[src]
F: Fn() -> String + Send + Sync + 'static,
Sets a function used to generate the name of threads spawned by the Runtime
's thread pool.
The default name fn is || "tokio-runtime-worker".into()
.
Examples
let rt = runtime::Builder::new_multi_thread() .thread_name_fn(|| { static ATOMIC_ID: AtomicUsize = AtomicUsize::new(0); let id = ATOMIC_ID.fetch_add(1, Ordering::SeqCst); format!("my-pool-{}", id) }) .build();
pub fn thread_stack_size(&mut self, val: usize) -> &mut Selfⓘ
[src]
Sets the stack size (in bytes) for worker threads.
The actual stack size may be greater than this value if the platform specifies minimal stack size.
The default stack size for spawned threads is 2 MiB, though this particular stack size is subject to change in the future.
Examples
let rt = runtime::Builder::new_multi_thread() .thread_stack_size(32 * 1024) .build();
pub fn on_thread_start<F>(&mut self, f: F) -> &mut Selfⓘ where
F: Fn() + Send + Sync + 'static,
[src]
F: Fn() + Send + Sync + 'static,
Executes function f
after each thread is started but before it starts
doing work.
This is intended for bookkeeping and monitoring use cases.
Examples
let runtime = runtime::Builder::new_multi_thread() .on_thread_start(|| { println!("thread started"); }) .build();
pub fn on_thread_stop<F>(&mut self, f: F) -> &mut Selfⓘ where
F: Fn() + Send + Sync + 'static,
[src]
F: Fn() + Send + Sync + 'static,
Executes function f
before each thread stops.
This is intended for bookkeeping and monitoring use cases.
Examples
let runtime = runtime::Builder::new_multi_thread() .on_thread_stop(|| { println!("thread stopping"); }) .build();
pub fn build(&mut self) -> Result<Runtime>
[src]
Creates the configured Runtime
.
The returned Runtime
instance is ready to spawn tasks.
Examples
use tokio::runtime::Builder; let rt = Builder::new_multi_thread().build().unwrap(); rt.block_on(async { println!("Hello from the Tokio runtime"); });
pub fn thread_keep_alive(&mut self, duration: Duration) -> &mut Selfⓘ
[src]
Sets a custom timeout for a thread in the blocking pool.
By default, the timeout for a thread is set to 10 seconds. This can be overriden using .thread_keep_alive().
Example
let rt = runtime::Builder::new_multi_thread() .thread_keep_alive(Duration::from_millis(100)) .build();
impl Builder
[src]
pub fn enable_io(&mut self) -> &mut Selfⓘ
[src]
Enables the I/O driver.
Doing this enables using net, process, signal, and some I/O types on the runtime.
Examples
use tokio::runtime; let rt = runtime::Builder::new_multi_thread() .enable_io() .build() .unwrap();
impl Builder
[src]
pub fn enable_time(&mut self) -> &mut Selfⓘ
[src]
Enables the time driver.
Doing this enables using tokio::time
on the runtime.
Examples
use tokio::runtime; let rt = runtime::Builder::new_multi_thread() .enable_time() .build() .unwrap();
Trait Implementations
Auto Trait Implementations
impl !RefUnwindSafe for Builder
[src]
impl Send for Builder
[src]
impl Sync for Builder
[src]
impl Unpin for Builder
[src]
impl !UnwindSafe for Builder
[src]
Blanket Implementations
impl<T> Any for T where
T: 'static + ?Sized,
[src]
T: 'static + ?Sized,
impl<T> Borrow<T> for T where
T: ?Sized,
[src]
T: ?Sized,
impl<T> BorrowMut<T> for T where
T: ?Sized,
[src]
T: ?Sized,
pub fn borrow_mut(&mut self) -> &mut Tⓘ
[src]
impl<T> From<T> for T
[src]
impl<T, U> Into<U> for T where
U: From<T>,
[src]
U: From<T>,
impl<T, U> TryFrom<U> for T where
U: Into<T>,
[src]
U: Into<T>,
type Error = Infallible
The type returned in the event of a conversion error.
pub fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>
[src]
impl<T, U> TryInto<U> for T where
U: TryFrom<T>,
[src]
U: TryFrom<T>,