(图片来源链接:http://jm.taobao.org/2017/05/25/525-1/)
这里的重点是两个队列,分别是syns queue和accpet queue。syns queue为半连接队列,accpet queue为全连接队列。
1. 在client端发送SYN给server后,server端变成SYN_RCVD状态,并将连接信息放入半连接队列中。
2. server端收到client端的ACK后,如果全连接队列没有满,则将连接信息从半连接队列取出,并放入全连接队列中。
# cat /proc/sys/net/ipv4/tcp_abort_on_overflow 0tcp_abort_on_overflow 为0表示如果三次握手第三步的时候全连接队列满了那么server扔掉client 发过来的ack。
如果全连接队列满了并且tcp_abort_on_overflow是0的话,server过一段时间再次发送syn+ack给client(也就是重新走握手的第二步),如果client超时等待比较短,就很容易异常了。
默认的sync+ack的重试次数为5次:
# cat /proc/sys/net/ipv4/tcp_synack_retries 5Send-Q 表示listen端口上的全连接队列最大为50,Recv-Q表示全连接队列当前使用了多少。
全连接队列的大小取决于:min(backlog, /proc/sys/net/core/somaxconn) . backlog是在socket创建的时候传入的,
# cat /proc/sys/net/core/somaxconn 65535半连接队列的大小取决于:max(64, /proc/sys/net/ipv4/tcp_max_syn_backlog)。
# cat /proc/sys/net/ipv4/tcp_max_syn_backlog 2048