Netty如何解决TCP的粘包半包问题?(下)

简介: Netty如何解决TCP的粘包半包问题?

1 TCP为何会有粘包半包?

1.1 粘包

  • 发送方每次写入数据 < 套接字缓冲区大小
  • 接收方读取套接字缓冲区数据不够及时

1.2 半包

  • 发送方写入数据 > 套接字缓冲区大小
  • 发送的数据大于协议的MTU ( Maximum Transmission Unit,最大传输单元),必须拆包

而且

  • 一个发送可能被多次接收,多个发送可能被一次接收
  • 一个发送可能占用多个传输包,多个发送可能公用一个传输包

本质是因为 TCP 是流式协议,消息无边界。

UDP就像快递,虽然一次运输多个,但每个包都有边界,一个个签收,所以无此类问题。

清楚了问题本质,就知道如何避免了,即确定消息边界。

2 解决方案

2.1 改为短连接

一个请求一个短连接。建立连接到释放连接之间的信息即为传输信息。

简单,但效率低下,不推荐。

2.2 封装成帧

2.2.1 固定长度

  • 解码:FixedLengthFrameDecoder
  • image.png
  • 满足固定长度即可。
  • image.png
  • 简单,但空间浪费,不推荐。

2.2.2 分割符

  • 解码:DelimiterBasedFrameDecoder,分隔符之间即为消息。
  • image.png
  • 空间不浪费,也比较简单,但内容本身出现分隔符时需转义,所以需扫描内容。

推荐度低。


2.2.3 固定长度字段存个内容的长度信息

解码:LengthFieldBasedFrameDecoder

编码:LengthFieldPrepender

先解析固定长度的字段获取长度,然后读取后续内容。这就没有之前的缺点了


精确定位用户数据,内容也不用转义。

但长度理论上有限制,需提前预知可能的最大长度,从而定义长度占用字节数。

如果直接定义成最大长度,但实际上每次传输的又远没达到最大值,不就浪费空间啦,所以根据需要设置最大长度。


重点推荐使用。


其他方式比如 json 可看{}是否已经成对。但这种明显要扫描全部内容才知道是否成对。


目录
相关文章
|
网络协议 前端开发
netty的TCP服务端和客户端实现
本文介绍了使用Netty框架实现TCP服务端和客户端的步骤,包括添加Netty依赖、编写服务端和客户端的代码,涉及NioEventLoopGroup、ServerBootstrap、Bootstrap、ChannelInitializer等核心组件,以及如何启动服务端监听和客户端连接。
1056 4
|
编解码 网络协议 开发者
Netty运行原理问题之NettyTCP的粘包和拆包的问题如何解决
Netty运行原理问题之NettyTCP的粘包和拆包的问题如何解决
153 1
|
移动开发 网络协议 算法
(十)Netty进阶篇:漫谈网络粘包、半包问题、解码器与长连接、心跳机制实战
在前面关于《Netty入门篇》的文章中,咱们已经初步对Netty这个著名的网络框架有了认知,本章的目的则是承接上文,再对Netty中的一些进阶知识进行阐述,毕竟前面的内容中,仅阐述了一些Netty的核心组件,想要真正掌握Netty框架,对于它我们应该具备更为全面的认知。
944 2
|
网络协议
netty粘包问题分析
netty粘包问题分析
189 0
|
Java
Netty传输object并解决粘包拆包问题
Netty传输object并解决粘包拆包问题
205 0
|
网络协议 算法
Netty入门到超神系列-TCP粘包拆包处理
TCP是面向连接的,服务端和客户端通过socket进行数据传输,发送端为了更有效的发送数据,通常会使用Nagle算法把多个数据块合并成一个大的数据块,这样做虽然提高了效率,但是接收端就很难识别完整的数据包了(TCP无消息保护边界),可能会出现粘包拆包的问题。
268 0
|
移动开发 网络协议
【Netty】TCP粘包和拆包
前面已经基本上讲解完了Netty的主要内容,现在来学习Netty中的一些可能存在的问题,如TCP粘包和拆包。
290 0
【Netty】TCP粘包和拆包
|
移动开发 网络协议
Netty解决TCP粘包/拆包的问题
首先要明确, 粘包问题中的 “包”, 是指应用层的数据包.在TCP的协议头中, 没有如同UDP一样的 “报文长度” 字段,但是有一个序号字段.
Netty解决TCP粘包/拆包的问题
|
网络协议 前端开发 Java
Netty的TCP粘包/拆包(源码二)
假设客户端分别发送了两个数据包D1和D2给服务器,由于服务器端一次读取到的字节数是不确定的,所以可能发生四种情况:   1、服务端分两次读取到了两个独立的数据包,分别是D1和D2,没有粘包和拆包。   2、服务端一次接收到了两个数据包,D1和D2粘合在一起,被称为TCP粘包。
1107 0
|
9月前
|
算法 Java 容器
Netty源码—4.客户端接入流程
本文主要介绍了关于Netty客户端连接接入问题整理、Reactor线程模型和服务端启动流程、Netty新连接接入的整体处理逻辑、新连接接入之检测新连接、新连接接入之创建NioSocketChannel、新连接接入之绑定NioEventLoop线程、新连接接入之注册Selector和注册读事件、注册Reactor线程总结、新连接接入总结