#tokio #applications #run-time #io #reliable #reserved

tokio-compat-03

类似于 tokio-compat-02,但预留供以后使用

1 个不稳定版本

0.0.0 2020 年 10 月 26 日

#21#reserved

MIT 许可证

2KB

Tokio

一个用于使用 Rust 编程语言编写可靠、异步和精简应用程序的运行时。它是

  • 快速:Tokio 的零成本抽象为您提供裸机性能。

  • 可靠:Tokio 利用 Rust 的所有权、类型系统和并发模型来减少错误并确保线程安全。

  • 可扩展:Tokio 脚印最小,并能自然地处理背压和取消。

Crates.io MIT licensed Build Status Discord chat

网站 | 指南 | API 文档 | 聊天

概述

Tokio 是一个基于 Rust 编程语言编写异步应用程序的事件驱动、非阻塞 I/O 平台。在较高层面,它提供了一些主要组件

  • 一个基于多线程和任务窃取的调度器。
  • 一个由操作系统的事件队列(epoll、kqueue、IOCP 等)支持的反应器。
  • 异步 TCP 和 UDP 套接字。

这些组件为构建异步应用程序提供了必要的运行时组件。

示例

使用 Tokio 的一个基本的 TCP 反射服务器。

确保你在 Cargo.toml 中激活了 tokio crate 的全部功能

[dependencies]
tokio = { version = "1.38.0", features = ["full"] }

然后,在你的 main.rs 中

use tokio::net::TcpListener;
use tokio::io::{AsyncReadExt, AsyncWriteExt};

#[tokio::main]
async fn main() -> Result<(), Box<dyn std::error::Error>> {
    let listener = TcpListener::bind("127.0.0.1:8080").await?;

    loop {
        let (mut socket, _) = listener.accept().await?;

        tokio::spawn(async move {
            let mut buf = [0; 1024];

            // In a loop, read data from the socket and write the data back.
            loop {
                let n = match socket.read(&mut buf).await {
                    // socket closed
                    Ok(n) if n == 0 => return,
                    Ok(n) => n,
                    Err(e) => {
                        eprintln!("failed to read from socket; err = {:?}", e);
                        return;
                    }
                };

                // Write the data back
                if let Err(e) = socket.write_all(&buf[0..n]).await {
                    eprintln!("failed to write to socket; err = {:?}", e);
                    return;
                }
            }
        });
    }
}

更多示例可以在 这里 找到。对于更大的“现实世界”示例,请参阅 mini-redis 仓库。

要查看可以启用的功能标志列表,请参阅我们的 文档

获取帮助

首先,看看你的问题是否可以在 指南API 文档 中找到。如果没有找到答案,在 Tokio Discord 服务器 中有一个活跃的社区。我们很高兴尝试回答你的问题。你还可以在 讨论页面 上提出你的问题。

贡献

🎈 感谢你帮助改进这个项目!我们非常高兴有你!我们有一个 贡献指南,帮助你参与 Tokio 项目。

除了这个存储库中的crate之外,Tokio项目还维护了几个其他库,包括

  • axum:一个专注于人体工程学和模块化的Web应用框架。

  • hyper:Rust的快速且正确的HTTP/1.1和HTTP/2实现。

  • tonic:一个专注于高性能、互操作性和灵活性的gRPC over HTTP/2实现。

  • warp:一个超级简单、可组合的,以高速为目标的Web服务器框架。

  • tower:用于构建健壮的网络客户端和服务器的一系列模块化和可重用组件的库。

  • tracing(原tokio-trace):一个用于应用级跟踪和异步感知诊断的框架。

  • mio:一个在OS I/O API之上的低级别、跨平台抽象,为tokio提供动力。

  • bytes:用于处理字节的实用工具,包括高效的字节缓冲区。

  • loom:一个用于并发Rust代码的测试工具。

变更日志

托库存储库包含多个crate。每个crate都有自己的变更日志。

支持的Rust版本

托库将保持至少6个月的滚动MSRV(最低支持Rust版本)政策。当提高MSRV时,新的Rust版本必须至少发布6个月前。当前的MSRV是1.63。

请注意,MSRV不会自动提高,并且仅在作为次要版本发布的一部分时才会提高。以下是过去次要版本中MSRV的历史记录

  • 1.30至现在 - Rust 1.63
  • 1.27至1.29 - Rust 1.56
  • 1.17至1.26 - Rust 1.49
  • 1.15至1.16 - Rust 1.46
  • 1.0至1.14 - Rust 1.45

请注意,尽管我们试图避免Tokio的依赖关系间接提高MSRV的情况,但我们不保证这种情况不会发生。但是,每个次要版本都将有一组与该次要版本的MSRV兼容的依赖项版本。

发布计划

托库不遵循固定的发布计划,但我们通常每月发布一到两个新的次要版本。我们需要进行修补程序发布以修复错误。

错误修补策略

为了制作带有错误修复的修补程序发布,我们已经将某些次要版本指定为LTS(长期支持)版本。每当一个错误需要带有错误修复的修补程序发布时,它将被回退并作为每个LTS次要版本的新修补程序发布。我们当前的LTS版本是

  • 1.32.x - 直到2024年9月LTS发布。(MSRV 1.63)
  • 1.36.x - 直到2025年3月LTS发布。(MSRV 1.63)

每个LTS版本将继续至少一年内接收回退修复。如果您希望在自己的项目中使用固定的次要版本,我们建议您使用LTS版本。

要使用固定的次要版本,您可以使用波浪号指定版本。例如,要指定您希望使用最新的 1.32.x 补丁版本,可以使用以下依赖项指定

tokio = { version = "~1.32", features = [...] }

以前的 LTS 版本

  • 1.8.x - LTS 版本,至 2022 年 2 月。
  • 1.14.x - LTS 版本,至 2022 年 6 月。
  • 1.18.x - LTS 版本,至 2023 年 6 月。
  • 1.20.x - LTS 版本,至 2023 年 9 月。
  • 1.25.x - LTS 版本,至 2024 年 3 月。

许可证

本项目采用 MIT 许可证

贡献

除非您明确声明,否则您提交给 Tokio 的任何有意包含在内的贡献,都应按 MIT 许可,不附加任何额外条款或条件。

无运行时依赖