Crates.io | may_minihttp |
lib.rs | may_minihttp |
version | 0.1.11 |
source | src |
created_at | 2024-02-21 01:59:14.210664 |
updated_at | 2024-09-22 09:07:27.092335 |
description | Mini http server that implemented on top of [may](https://github.com/Xudong-Huang/may) |
homepage | https://github.com/Xudong-Huang/may_minihttp.git |
repository | https://github.com/Xudong-Huang/may_minihttp.git |
max_upload_size | |
id | 1147478 |
size | 83,712 |
Mini http server that implemented on top of may
This crate is ported from tokio_minihttp.
But with much ease of use, you can call MAY
block APIs directly in your service.
First, add this to your Cargo.toml
:
[dependencies]
may_minihttp = "0.1"
Then just simply implement your http service
extern crate may_minihttp;
use std::io;
use may_minihttp::{HttpServer, HttpService, Request, Response};
#[derive(Clone)]
struct HelloWorld;
impl HttpService for HelloWorld {
fn call(&mut self, _req: Request, res: &mut Response) -> io::Result<()> {
res.body("Hello, world!");
Ok(())
}
}
// Start the server in `main`.
fn main() {
let server = HttpServer(HelloWorld).start("0.0.0.0:8080").unwrap();
server.join().unwrap();
}
Tested with only one working thread on my laptop
Both with the following command to start the server.
$ cargo run --example=hello-world --release
tokio_minihttp
$ wrk http://127.0.0.1:8080 -d 10 -t 1 -c 200
Running 10s test @ http://127.0.0.1:8080
1 threads and 200 connections
Thread Stats Avg Stdev Max +/- Stdev
Latency 1.98ms 284.06us 12.53ms 98.92%
Req/Sec 101.64k 1.76k 103.69k 91.00%
1011679 requests in 10.05s, 99.38MB read
Requests/sec: 100650.94
Transfer/sec: 9.89MB
may_minihttp
$ wrk http://127.0.0.1:8080 -d 10 -t 1 -c 200
Running 10s test @ http://127.0.0.1:8080
1 threads and 200 connections
Thread Stats Avg Stdev Max +/- Stdev
Latency 1.70ms 812.42us 20.17ms 97.94%
Req/Sec 117.65k 7.52k 123.40k 88.00%
1171118 requests in 10.08s, 115.04MB read
Requests/sec: 116181.73
Transfer/sec: 11.41MB
One of the fastest web frameworks available according to the TechEmpower Framework Benchmark.
This project is licensed under either of
at your option.