前段时间面试美团的时候被问到了TCP的Nagle算法,当时完全没有印象学过这么一个东西,现在将其记录如下:
Nagle算法
nagle算法用于处理小报文段(微小分组)的发送问题
nagle算法的核心思想是允许网络中最多只能有一个小分组被发送,而待发送的其它小分组会被重新分组成一个”较大的”小分组,等收到上一个小分组的应答后再发送
nagle算法可以减少网络中微小分组的数量,比如客户端需要依次向服务器发送大小为1,2,3,1,2字节的5个分组
在没有开启nagle算法的情况下,这些小分组会被依次发送(不需要等待上一个小分组的应答,因为没启动nagle),总共发送的报文段(分组)个数为5
当开启nagle算法时,客户端首先发送大小为1字节的第一个分组,随后其它分组到达发送缓冲区,由于上一个分组的应答还没有收到,所以TCP会先缓存新来的这4个小分组,并将其重新分组,组成一个大小为8(2+3+1+2)字节的”较大的”小分组。当第一个小分组的应答收到后,客户端将这个8字节的分组发送。总共发送的报文段(分组)个数为2
可以看到,当传输数据存在大量交互数据时,nagle算法可以有效减少网络中的报文段个数
————————————————
原文链接:https://blog.csdn.net/sinat_35261315/article/details/79392116