>>分享流行的Java框架以及开源软件,对孙卫琴的《精通Spring》、《Spring Cloud Alibaba微服务开发零基础入门到实操》提供技术支持 书籍支持  卫琴直播  品书摘要  在线测试  资源下载  联系我们
发表一个新主题 开启一个新投票 回复文章 您是本文章第 19715 个阅读者 刷新本主题
 * 贴子主题:  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开发-->使用Session(Ⅰ)
  JSP与Hibernate开发-->第一个helloapp应用
  Java网络编程-->基于UDP的数据报和套接字
  精通Spring-->计算属性和数据监听
  Vue3开发-->绑定CSS样式
  Spring 5 webflux响应式编程 - 但时间也偷换概念
  使用Spring MVC统一异常处理实战
  Spring MVC的拦截器的详细用法
  拦截器不拦截静态资源的三种处理方法
  JSR-303 数据验证注解的用法
  Spring MVC处理异步请求
  SpringMVC Model、ModelMap和ModelAndView的区别和用法
  国内 Java 开发者必备的两个神器:Maven国内镜像和Spring国内...
  聊聊Spring Cloud版本的那些事儿
  中央厨房订单管理系统,引入ActiveMQ消息队列,平滑处理高峰...
  Spring+JPA+ehcache开启二级本地缓存
  再谈响应式流(结合制奶厂业务的案例)
  mybatis-plus 注解实现多表关联查询的最佳实践
  Spring Boot整合WebSocket及Spring Security实例
  Axis、Axis2和CXF比较
  更多...
 IPIP: 已设置保密
楼主      
1页 0条记录 当前第1
发表一个新主题 开启一个新投票 回复文章


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