粘包半包 和 netty 中的四种拆包器 三种读半包解码器

1. 粘包

是什么?
粘包半包是发生在TCP协议阶段的一种现象。粘包,就是在接受数据时,多个发送过来的TCP包“粘”在了一起。也就是一次性读到了发送的多个通信包 ,粘在一起,如果不能正确的将这些包分隔开,我们就没办法处理请求数据。

怎么办?
那么解决这个问题的思路就是,按照我们规定好的格式来,如果从TCP底层读到了多个应用层数据包,则将其拆成一个一个的独立的应用层数据包,返回上层应用,这个过程通常称为拆包。

2. 半包

是什么?
同理,半包就是一次发送过来的TCP包被“拆”开了。也就是一次读到的包不完整,

怎么办?
解决这个问题的思路就是,接收端应用层不断从底层的TCP 缓冲区中读取数据。每次读取完,判断一下是否为一个完整的应用层数据包。如果是,上层应用层数据包读取完成。如果不是,那就保留该数据在应用层缓冲区,然后继续从 TCP 缓冲区中读取,直到得到一个完整的应用层数据包为止。

3. Netty 中的拆包器

  • 固定长度的拆包器 FixedLengthFrameDecoder
    每个应用层数据包的都拆分成都是固定长度的大小,比如 1024字节。

  • 行拆包器 LineBasedFrameDecoder
    每个应用层数据包,都以换行符作为分隔符,进行分割拆分。

  • 分隔符拆包器 DelimiterBasedFrameDecoder
    每个应用层数据包,都通过自定义的分隔符,进行分割拆分。

  • 基于数据包长度的拆包器 LengthFieldBasedFrameDecoder
    将应用层数据包的长度,作为接收端应用层数据包的拆分依据。要求应用层协议中包含数据包的长度。

4. 读半包解码器

  • LengthFieldBasedFrameDecoder
    netty提供的通用半包解码器
  • ProtobufVarint3FrameDecoder
    netty提供的针对Protobuf的半包解码器
  • 继承ByteToMessageDecoder类,自己处理半包消息
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值