#http #https #web #server

axum-server

High level server designed to be used with axum framework

23 releases

0.6.0 Dec 22, 2023
0.5.1 May 15, 2023
0.4.7 Mar 19, 2023
0.4.4 Nov 7, 2022
0.3.3 Nov 25, 2021

#1 in #hyper-server

Download history 32505/week @ 2023-11-07 36743/week @ 2023-11-14 32580/week @ 2023-11-21 35840/week @ 2023-11-28 34907/week @ 2023-12-05 32372/week @ 2023-12-12 27384/week @ 2023-12-19 17498/week @ 2023-12-26 35050/week @ 2024-01-02 52510/week @ 2024-01-09 58288/week @ 2024-01-16 59944/week @ 2024-01-23 72581/week @ 2024-01-30 66673/week @ 2024-02-06 68150/week @ 2024-02-13 66025/week @ 2024-02-20

284,347 downloads per month
Used in 58 crates (52 directly)

MIT license

81KB
1.5K SLoC

License Crates.io Docs

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.63.

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

~8–20MB
~267K SLoC