>>分享流行的Java框架以及开源软件,对孙卫琴的《精通Spring:Java Web开发技术详解》提供技术支持 书籍支持  卫琴直播  品书摘要  在线测试  资源下载  联系我们
发表一个新主题 开启一个新投票 回复文章 您是本文章第 13991 个阅读者 刷新本主题
 * 贴子主题:  Netty的粘包和拆包问题分析 回复文章 点赞(0)  收藏  
作者:Jacky    发表时间:2021-06-24 00:04:22     消息  查看  搜索  好友  邮件  复制  引用

    

什么是粘包和拆包

  粘包:多次发送的消息,客户端一次合并读取 Msg Msg=msgmsg

拆包:第一次完整消息+第二次部分消息组合 、第二次缺失的消息 Msg Msg=MsgM  sg

粘包和拆包产生的原因

   前提长连接、其次缓冲区

Tcp协议为了能够高性能的传输数据,发送和接受时候都会采用缓冲区,必须等待缓冲区满了以后才可以发送或者读取;

1.当我们的应用程序如果发送的数据大于了我们的套字节的缓冲区大小的话,就会造成了拆包。拆分成多条消息读取

2.当我们应用程序如果发送的写入的消息如果小于套字节缓冲区大小的时候,就会造成粘包。

3.接受端不够及时的获取缓冲区的数据,也会产生粘包的问题

4.进行mss(最大报文长度)大小的TCP分段,当TCP报文长度-TCP头部长度>mss的时候将发生拆包。
----------------------------
原文链接:https://www.jianshu.com/p/1837ab534b9a

程序猿的技术大观园:www.javathinker.net



[这个贴子最后由 flybird 在 2021-08-30 21:50:55 重新编辑]
  Java面向对象编程-->变量的作用域和初始化
  JavaWeb开发-->JSP技术详解(Ⅱ)
  JSP与Hibernate开发-->Java对象持久化技术概述
  Java网络编程-->基于MVC和RMI的分布式应用
  精通Spring-->Vue Router路由管理器
  Vue3开发-->虚拟DOM和render()函数
  Marshalling在Netty中的使用
  重新理解响应式编程
  Spring MVC异常处理机制
  Spring MVC和前后端分离的RESTFul框架
  Spring Boot、SpringMVC进行i18n国际化支持:使用MessageSou...
  重新理解响应式编程
  @SessionAttributes的用法
  Spring MVC中Controller的用法
  SpringMVC Model、ModelMap和ModelAndView的区别和用法
  深入Redis客户端(redis客户端属性、redis缓冲区、关闭redis客...
  Spring Cloud Config 客户端的高可用实现
  开发一个Java项目的基本流程
  Spring+JPA+ehcache开启二级本地缓存
  写给新手的Spring Cloud的微服务入门教程
  什么是CXF
  更多...
 IPIP: 已设置保密
楼主      
1页 0条记录 当前第1
发表一个新主题 开启一个新投票 回复文章


中文版权所有: JavaThinker技术网站 Copyright 2016-2026 沪ICP备16029593号-2
荟萃Java程序员智慧的结晶,分享交流Java前沿技术。  联系我们
如有技术文章涉及侵权,请与本站管理员联系。