博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
netty如何解决粘包和半包
阅读量:6281 次
发布时间:2019-06-22

本文共 2163 字,大约阅读时间需要 7 分钟。

hot3.png


TCP是一个基于“流”的协议,所谓流就像河里的水没有严格的界限。TCP底层并不了解上层业务的具体实现,它会根据TCP缓冲区的具体情况进行划分,所以就可能会出现业务上一个完整的TCP包可能会拆分成多个小包进行发送,也可能多个小包被组装成一个大包进行发送,从而导致了TCP中的粘包和半包问题。

解决方案

  1. 消息定长,每发送一次消息,在接收消息的同时截取固定长度的字节。
  2. 以某种分隔符进行分割。
  3. 把消息封装成消息头和消息体。

netty中的粘包和半包解决方案

消息定长格式解决

通过添加DelimiterBasedFrameDecoder来解决粘包半包问题

b.group(bossGroup, workGroup)                .channel(NioServerSocketChannel.class)                .option(ChannelOption.SO_BACKLOG, 1024)                .handler(new LoggingHandler())                .childHandler(new ChannelInitializer
() { @Override protected void initChannel(SocketChannel socketChannel) throws Exception { ByteBuf delimiter = Unpooled.copiedBuffer("$_".getBytes()); socketChannel.pipeline().addLast(new DelimiterBasedFrameDecoder(1024, delimiter)); //socketChannel.pipeline().addLast(new FixedLengthFrameDecoder(10)); socketChannel.pipeline().addLast(new StringDecoder()); socketChannel.pipeline().addLast(new EchoServerHandler()); } });

根据特定字符分割解决

通过添加FixedLengthFrameDecoder获取固定长度字符来解决粘包半包问题

b.group(bossGroup, workGroup)                .channel(NioServerSocketChannel.class)                .option(ChannelOption.SO_BACKLOG, 1024)                .handler(new LoggingHandler())                .childHandler(new ChannelInitializer
() { @Override protected void initChannel(SocketChannel socketChannel) throws Exception { //ByteBuf delimiter = Unpooled.copiedBuffer("$_".getBytes()); //socketChannel.pipeline().addLast(new DelimiterBasedFrameDecoder(1024, delimiter)); socketChannel.pipeline().addLast(new FixedLengthFrameDecoder(10)); socketChannel.pipeline().addLast(new StringDecoder()); socketChannel.pipeline().addLast(new EchoServerHandler()); } });

根据消息头和消息体封装解决

通过ObjectDecoder和ObjectEncoder来消息头和消息体来解决粘包和半包问题。

转载于:https://my.oschina.net/u/1787735/blog/1930053

你可能感兴趣的文章
《UNIX网络编程 卷1:套接字联网API(第3版)》——8.6 UDP回射客户程序:dg_cli函数...
查看>>
不要将时间浪费到编写完美代码上
查看>>
《第一桶金怎么赚——淘宝开店创业致富一册通》一一第1章 创业梦想,怎样起步...
查看>>
基于容器服务的持续集成与云端交付(三)- 从零搭建持续交付系统
查看>>
《算法基础:打开算法之门》一3.4 归并排序
查看>>
高德开放平台开放源代码 鼓励开发者创新
查看>>
《高并发Oracle数据库系统的架构与设计》一2.5 索引维护
查看>>
《Exchange Server 2010 SP1/SP2管理实践》——2.4 部署外部网络环境
查看>>
Firefox 是 Pwn2own 2014 上攻陷次数最多的浏览器
查看>>
阿里感悟(十八)- 应届生Review
查看>>
《计算广告:互联网商业变现的市场与技术》一第一部分 在线广告市场与背景...
查看>>
话说模式匹配(5) for表达式中的模式匹配
查看>>
《锋利的SQL(第2版)》——1.7 常用函数
查看>>
《Arduino家居安全系统构建实战》——1.5 介绍用于机器学习的F
查看>>
jquery中hover()的用法。简单粗暴
查看>>
线程管理(六)等待线程的终结
查看>>
spring boot集成mongodb最简单版
查看>>
DELL EqualLogic PS存储数据恢复全过程整理
查看>>
《Node.js入门经典》一2.3 安装模块
查看>>
《Java 开发从入门到精通》—— 2.5 技术解惑
查看>>