zap :zap:

GitHub issues GitHub stars Crates.io Crates.io

The mission of zap is, to deliver a basic, but fast rust web framework.

Documentation

About

This code is based on tokio's minihttp project, so a big thanks to them. (source)

How to use

Add the following to your Cargo.toml: toml [dependencies] zap = "0.0.3"

Speed

So zap is not only fast, it is wapping 2.9 times faster than iron, which is based on hyper. Benchmarks below:

Benchmark Code

Iron

This code had been taken from the ironframework.io webpage.

```rust extern crate iron;

use iron::prelude::*; use iron::status;

fn main() { fn helloworld(: &mut Request) -> IronResult { Ok(Response::with((status::Ok, "Hello World!"))) }

Iron::new(hello_world).http("localhost:3000").unwrap();

} ```

Zap

This example can be run, by:

$ git clone https://github.com/oldaniel/zap && cd zap $ cargo run --example hello-world --release

```rust extern crate zap;

use std::io::Error as ZapError; use zap::prelude::*;

struct HelloWorld;

impl Handler for HelloWorld { type Request = Request; type Response = Response; type Error = ZapError; type Future = ZapResult;

fn call(&self, _: Request) -> ZapResult {
    let mut resp = Response::new();

    resp.body("Hello World!");

    resp.ok()
}

}

fn main() { let addr = "0.0.0.0:8080".parse().unwrap(); let mut server = Server::new(Http, addr); server.threads(8); server.serve(|| Ok(HelloWorld)); } ```

Benchmark Results

The benchmark results have been computed with this command: wrk -t16 -c500 -d10s http://127.0.0.1:8080 --latency

Technical details about the server:

Detailed results: in the wiki.

Iron

[...] Requests/sec: 307581.17 Transfer/sec: 33.44MB

Zap

[...] Requests/sec: 900745.44 Transfer/sec: 43.81MB

Todo

Some things we still need to make:

Credits & License

A project by Daniel Oltmanns. Other amazing contributors here.

GitHub license