Build Status Build status Current Crates.io Version Document

MAY

Rust Stackful Coroutine Library.

May is a high performance stackful coroutine library that can be thought of rust version goroutine. You can use it easily to design and develop massive concurrent programs in Rust.

Features

Usage

```rust /// a naive echo server

[macro_use]

extern crate may;

use may::net::TcpListener; use std::io::{Read, Write};

fn main() { let listener = TcpListener::bind("127.0.0.1:8000").unwrap(); while let Ok((mut stream, )) = listener.accept() { go!(move || { let mut buf = vec![0; 1024 * 16]; // alloc in heap! while let Ok(n) = stream.read(&mut buf) { if n == 0 { break; } stream.writeall(&buf[0..n]).unwrap(); } }); } }

```

More examples

CPU heavy load examples

IO heavy Bound examples

Performance

Just a simple comparison with the Rust echo server implemented in tokio to get a sense about May

Machine Specs:

Echo server client:

tokio echo server

run the server by default with 2 threads in another terminal sh $ cd tokio-core $ cargo run --example=echo-threads --release

```sh $ target/release/examples/echo_client -t 2 -c 100 -l 100 -a 127.0.0.1:8080 ==================Benchmarking: 127.0.0.1:8080================== 100 clients, running 100 bytes, 10 sec.

Speed: 315698 request/sec, 315698 response/sec, 30829 kb/sec Requests: 3156989 Responses: 3156989 target/release/examples/echo_client -t 2 -c 100 -l 100 -a 127.0.0.1:8080 1.89s user 13.46s system 152% cpu 10.035 total ```

may echo server

run the server by default with 2 threads in another terminal sh $ cd may $ cargo run --example=echo --release -- -p 8000 -t 2

```sh $ target/release/examples/echo_client -t 2 -c 100 -l 100 -a 127.0.0.1:8000 ==================Benchmarking: 127.0.0.1:8000================== 100 clients, running 100 bytes, 10 sec.

Speed: 419094 request/sec, 419094 response/sec, 40927 kb/sec Requests: 4190944 Responses: 4190944 target/release/examples/echo_client -t 2 -c 100 -l 100 -a 127.0.0.1:8000 2.60s user 16.96s system 195% cpu 10.029 total ```

Caveat

There is a detailed doc that describes MAY's main restrictions.

There are four things you should avoid when writing coroutines: * Don't call thread blocking APIs. It will hurt the performance.

How to tune stack size

If you need to tune the coroutine stack size, please read here

Notices

License

May is licensed under either of the following, at your option: