When an application puts a socket into LISTEN state using the listen syscall, it needs to specify a backlog for that socket. The backlog is usually described as the limit for the queue of incoming connections. Because of the 3-way handshake used by TCP, an incoming connection goes through an intermediate state SYN RECEIVED before it reaches the ESTABLISHED state and can be returned by the accept s
data:image/s3,"s3://crabby-images/6280a/6280abb56795cde97d44cc67c0770a17ded0bb20" alt="How TCP backlog works in Linux"