[][src]Struct hyper::server::Server

pub struct Server<I, S, E = Exec> { /* fields omitted */ }

A listening HTTP server that accepts connections in both HTTP1 and HTTP2 by default.

Server is a Future mapping a bound listener with a set of service handlers. It is built using the Builder, and the future completes when the server has been shutdown. It should be run by an Executor.

Methods

impl<I> Server<I, ()>[src]

pub fn builder(incoming: I) -> Builder<I>[src]

Starts a Builder with the provided incoming stream.

impl Server<AddrIncoming, ()>[src]

pub fn bind(addr: &SocketAddr) -> Builder<AddrIncoming>[src]

Binds to the provided address, and returns a Builder.

Panics

This method will panic if binding to the address fails. For a method to bind to an address and return a Result, see Server::try_bind.

pub fn try_bind(addr: &SocketAddr) -> Result<Builder<AddrIncoming>>[src]

Tries to bind to the provided address, and returns a Builder.

pub fn from_tcp(
    listener: StdTcpListener
) -> Result<Builder<AddrIncoming>, Error>
[src]

Create a new instance from a std::net::TcpListener instance.

impl<S> Server<AddrIncoming, S>[src]

pub fn local_addr(&self) -> SocketAddr[src]

Returns the local address that this server is bound to.

impl<I, S, E, B> Server<I, S, E> where
    I: Stream,
    I::Error: Into<Box<dyn StdError + Send + Sync>>,
    I::Item: AsyncRead + AsyncWrite + Send + 'static,
    S: MakeServiceRef<I::Item, ReqBody = Body, ResBody = B>,
    S::Error: Into<Box<dyn StdError + Send + Sync>>,
    S::Service: 'static,
    B: Payload,
    E: H2Exec<<S::Service as Service>::Future, B>,
    E: NewSvcExec<I::Item, S::Future, S::Service, E, GracefulWatcher>, 
[src]

pub fn with_graceful_shutdown<F>(self, signal: F) -> Graceful<I, S, F, E> where
    F: Future<Item = ()>, 
[src]

Prepares a server to handle graceful shutdown when the provided future completes.

Example


// Make a server from the previous examples...
let server = Server::bind(&([127, 0, 0, 1], 3000).into())
    .serve(new_service);

// Prepare some signal for when the server should start
// shutting down...
let (tx, rx) = futures::sync::oneshot::channel::<()>();

let graceful = server
    .with_graceful_shutdown(rx)
    .map_err(|err| eprintln!("server error: {}", err));

// Spawn `server` onto an Executor...
hyper::rt::spawn(graceful);

// And later, trigger the signal by calling `tx.send(())`.
let _ = tx.send(());

Trait Implementations

impl<I: Debug, S: Debug> Debug for Server<I, S>[src]

impl<I, S, B, E> Future for Server<I, S, E> where
    I: Stream,
    I::Error: Into<Box<dyn StdError + Send + Sync>>,
    I::Item: AsyncRead + AsyncWrite + Send + 'static,
    S: MakeServiceRef<I::Item, ReqBody = Body, ResBody = B>,
    S::Error: Into<Box<dyn StdError + Send + Sync>>,
    S::Service: 'static,
    B: Payload,
    E: H2Exec<<S::Service as Service>::Future, B>,
    E: NewSvcExec<I::Item, S::Future, S::Service, E, NoopWatcher>, 
[src]

type Item = ()

The type of value that this future will resolved with if it is successful. Read more

type Error = Error

The type of error that this future will resolve with if it fails in a normal fashion. Read more

Auto Trait Implementations

impl<I, S, E> Send for Server<I, S, E> where
    E: Send,
    I: Send,
    S: Send

impl<I, S, E> Unpin for Server<I, S, E> where
    E: Unpin,
    I: Unpin,
    S: Unpin

impl<I, S, E> Sync for Server<I, S, E> where
    E: Sync,
    I: Sync,
    S: Sync

impl<I, S, E> UnwindSafe for Server<I, S, E> where
    E: UnwindSafe,
    I: UnwindSafe,
    S: UnwindSafe

impl<I, S, E> RefUnwindSafe for Server<I, S, E> where
    E: RefUnwindSafe,
    I: RefUnwindSafe,
    S: RefUnwindSafe

Blanket Implementations

impl<T, U> Into<U> for T where
    U: From<T>, 
[src]

impl<T> From<T> for T[src]

impl<T, U> TryFrom<U> for T where
    U: Into<T>, 
[src]

type Error = Infallible

The type returned in the event of a conversion error.

impl<T, U> TryInto<U> for T where
    U: TryFrom<T>, 
[src]

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

The type returned in the event of a conversion error.

impl<T> BorrowMut<T> for T where
    T: ?Sized
[src]

impl<T> Borrow<T> for T where
    T: ?Sized
[src]

impl<T> Any for T where
    T: 'static + ?Sized
[src]

impl<F> IntoFuture for F where
    F: Future
[src]

type Future = F

The future that this type can be converted into.

type Item = <F as Future>::Item

The item that the future may resolve with.

type Error = <F as Future>::Error

The error that the future may resolve with.

impl<T> FutureExt for T where
    T: Future + ?Sized
[src]