资讯专栏INFORMATION COLUMN

php - tcp 粘包/拆包实例

Blackjun / 2358人阅读

摘要:长链接模式下,使用固定消息头长度的方式进行消息拆包,解决粘包问题。但如果是短连接多个消息或长链接模式下,就可能会发生粘包,客户端不关闭服务端无法通过确定消息读取完毕的问题。这就需要定义协议和拆包。

tcp 长链接模式下,使用固定消息头长度的方式进行消息拆包,解决粘包问题。

固定消息头协议

将消息头的前N个字节固定为消息长度位,结合业务场景,2bytes4bytes,读取消息时先读取消息长度位,即可按具体的消息长度读取消息内容

pack/unpack 可以打包数值至二进制/解包二进制至数值,具体的模式可以参考 pack/unpack 详细用法,这里我们选用固定头长度为2bytes来表示消息体长度,最大能表示2^16 - 1长度的消息体,不够你就上4bytes好了。

组包

粘包
// send
// 传输 $package 由 $foo $bar 两条消息组成 模拟粘包场景
// receive
拆包

日常工作中经常遇到的tcp场景可能是短连接单个消息的模式,客户端发送一条消息后便关闭连接,服务端循环读取到EOF即可得到一条完整的消息。但如果是短连接多个消息长链接模式下,就可能会发生粘包,客户端不关闭服务端无法通过EOL确定消息读取完毕的问题。这就需要定义协议和拆包。

文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。

转载请注明本文地址:https://www.ucloud.cn/yun/31837.html

相关文章

  • TCP 粘包拆包

    摘要:粘包问题在这种字节流协议上做应用层分包是网络编程的基本需求。分包指的是在发生一个消息或一帧数据时,通过一定的处理,让接收方能从字节流中识别并截取还原出一个个消息。 粘包问题 在 TCP 这种字节流协议上做应用层分包是网络编程的基本需求。分包指的是在发生一个消息(message)或一帧(frame)数据时,通过一定的处理,让接收方能从字节流中识别并截取(还原)出一个个消息。因此,粘包问题...

    zilu 评论0 收藏0
  • Netty(三) 什么是 TCP 拆、粘包?如何解决?

    摘要:是一个面向字节流的协议,它是性质是流式的,所以它并没有分段。可基于分隔符解决。编解码的主要目的就是为了可以编码成字节流用于在网络中传输持久化存储。 showImg(https://segmentfault.com/img/remote/1460000015895049); 前言 记得前段时间我们生产上的一个网关出现了故障。 这个网关逻辑非常简单,就是接收客户端的请求然后解析报文最后发送...

    YanceyOfficial 评论0 收藏0
  • 【Java】几道让你拿offer的面试题

    摘要:的方法,的默认实现会判断是否是类型注意自动拆箱,自动装箱问题。适应自旋锁锁竞争是下的,会经过用户态到内核态的切换,是比较花时间的。在中引入了自适应的自旋锁,说明自旋的时间不固定,要不要自旋变得越来越聪明。 前言 只有光头才能变强 之前在刷博客的时候,发现一些写得比较好的博客都会默默收藏起来。最近在查阅补漏,有的知识点比较重要的,但是在之前的博客中还没有写到,于是趁着闲整理一下。 文本的...

    张春雷 评论0 收藏0
  • 彻底理解Netty,这一篇文章就够了

    摘要:如果什么事都没得做,它也不会死循环,它会将线程休眠起来,直到下一个事件来了再继续干活,这样的一个线程称之为线程。而请求处理逻辑既可以使用单独的线程池进行处理,也可以跟放在读写线程一块处理。 Netty到底是什么 从HTTP说起 有了Netty,你可以实现自己的HTTP服务器,FTP服务器,UDP服务器,RPC服务器,WebSocket服务器,Redis的Proxy服务器,MySQL的P...

    yy13818512006 评论0 收藏0

发表评论

0条评论

最新活动
阅读需要支付1元查看
<