关注
什么是TCP粘包问题?
TCP粘包就是指发送方发送的若干包数据到达接收方时粘成了一包,从接收缓冲区来看,后一包数据的头紧接着前一包数据的尾,出现粘包的原因是多方面的,可能是来自发送方,也可能是来自接收方。
造成TCP粘包的原因
(1)发送方原因
TCP默认使用Nagle算法(主要作用:减少网络中报文段的数量),而Nagle算法主要做两件事:
只有上一个分组得到确认,才会发送下一个分组
收集多个小分组,在一个确认到来时一起发送
Nagle算法造成了发送方可能会出现粘包问题
(2)接收方原因
TCP接收到数据包时,并不会马上交到应用层进行处理,或者说应用层并不会立即处理。实际上,TCP将接收到的数据包保存在接收缓存里,然后应用程序主动从缓存读取收到的分组。这样一来,如果TCP接收数据包到缓存的速度大于应用程序从缓存中读取数据包的速度,多个包就会被缓存,应用程序就有可能读取到多个首尾相接粘到一起的包。
什么时候需要处理粘包现象?
如果发送方发送的多组数据本来就是同一块数据的不同部分,比如说一个文件被分成多个部分发送,这时当然不需要处理粘包现象
如果多个分组毫不相干,甚至是并列关系,那么这个时候就一定要处理粘包现象了
如何处理粘包现象?
(1)发送方
对于发送方造成的粘包问题,可以通过关闭Nagle算法来解决,使用TCP_NODELAY选项来关闭算法。
(2)接收方
接收方没有办法来处理粘包现象,只能将问题交给应用层来处理。
(2)应用层
应用层的解决办法简单可行,不仅能解决接收方的粘包问题,还可以解决发送方的粘包问题。
解决办法:循环处理,应用程序从接收缓存中读取分组时,读完一条数据,就应该循环读取下一条数据,直到所有数据都被处理完成,但是如何判断每条数据的长度呢?
格式化数据:每条数据有固定的格式(开始符,结束符),这种方法简单易行,但是选择开始符和结束符时一定要确保每条数据的内部不包含开始符和结束符。
发送长度:发送每条数据时,将数据的长度一并发送,例如规定数据的前4位是数据的长度,应用层在处理时可以根据长度来判断每个分组的开始和结束位置。
查看原帖
3 评论
相关推荐
牛客热帖
更多
正在热议
更多
# 在大厂上班是一种什么样的体验 #
6255次浏览 84人参与
# 机械人避雷的岗位/公司 #
41635次浏览 275人参与
# 程序员找工作至少要刷多少题? #
11592次浏览 183人参与
# 过年最难忘的一件事 #
23008次浏览 174人参与
# 我现在比当时_,你想录用我吗 #
4966次浏览 79人参与
# 为了减少AI幻觉,你注入过哪些设定? #
2376次浏览 89人参与
# 12306一秒售罄,你抢到回家的票了吗? #
970次浏览 31人参与
# 牛客AI体验站 #
4323次浏览 129人参与
# AI Coding的使用心得 #
3189次浏览 88人参与
# 找工作的破防时刻 #
252839次浏览 1960人参与
# 刚入职的你踩过哪些坑 #
5061次浏览 105人参与
# 一张图晒一下你的AI员工 #
3496次浏览 81人参与
# 你最满意的offer薪资是哪家公司? #
69408次浏览 348人参与
# 论秋招对个人心气的改变 #
6768次浏览 116人参与
# 关于春招/暑期实习,你想知道哪些信息? #
5035次浏览 89人参与
# 机械人你知道哪些单休企业 #
85265次浏览 428人参与
# 程序员能干到多少岁? #
6520次浏览 98人参与
# 黄金这个事上,你学到了什么 #
1159次浏览 35人参与
# 晒晒你司的新年福利 #
5042次浏览 80人参与
# 大家实习每天都在干啥 #
119202次浏览 627人参与
查看19道真题和解析