一分钟看懂TCP粘包拆包

本文介绍了TCP粘包拆包的现象、原因及解决方法,包括Netty框架如何处理这一问题。TCP作为面向流的协议,可能导致数据包的粘合或拆分,影响消息的正确解读。解决粘包拆包可以通过在数据包前添加长度字段、固定长度封装或设置数据边界。Netty提供了多种编解码器来应对这种情况。
摘要由CSDN通过智能技术生成

平时大家在网络编程过程中可能会遇到这样一种现象:客户端发送了一长串消息,服务端接受的消息揉在一起或者被拆分了,这样就会造成消息难以被正确理解。

比如说有一天你特别想喝奶茶,看了一下外卖,「一点点」的奶茶看着不错,(一点点赶紧给我打钱 doge),于是你在群里发了一条消息,想找几个人拼奶茶:

一点点奶茶有人喝吗?

结果群里同事回了一句:

现在不是已经三点了吗?

你觉得莫名其妙,看了一眼同事的手机,他收到的消息是这样的两行:

一点 点奶茶有人喝吗?

哈哈,讲了一个冷笑话。用专业的术语来说这种现象就是「拆包」了,我们接着往下讲。

TCP 粘包拆包的现象

粘包拆包问题一般是处于应用层下的问题,在数据链路层、网络层以及传输层都有可能发生。我们日常的网络应用开发大多都在传输层进行,因此本文着重讲解传输层粘包拆包问题。

传输层有两个协议我们都很熟悉:UDP 和 TCP,UDP有消息保护边界,不会发生粘包拆包问题,因此粘包拆包问题只发生在TCP协议中。

下面用一个简单的例子来讲解什么是粘包和拆包。

假设客户端向服务端连续发送了两个数据包,用 packet1 和 packet2 来表示,那么服务端收到的数据可能有四种:

(1)第一种情况,服务端按顺序正常收到两个包,即未出现粘包和拆包的现象。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值