26 releases

0.7.2 Mar 14, 2025
0.7.1 Jul 31, 2024
0.6.0 Dec 22, 2023
0.5.1 May 15, 2023
0.3.3 Nov 25, 2021

#10 in Asynchronous

Download history 22577/week @ 2024-12-23 28325/week @ 2024-12-30 47050/week @ 2025-01-06 51082/week @ 2025-01-13 55634/week @ 2025-01-20 65999/week @ 2025-01-27 90483/week @ 2025-02-03 90563/week @ 2025-02-10 76885/week @ 2025-02-17 78276/week @ 2025-02-24 85919/week @ 2025-03-03 95832/week @ 2025-03-10 107991/week @ 2025-03-17 96680/week @ 2025-03-24 102604/week @ 2025-03-31 109759/week @ 2025-04-07

421,768 downloads per month
Used in 141 crates (111 directly)

MIT license

86KB
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.66.

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

~7–18MB
~249K SLoC