本人是刚开始阅读rust的tokio源码不久,想把自己的的一些理解写下来,如果有什么不对的地方欢迎指出。
tokio是rust的异步库,其主要的逻辑在runtime里,就是我们通常说的运行时。在运行时里,我们可以执行异步函数。
看tokio源码的时候,在tokio项目下src/runtime/mod.rs 文件我们可以看到下面一段话:
//! Unlike other Rust programs, asynchronous applications require runtime //! support. In particular, the following runtime services are necessary: //! //! * An **I/O event loop**, called the driver, which drives I/O resources and dispatches I/O events to tasks that depend on them. //! * A **scheduler** to execute [tasks] that use these I/O resources. //! * A **timer** for scheduling work to run after a set period of time.
这段话的大概意思就是,不同其他rust项目,异步应用需要运行时支持,而运行时需要驱动(driver), 调度器(scheduler) 和 计时器(timer) 这个三个组件支持。
- driver: 可用来管理IO资源和给执行的task分发他们所需要的IO
- scheduler: 调度器,可以使用IO资源执行tasks
- timer: 记录任务执行时间 <