11 releases (5 breaking)

new 0.6.3 Dec 1, 2024
0.6.2 Nov 25, 2024
0.5.1 Sep 24, 2024
0.4.0 Jun 17, 2024
0.2.0-beta.2 Nov 18, 2023

#1975 in Asynchronous

Download history 641/week @ 2024-08-18 643/week @ 2024-08-25 585/week @ 2024-09-01 478/week @ 2024-09-08 508/week @ 2024-09-15 1557/week @ 2024-09-22 706/week @ 2024-09-29 530/week @ 2024-10-06 767/week @ 2024-10-13 570/week @ 2024-10-20 622/week @ 2024-10-27 905/week @ 2024-11-03 1118/week @ 2024-11-10 1469/week @ 2024-11-17 925/week @ 2024-11-24 1326/week @ 2024-12-01

4,855 downloads per month
Used in 24 crates (11 directly)

MIT license

295KB
7K SLoC


Compio

MIT licensed crates.io docs.rs Check Test Telegram

A thread-per-core Rust runtime with IOCP/io_uring/polling. The name comes from "completion-based IO". This crate is inspired by monoio.

Why not Tokio?

Tokio is a great generic-purpose async runtime. However, it is poll-based, and even uses undocumented APIs on Windows. We would like some new high-level APIs to perform IOCP/io_uring.

Unlike tokio-uring, this runtime isn't Tokio-based. This is mainly because that no public APIs to control IOCP in mio, and tokio won't expose APIs to control mio before mio reaches 1.0.

Why not monoio/tokio-uring/glommio?

They don't support Windows.

Quick start

Add compio as dependency:

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

Then we can use high level APIs to perform filesystem & net IO.

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);
}

You can also control the low-level driver manually. See driver example of the repo.

Contributing

There are opportunities to contribute to Compio at any level. It doesn't matter if you are just getting started with Rust or are the most weathered expert, we can use your help. If you have any question about Compio, feel free to join our telegram group. Before contributing, please checkout our contributing guide.

Dependencies

~1–14MB
~191K SLoC