Struct TcpListener
struct TcpListener { ... }
A TCP socket server, listening for connections.
You can accept a new connection by using the accept
method.
A TcpListener can be turned into a Stream with TcpListenerStream.
Errors
Note that accepting a connection can lead to various errors and not all of them are necessarily fatal ‒ for example having too many open file descriptors or the other side closing the connection while it waits in an accept queue. These would terminate the stream if not handled in any way.
Examples
Using accept:
use tokio::net::TcpListener;
use std::io;
async fn process_socket<T>(socket: T) {
# drop(socket);
// do work with socket here
}
#[tokio::main]
async fn main() -> io::Result<()> {
let listener = TcpListener::bind("127.0.0.1:8080").await?;
loop {
let (socket, _) = listener.accept().await?;
process_socket(socket).await;
}
}
Implementations
impl TcpListener
async fn bind<A: ToSocketAddrs>(addr: A) -> Result<TcpListener>Creates a new
TcpListener, which will be bound to the specified address.The returned listener is ready for accepting connections.
Binding with a port number of 0 will request that the OS assigns a port to this listener. The port allocated can be queried via the
local_addrmethod.The address type can be any implementor of the
ToSocketAddrstrait. Ifaddryields multiple addresses, bind will be attempted with each of the addresses until one succeeds and returns the listener. If none of the addresses succeed in creating a listener, the error returned from the last attempt (the last address) is returned.This function sets the
SO_REUSEADDRoption on the socket.To configure the socket before binding, you can use the
TcpSockettype.Examples
use tokio::net::TcpListener; use std::io; #[tokio::main] async fn main() -> io::Result<()> { # if cfg!(miri) { return Ok(()); } // No `socket` in miri. let listener = TcpListener::bind("127.0.0.1:2345").await?; // use the listener # let _ = listener; Ok(()) }async fn accept(self: &Self) -> Result<(TcpStream, SocketAddr)>Accepts a new incoming connection from this listener.
This function will yield once a new TCP connection is established. When established, the corresponding
TcpStreamand the remote peer's address will be returned.Cancel safety
This method is cancel safe. If the method is used as the event in a
tokio::select!statement and some other branch completes first, then it is guaranteed that no new connections were accepted by this method.Examples
use tokio::net::TcpListener; use std::io; #[tokio::main] async fn main() -> io::Result<()> { let listener = TcpListener::bind("127.0.0.1:8080").await?; match listener.accept().await { Ok((_socket, addr)) => println!("new client: {:?}", addr), Err(e) => println!("couldn't get client: {:?}", e), } Ok(()) }fn poll_accept(self: &Self, cx: &mut Context<'_>) -> Poll<Result<(TcpStream, SocketAddr)>>Polls to accept a new incoming connection to this listener.
If there is no connection to accept,
Poll::Pendingis returned and the current task will be notified by a waker. Note that on multiple calls topoll_accept, only theWakerfrom theContextpassed to the most recent call is scheduled to receive a wakeup.fn from_std(listener: TcpListener) -> Result<TcpListener>Creates new
TcpListenerfrom astd::net::TcpListener.This function is intended to be used to wrap a TCP listener from the standard library in the Tokio equivalent.
This API is typically paired with the
socket2crate and theSockettype to build up and customize a listener before it's shipped off to the backing event loop. This allows configuration of options likeSO_REUSEPORT, binding to multiple addresses, etc.Notes
The caller is responsible for ensuring that the listener is in non-blocking mode. Otherwise all I/O operations on the listener will block the thread, which will cause unexpected behavior. Non-blocking mode can be set using
set_nonblocking.Passing a listener in blocking mode is always erroneous, and the behavior in that case may change in the future. For example, it could panic.
Examples
use Error; use TcpListener; asyncPanics
This function panics if it is not called from within a runtime with IO enabled.
The runtime is usually set implicitly when this function is called from a future driven by a tokio runtime, otherwise runtime can be set explicitly with
Runtime::enterfunction.fn into_std(self: Self) -> Result<TcpListener>Turns a
tokio::net::TcpListenerinto astd::net::TcpListener.The returned
std::net::TcpListenerwill have nonblocking mode set astrue. Useset_nonblockingto change the blocking mode if needed.Examples
use Error; asyncfn local_addr(self: &Self) -> Result<SocketAddr>Returns the local address that this listener is bound to.
This can be useful, for example, when binding to port 0 to figure out which port was actually bound.
Examples
use TcpListener; use io; use ; asyncfn ttl(self: &Self) -> Result<u32>Gets the value of the
IP_TTLoption for this socket.For more information about this option, see
set_ttl.Examples
use tokio::net::TcpListener; use std::io; #[tokio::main] async fn main() -> io::Result<()> { let listener = TcpListener::bind("127.0.0.1:0").await?; listener.set_ttl(100).expect("could not set TTL"); assert_eq!(listener.ttl()?, 100); Ok(()) }fn set_ttl(self: &Self, ttl: u32) -> Result<()>Sets the value for the
IP_TTLoption on this socket.This value sets the time-to-live field that is used in every packet sent from this socket.
Examples
use tokio::net::TcpListener; use std::io; #[tokio::main] async fn main() -> io::Result<()> { let listener = TcpListener::bind("127.0.0.1:0").await?; listener.set_ttl(100).expect("could not set TTL"); Ok(()) }
impl AsFd for TcpListener
fn as_fd(self: &Self) -> BorrowedFd<'_>
impl AsRawFd for TcpListener
fn as_raw_fd(self: &Self) -> RawFd
impl Debug for TcpListener
fn fmt(self: &Self, f: &mut Formatter<'_>) -> Result
impl Freeze for TcpListener
impl RefUnwindSafe for TcpListener
impl Send for TcpListener
impl Sync for TcpListener
impl TryFrom for TcpListener
fn try_from(stream: TcpListener) -> Result<Self, <Self as >::Error>Consumes stream, returning the tokio I/O object.
This is equivalent to
TcpListener::from_std(stream).
impl Unpin for TcpListener
impl UnsafeUnpin for TcpListener
impl UnwindSafe for TcpListener
impl<T> Any for TcpListener
fn type_id(self: &Self) -> TypeId
impl<T> Borrow for TcpListener
fn borrow(self: &Self) -> &T
impl<T> BorrowMut for TcpListener
fn borrow_mut(self: &mut Self) -> &mut T
impl<T> From for TcpListener
fn from(t: T) -> TReturns the argument unchanged.
impl<T, U> Into for TcpListener
fn into(self: Self) -> UCalls
U::from(self).That is, this conversion is whatever the implementation of
[From]<T> for Uchooses to do.
impl<T, U> TryFrom for TcpListener
fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>
impl<T, U> TryInto for TcpListener
fn try_into(self: Self) -> Result<U, <U as TryFrom<T>>::Error>