服务端NETTY 客户端非NETTY处理粘包和拆包的问题
之前为了调式和方便一直没有处理粘包的问题,今天专门花了时间来搞NETTY的粘包处理,要知道在高并发下,不处理粘包是不可能的,数据流的混乱会造成业务的崩溃什么的我就不说了。所以这个问题 在我心里一直是个结。
使用NETTY真的很幸福,以前用C写服务端 还的自己处理粘包的问题 各种痛苦 不过那也是基本功 没办法的事情。
在NETTY里面 有几个拆个包器 我使用的是 LengthFileldBasedFrameDecoder,这个用来解析带有长度属性的包,只要我们在传输协议中加入包的总长度就行
arg0.pipeline().addFirst("decoder", new LengthFieldBasedFrameDecoder(1024,0,4,0,4));
arg0.pipeline().addLast(new TestInListener());
LengthFieldBasedFrameDecoder
几个参数的意思
1、最大长度
2-3、描述包长,因为我用的4个字节描述整个包的长度 这里就告诉拆包器 前4个字节描述的包长
4-5、如果整个包长的长度值包含了 包头的4个字节,那么告诉拆包器从0开始到第4个字节不用截取
最后拆包器拆完包就是调用handler.这里拿到的数据流就是已经截取好的内容了,没有包含前4个字节了
@Override public void channelRead(ChannelHandlerContext ctx, Object msg) throws Exception { String resultStr=""; //先转成NETTY buf ByteBuf result = (ByteBuf) msg; //全部数据 byte[] allDataByte = new byte[result.readableBytes()]; //转成BYTE数组 result.readBytes(allDataByte); resultStr = new String(allDataByte,"UTF-8"); }
好了 现在说说 我遇到的问题
首先 服务端是用NETTY 但是客户端是C# 之前没有用拆包器的时候 读取前4个字节没有什么问题 加了拆包器就出了问题,原因是,
C#那边发送的整个包 是小端模式 造成NETTY拿到包后 拆了前4个字节,解出来的长度错误~NETTY那边是不处理这个的,
所以C#发送之前 把前个4字节 转成大端 就OK了
什么是大端小端,其实这个叫法有点坑爹 会给人造成混乱,因为 端 对于中国人来说 有开始的意思 以后 这样叫吧 小尾,大尾
小尾就是 低地址存 数据的高位 高低地址存数据的地位 什么鬼意思呢
看图
看 小端模式 都是高地址存小数据
小端 就是小尾巴 大端就是大尾巴。
LengthFieldBasedFrameDecoder 的报错
Adjusted frame length exceeds
一定要清楚字节序
new LengthFieldBasedFrameDecoder(
ByteOrder.LITTLE_ENDIAN,//字节序
20*1024,
0,
4,
0,
4,
true
)
第一个参数就是字节序,服务端和客户端要一样
坑
字节序一定要一致,网络传输默认的都是大端序.但为什么会出现一组数据中,字节序不一致?
let buffer = Buffer.from(JSON.stringify(sendData)); let lenBuf = Buffer.alloc(4); //需要发送的数据长度 let needLen = buffer.length+4; //数据长度 lenBuf.writeInt32LE(needLen); //开辟新的内存块 let newBuf = Buffer.alloc(needLen); lenBuf.copy(newBuf,0,0,4); buffer.copy(newBuf, 4, 0, buffer.length); this._debugProxySock.write(newBuf);
上面的js代码,很明显把包头大小设置了成了小端writeInt32LE,但所有框架啊,系统啊,什么的,都是按大端发送的,所以,这数据发出去。别人解析的时候就会有问题,当然,明确解析时的字节序也不会有问题,只是会造成一些麻烦和困惑,所以,必须要一致。
java新手自学群 626070845
java/springboot/hadoop/JVM 群 4915800
Hadoop/mongodb(搭建/开发/运维)Q群481975850
GOLang Q1群:6848027
GOLang Q2群:450509103
GOLang Q3群:436173132
GOLang Q4群:141984758
GOLang Q5群:215535604
C/C++/QT群 1414577
单片机嵌入式/电子电路入门群群 306312845
MUD/LIB/交流群 391486684
Electron/koa/Nodejs/express 214737701
大前端群vue/js/ts 165150391
操作系统研发群:15375777
汇编/辅助/破解新手群:755783453
大数据 elasticsearch 群 481975850
本文版权归作者和博客园共有,欢迎转载,但未经作者同意必须保留此段声明,且在文章页面明显位置给出原文连接,否则保留追究法律责任的权利。
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
· 探究高空视频全景AR技术的实现原理
· 阿里最新开源QwQ-32B,效果媲美deepseek-r1满血版,部署成本又又又降低了!
· SQL Server 2025 AI相关能力初探
· AI编程工具终极对决:字节Trae VS Cursor,谁才是开发者新宠?
· 开源Multi-agent AI智能体框架aevatar.ai,欢迎大家贡献代码
· Manus重磅发布:全球首款通用AI代理技术深度解析与实战指南