TCP全连接和半连接

最近听组内老司机分享了关于TCP半连接和全连接的分享,颇有收获。

现网问题:
server、client负载都不是很高的时候,居然可能会出现如下两个问题
1、Client端在多次重发SYN包得不到响应而返回(connection time out)错误
2、client端报错read timeout 或者 connection reset by peer

负载不是很高的情况下,一般不会出现这种情况,所以估计是linux内核参数哪里不对,需要对整个TCP连接进行回顾。

TCP连接的基本概念:

三次握手:
1、第一次握手:客户端发送syn包(syn=j)到服务器,并进入SYN_SEND状态,等待服务器确认;
2、第二次握手:服务器收到syn包,必须确认客户的SYN(ack=j+1),同时也发送一个SYN包(syn=k),即SYN+ACK包,此时服务器进入SYN_RECV状态;
3、第三次握手:客户端收到服务器的SYN+ACK包,向服务器发送确认包ACK(ack=k+1),此包发送完毕,客户端和服务器进入ESTABLISHED状态,完成三次握手。

四次分手:
1、客户端向服务器发送一个FIN为1 的TCP报文
2、服务器返回给客户端一个确认ACK报文
3、服务器同时发送一个FIN报文
4、客户机回复ACK报文后(四次握手),连接结束。


Linux内核协议栈为一个tcp连接管理使用两个队列,一个是半链接队列(用来保存处于SYN_SENT和SYN_RECV状态的请求),一个是全连接队列(accpetd队列)(用来保存处于established状态,但是应用层没有调用accept取走的请求)。


全连接队列的大小取决于:min(tcp_max_syn_backlog, net.core.somaxconn)
半连接队列的大小取决于:max(64, tcp_max_syn_backlog)


全连接队列、半连接队列溢出很容易忽视,对于一些短连接应用(比如Nginx、PHP)更容易爆发。一旦溢出,Server端从cpu、线程状态看负载正常,但压力上不去。而Client端看来,请求耗时较高,但server端记录的服务响应又很短,同时客户端会不定期出现连接超时、socket 读写超时 的现象。

客户端调整思路
对TCP连接失败,增加重试机制和超时时间
启用长连接机制 (可减少连接环节开销,从而降低延时)

服务端调整思路
修改内核参数,适当调整 net.core.somaxconn (调整全队列长度)
修改内核参数,适当调整 tcp_max_syn_backlog (调整半队列长度)




  • 9
    点赞
  • 29
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
TCP (Transmission Control Protocol) 连接全连接是建立两个进程间通信的两种状态,它们的主要区别在于网络连接的状态和数据传输的过程: **连接(三次握手):** - 在客户端发起连接请求之前,首先发送一个SYN(同步序号)包给服务器。 - 服务器接收到SYN包后,会回应一个SYN+ACK(同步确认)包,同时设置期望序列号。 - 客户端再次回应一个ACK(确认)包,表示收到了服务器的响应并且同意连接条件。 在这个阶段,双方已经交换了必要的控制信息,但是还没有正式的数据传输,因此还不是一个完全的连接状态。 **全连接(四次挥手):** - 当服务器和客户端都准备好开始数据传输时,他们各自维护一个完整的连接(即双方都有SYN+ACK包来回交互)。 - 数据传输结束后,一方希望关闭连接,通常由发起方发送FIN(结束)包,请求释放连接。 - 对方收到FIN包后,发送ACK作为应答,并在完成数据发送后也发送FIN包结束本方向的连接。 - 最后,双方互相发送ACK确认对方已接收FIN,完成断开连接的所有步骤。 总的来说,连接是在连接建立前的试探阶段,而全连接则是实际数据传输的稳定状态。连接节省了资源,因为它不需要立即创建一个全双工连接,但在数据传输开始前需要更多交互。全连接更高效,一旦建立就可以直接传输数据,直到双方协商关闭。
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值