#http #https #web #server

axum-server

High level server designed to be used with axum framework

12 unstable releases (3 breaking)

new 0.3.3 Nov 25, 2021
0.3.2 Nov 17, 2021
0.2.6 Nov 3, 2021
0.2.5 Oct 5, 2021
0.0.0 Aug 20, 2021

#179 in Network programming

Download history 27/week @ 2021-08-17 448/week @ 2021-08-24 648/week @ 2021-08-31 1030/week @ 2021-09-07 1452/week @ 2021-09-14 1201/week @ 2021-09-21 1429/week @ 2021-09-28 1999/week @ 2021-10-05 1448/week @ 2021-10-12 1938/week @ 2021-10-19 2255/week @ 2021-10-26 1886/week @ 2021-11-02 825/week @ 2021-11-09 662/week @ 2021-11-16 757/week @ 2021-11-23

4,585 downloads per month
Used in hrpc

MIT license

51KB
1K SLoC

License Crates.io Docs - Master Docs - Stable

axum-server

axum-server is a hyper server implementation designed to be used with axum framework.

This project is maintained by community independently from axum.

Features

  • HTTP/1 and HTTP/2
  • HTTPS through rustls.
  • High performance through hyper.
  • Using tower make service API.
  • Very good axum compatibility. Likely to work with future axum releases.

Usage Example

A simple hello world application can be served like:

use axum::{routing::get, Router};
use std::net::SocketAddr;

#[tokio::main]
async fn main() {
    let app = Router::new().route("/", get(|| async { "Hello, world!" }));

    let addr = SocketAddr::from(([127, 0, 0, 1], 3000));
    println!("listening on {}", addr);
    axum_server::bind(addr)
        .serve(app.into_make_service())
        .await
        .unwrap();
}

You can find more examples here.

Minimum Supported Rust Version

axum-server's MSRV is 1.49.

Safety

This crate uses #![forbid(unsafe_code)] to ensure everything is implemented in 100% safe Rust.

License

This project is licensed under the MIT license.

Dependencies

~6–9.5MB
~188K SLoC