Struct Server

Source
pub struct Server<A = DefaultAcceptor> { /* private fields */ }
Expand description

Represents an HTTP server with customization capabilities for handling incoming requests.

Implementations§

Source§

impl Server

Source

pub fn bind(addr: SocketAddr) -> Self

Constructs a server bound to the provided address.

Source

pub fn from_tcp(listener: TcpListener) -> Self

Constructs a server from an existing std::net::TcpListener.

Source§

impl<A> Server<A>

Source

pub fn acceptor<Acceptor>(self, acceptor: Acceptor) -> Server<Acceptor>

Replace the current acceptor with a new one.

Examples found in repository?
examples/rustls_session.rs (line 32)
17async fn main() {
18    let app = Router::new().route("/", get(handler));
19
20    let config = RustlsConfig::from_pem_file(
21        "examples/self-signed-certs/cert.pem",
22        "examples/self-signed-certs/key.pem",
23    )
24    .await
25    .unwrap();
26
27    let addr = SocketAddr::from(([127, 0, 0, 1], 3000));
28
29    println!("listening on {}", addr);
30
31    let acceptor = CustomAcceptor::new(RustlsAcceptor::new(config));
32    let server = hyper_server::bind(addr).acceptor(acceptor);
33
34    server.serve(app.into_make_service()).await.unwrap();
35}
Source

pub fn enable_proxy_protocol( self, parsing_timeout: Option<Duration>, ) -> Server<ProxyProtocolAcceptor<A>>

Enable proxy protocol header parsing. Note has to be called after initial acceptor is set.

Source

pub fn map<Acceptor, F>(self, acceptor: F) -> Server<Acceptor>
where F: FnOnce(A) -> Acceptor,

Maps the current acceptor to a new type.

Source

pub fn get_ref(&self) -> &A

Retrieves a reference to the server’s acceptor.

Source

pub fn get_mut(&mut self) -> &mut A

Retrieves a mutable reference to the server’s acceptor.

Source

pub fn handle(self, handle: Handle) -> Self

Provides the server with a handle for extra utilities.

Examples found in repository?
examples/shutdown.rs (line 24)
13async fn main() {
14    let app = Router::new().route("/", get(|| async { "Hello, world!" }));
15
16    let handle = Handle::new();
17
18    // Spawn a task to shutdown server.
19    tokio::spawn(shutdown(handle.clone()));
20
21    let addr = SocketAddr::from(([127, 0, 0, 1], 3000));
22    println!("listening on {}", addr);
23    hyper_server::bind(addr)
24        .handle(handle)
25        .serve(app.into_make_service())
26        .await
27        .unwrap();
28
29    println!("server is shut down");
30}
More examples
Hide additional examples
examples/graceful_shutdown.rs (line 27)
16async fn main() {
17    let app = Router::new().route("/", get(|| async { "Hello, world!" }));
18
19    let handle = Handle::new();
20
21    // Spawn a task to gracefully shutdown server.
22    tokio::spawn(graceful_shutdown(handle.clone()));
23
24    let addr = SocketAddr::from(([127, 0, 0, 1], 3000));
25    println!("listening on {}", addr);
26    hyper_server::bind(addr)
27        .handle(handle)
28        .serve(app.into_make_service())
29        .await
30        .unwrap();
31
32    println!("server is shut down");
33}
Source

pub fn http_config(self, config: HttpConfig) -> Self

Replaces the current HTTP configuration.

Examples found in repository?
examples/configure_http.rs (line 22)
10async fn main() {
11    let app = Router::new().route("/", get(|| async { "Hello, world!" }));
12
13    let config = HttpConfig::new()
14        .http1_only(true)
15        .http2_only(false)
16        .max_buf_size(8192)
17        .build();
18
19    let addr = SocketAddr::from(([127, 0, 0, 1], 3000));
20    println!("listening on {}", addr);
21    hyper_server::bind(addr)
22        .http_config(config)
23        .serve(app.into_make_service())
24        .await
25        .unwrap();
26}
Source

pub fn addr_incoming_config(self, config: AddrIncomingConfig) -> Self

Replaces the current incoming address configuration.

Examples found in repository?
examples/configure_addr_incoming.rs (line 25)
11async fn main() {
12    let app = Router::new().route("/", get(|| async { "Hello, world!" }));
13
14    let config = AddrIncomingConfig::new()
15        .tcp_nodelay(true)
16        .tcp_sleep_on_accept_errors(true)
17        .tcp_keepalive(Some(Duration::from_secs(32)))
18        .tcp_keepalive_interval(Some(Duration::from_secs(1)))
19        .tcp_keepalive_retries(Some(1))
20        .build();
21
22    let addr = SocketAddr::from(([127, 0, 0, 1], 3000));
23    println!("listening on {}", addr);
24    hyper_server::bind(addr)
25        .addr_incoming_config(config)
26        .serve(app.into_make_service())
27        .await
28        .unwrap();
29}
Source

pub async fn serve<M>(self, make_service: M) -> Result<()>

Serves the provided MakeService.

The MakeService is responsible for constructing services for each incoming connection. Each service is then used to handle requests from that specific connection.

§Arguments
  • make_service: A mutable reference to a type implementing the MakeServiceRef trait. This will be used to produce a service for each incoming connection.
§Errors

This method can return errors in the following scenarios:

  • When binding to an address fails.
  • If the make_service function encounters an error during its poll_ready call. It’s worth noting that this error scenario doesn’t typically occur with axum make services.
Examples found in repository?
examples/multiple_addresses.rs (line 22)
18async fn start_server(addr: SocketAddr) {
19    let app = Router::new().route("/", get(|| async { "Hello, world!" }));
20
21    hyper_server::bind(addr)
22        .serve(app.into_make_service())
23        .await
24        .unwrap();
25}
More examples
Hide additional examples
examples/remote_address.rs (line 16)
9async fn main() {
10    let app = Router::new()
11        .route("/", get(handler))
12        .into_make_service_with_connect_info::<SocketAddr>();
13
14    let addr = SocketAddr::from(([127, 0, 0, 1], 3000));
15
16    hyper_server::bind(addr).serve(app).await.unwrap();
17}
examples/http_and_https.rs (line 25)
19async fn http_server() {
20    let app = Router::new().route("/", get(http_handler));
21
22    let addr = SocketAddr::from(([127, 0, 0, 1], 3000));
23    println!("http listening on {}", addr);
24    hyper_server::bind(addr)
25        .serve(app.into_make_service())
26        .await
27        .unwrap();
28}
29
30async fn http_handler(uri: Uri) -> Redirect {
31    let uri = format!("https://127.0.0.1:3443{}", uri.path());
32
33    Redirect::temporary(&uri)
34}
35
36async fn https_server() {
37    let app = Router::new().route("/", get(|| async { "Hello, world!" }));
38
39    let config = RustlsConfig::from_pem_file(
40        "examples/self-signed-certs/cert.pem",
41        "examples/self-signed-certs/key.pem",
42    )
43    .await
44    .unwrap();
45
46    let addr = SocketAddr::from(([127, 0, 0, 1], 3443));
47    println!("https listening on {}", addr);
48    hyper_server::bind_rustls(addr, config)
49        .serve(app.into_make_service())
50        .await
51        .unwrap();
52}
examples/hello_world.rs (line 15)
9async fn main() {
10    let app = Router::new().route("/", get(|| async { "Hello, world!" }));
11
12    let addr = SocketAddr::from(([127, 0, 0, 1], 3000));
13    println!("listening on {}", addr);
14    hyper_server::bind(addr)
15        .serve(app.into_make_service())
16        .await
17        .unwrap();
18}
examples/from_std_listener.rs (line 16)
9async fn main() {
10    let app = Router::new().route("/", get(|| async { "Hello, world!" }));
11
12    let addr = SocketAddr::from(([127, 0, 0, 1], 3000));
13    let listener = TcpListener::bind(addr).unwrap();
14    println!("listening on {}", addr);
15    hyper_server::from_tcp(listener)
16        .serve(app.into_make_service())
17        .await
18        .unwrap();
19}
examples/configure_http.rs (line 23)
10async fn main() {
11    let app = Router::new().route("/", get(|| async { "Hello, world!" }));
12
13    let config = HttpConfig::new()
14        .http1_only(true)
15        .http2_only(false)
16        .max_buf_size(8192)
17        .build();
18
19    let addr = SocketAddr::from(([127, 0, 0, 1], 3000));
20    println!("listening on {}", addr);
21    hyper_server::bind(addr)
22        .http_config(config)
23        .serve(app.into_make_service())
24        .await
25        .unwrap();
26}

Trait Implementations§

Source§

impl<A: Debug> Debug for Server<A>

Source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more

Auto Trait Implementations§

§

impl<A> Freeze for Server<A>
where A: Freeze,

§

impl<A = DefaultAcceptor> !RefUnwindSafe for Server<A>

§

impl<A> Send for Server<A>
where A: Send,

§

impl<A> Sync for Server<A>
where A: Sync,

§

impl<A> Unpin for Server<A>
where A: Unpin,

§

impl<A = DefaultAcceptor> !UnwindSafe for Server<A>

Blanket Implementations§

Source§

impl<T> Any for T
where T: 'static + ?Sized,

Source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
Source§

impl<T> Borrow<T> for T
where T: ?Sized,

Source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
Source§

impl<T> BorrowMut<T> for T
where T: ?Sized,

Source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
Source§

impl<T> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

Source§

impl<T> Instrument for T

Source§

fn instrument(self, span: Span) -> Instrumented<Self>

Instruments this type with the provided Span, returning an Instrumented wrapper. Read more
Source§

fn in_current_span(self) -> Instrumented<Self>

Instruments this type with the current Span, returning an Instrumented wrapper. Read more
Source§

impl<T, U> Into<U> for T
where U: From<T>,

Source§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

Source§

impl<T, U> TryFrom<U> for T
where U: Into<T>,

Source§

type Error = Infallible

The type returned in the event of a conversion error.
Source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
Source§

impl<T, U> TryInto<U> for T
where U: TryFrom<T>,

Source§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
Source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.
Source§

impl<T> WithSubscriber for T

Source§

fn with_subscriber<S>(self, subscriber: S) -> WithDispatch<Self>
where S: Into<Dispatch>,

Attaches the provided Subscriber to this type, returning a WithDispatch wrapper. Read more
Source§

fn with_current_subscriber(self) -> WithDispatch<Self>

Attaches the current default Subscriber to this type, returning a WithDispatch wrapper. Read more