Build Status Build status Current Crates.io Version Document License

MAY

Rust Stackfull Coroutine Library.

May is a high performance stackfull 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 extern crate may;

use may::coroutine; 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() { coroutine::spawn(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 comparation 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 ```

Notices

License

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