pub struct LocalRuntime { /* 私有字段 */ }展开描述
本地 Tokio 运行时。
此运行时能够在不使用 LocalSet 的情况下驱动不是 Send + Sync 的任务,因此支持 spawn_local 而无需 LocalSet 上下文。
此运行时不能在线程之间移动,也不能从不同线程驱动。
此运行时与 LocalSet 不兼容。你不应尝试在 LocalRuntime 内驱动 LocalSet。
目前,此运行时支持一种风格,其内部与 current_thread 完全相同,只是与 spawn_local 相关的上述差异除外。
有关如何使用运行时的更多一般信息,请参阅 模块 文档。
实现§
源代码§impl LocalRuntime
impl LocalRuntime
源代码pub fn new() -> Result<LocalRuntime>
pub fn new() -> Result<LocalRuntime>
源代码pub fn handle(&self) -> &Handle
pub fn handle(&self) -> &Handle
返回运行时 spawner 的句柄。
返回的句柄可用于派生在此运行时上运行的任务,并且可以克隆以便将 Handle 移到其他线程。
由于该句柄可以发送到其他线程,因此它只能用于生成 Send 的任务。
在 LocalRuntime 的句柄上调用 Handle::block_on 容易出错。有关更多信息,请参阅 Handle::block_on 的文档。
§示例
use tokio::runtime::LocalRuntime;
let rt = LocalRuntime::new()
.unwrap();
let handle = rt.handle();
// Use the handle...源代码pub fn spawn_local<F>(&self, future: F) -> JoinHandle<F::Output> ⓘ
pub fn spawn_local<F>(&self, future: F) -> JoinHandle<F::Output> ⓘ
源代码pub fn spawn_blocking<F, R>(&self, func: F) -> JoinHandle<R> ⓘ
pub fn spawn_blocking<F, R>(&self, func: F) -> JoinHandle<R> ⓘ
在专用阻塞线程池中的某个线程上运行所提供的函数。
此函数将在另一个线程上运行。
有关更多信息,请参阅非本地运行时中的文档。
§示例
use tokio::runtime::LocalRuntime;
// 创建运行时
let rt = LocalRuntime::new().unwrap();
// Spawn a blocking function onto the runtime
rt.spawn_blocking(|| {
println!("now running on a worker thread");
});源代码pub fn block_on<F: Future>(&self, future: F) -> F::Output
pub fn block_on<F: Future>(&self, future: F) -> F::Output
在 Tokio 运行时上运行 future 直到完成。这是运行时的入口点。
有关更多信息,请参阅Runtime 上等价方法的文档。
§示例
use tokio::runtime::LocalRuntime;
// 创建运行时
let rt = LocalRuntime::new().unwrap();
// 执行 future,阻塞当前线程直到完成
rt.block_on(async {
println!("hello");
});源代码pub fn enter(&self) -> EnterGuard<'_>
pub fn enter(&self) -> EnterGuard<'_>
进入运行时上下文。
这允许你构造在创建时必须有执行器可用的类型,例如 Sleep 或 TcpStream。它还允许你调用诸如 tokio::spawn 之类的方法。
如果这是 LocalRuntime 的句柄,并且此函数是从创建运行时的同一线程调用的,那么你也能够调用 tokio::task::spawn_local。
§示例
use tokio::runtime::LocalRuntime;
use tokio::task::JoinHandle;
fn function_that_spawns(msg: String) -> JoinHandle<()> {
// Had we not used `rt.enter` below, this would panic.
tokio::spawn(async move {
println!("{}", msg);
})
}
fn main() {
let rt = LocalRuntime::new().unwrap();
let s = "Hello World!".to_string();
// By entering the context, we tie `tokio::spawn` to this executor.
let _guard = rt.enter();
let handle = function_that_spawns(s);
// Wait for the task before we end the test.
rt.block_on(handle).unwrap();
}源代码pub fn shutdown_timeout(self, duration: Duration)
pub fn shutdown_timeout(self, duration: Duration)
关闭运行时,并最多等待 duration 时间让所有已派生的工作停止。
请注意,如果超时到期,spawn_blocking 任务(且只有 spawn_blocking 任务)可能会被遗留。
有关更多详细信息,请参阅 结构体级文档。
§示例
use tokio::runtime::LocalRuntime;
use tokio::task;
use std::thread;
use std::time::Duration;
fn main() {
let runtime = LocalRuntime::new().unwrap();
runtime.block_on(async move {
task::spawn_blocking(move || {
thread::sleep(Duration::from_secs(10_000));
});
});
runtime.shutdown_timeout(Duration::from_millis(100));
}源代码pub fn shutdown_background(self)
pub fn shutdown_background(self)
关闭运行时,但不等待任何已派生的工作停止。
如果你想从另一个运行时中 drop 一个运行时,这会很有用。通常情况下,drop 一个运行时会无限期阻塞以等待已派生的阻塞任务完成,而异步上下文通常不允许这样做。通过调用 shutdown_background(),你可以从此类上下文中 drop 该运行时。
但请注意,因为我们不等待任何阻塞任务完成,这可能会导致资源泄漏(即任何阻塞任务仍在运行,直到它们返回。其他任务不会泄漏。
有关更多详细信息,请参阅 结构体级文档。
此函数等价于调用 shutdown_timeout(Duration::from_nanos(0))。
use tokio::runtime::LocalRuntime;
fn main() {
let runtime = LocalRuntime::new().unwrap();
runtime.block_on(async move {
let inner_runtime = LocalRuntime::new().unwrap();
// ...
inner_runtime.shutdown_background();
});
}源代码pub fn metrics(&self) -> RuntimeMetrics
pub fn metrics(&self) -> RuntimeMetrics
返回一个视图,可用于获取运行时性能的相关信息。