4个版本

0.1.2 2024年6月17日
0.1.1 2024年3月4日
0.1.1-beta.12023年11月17日
0.1.0 2023年10月7日

#2178 in 异步

Download history 8/week @ 2024-04-14 13/week @ 2024-04-21 119/week @ 2024-04-28 17/week @ 2024-05-05 25/week @ 2024-05-12 33/week @ 2024-05-19 25/week @ 2024-05-26 61/week @ 2024-06-02 31/week @ 2024-06-09 177/week @ 2024-06-16 30/week @ 2024-06-23 5/week @ 2024-06-30 7/week @ 2024-07-07 16/week @ 2024-07-14 18/week @ 2024-07-21 24/week @ 2024-07-28

每月下载量 65次
9 个crate中(直接使用6个) 使用

MIT 许可证

11KB
192

Compio

MIT licensed crates.io docs.rs Check Test Telegram

基于IOCP/io_uring/polling的每个核心的Rust运行时。名称来源于“基于完成I/O”。这个crate受到了monoio的启发。

为什么不使用Tokio呢?

Tokio是一个优秀的通用异步运行时。然而,它是基于poll的,甚至在Windows上使用了未记录的API。我们希望有一些新的高级API来执行IOCP/io_uring。

tokio-uring不同,这个运行时不基于Tokio。这主要是因为在mio中没有控制IOCP的公共API,而且在mio达到1.0之前,tokio不会公开控制mio的API。

为什么不使用monoio/tokio-uring/glommio呢?

它们不支持Windows。

快速入门

compio作为依赖项添加

compio = { version = "0.10.0", features = ["macros"] }

然后我们可以使用高级API来执行文件系统和网络I/O。

use compio::{fs::File, io::AsyncReadAtExt};

#[compio::main]
async fn main() {
    let file = File::open("Cargo.toml").await.unwrap();
    let (read, buffer) = file.read_to_end_at(Vec::with_capacity(1024), 0).await.unwrap();
    assert_eq!(read, buffer.len());
    let buffer = String::from_utf8(buffer).unwrap();
    println!("{}", buffer);
}

您也可以手动控制低级驱动程序。请参阅仓库中的driver示例。

贡献

您可以在任何级别为Compio做出贡献。无论您是刚开始接触Rust还是经验丰富的专家,我们都可以使用您的帮助。如果您对Compio有任何疑问,请随时加入我们的Telegram群组。在贡献之前,请查阅我们的贡献指南

依赖项

~1.3–2MB
~41K SLoC