>>分享流行的Java框架以及开源软件,对孙卫琴的《精通Spring》、《Spring Cloud Alibaba微服务开发零基础入门到实操》提供技术支持 书籍支持  卫琴直播  品书摘要  在线测试  资源下载  联系我们
发表一个新主题 开启一个新投票 回复文章 您是本文章第 19716 个阅读者 刷新本主题
 * 贴子主题:  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面向对象编程-->Java常用类(下)
  JavaWeb开发-->JavaWeb应用入门(Ⅱ)
  JSP与Hibernate开发-->通过JPA API检索数据
  Java网络编程-->用Axis发布Web服务
  精通Spring-->Vue CLI脚手架工具
  Vue3开发-->Vue组件开发高级技术
  Mybatis常见注解有哪些?
  面试官问什么是Spring循环依赖,该如何回答?
  Redis夺命连环11问
  @Service注解的使用
  springmvc处理异步请求的示例
  SpringMVC 中 @ControllerAdvice 注解的三种使用场景!
  Spring MVC的拦截器的详细用法
  说说微服务的优缺点
  SpringCloud Gateway-整体流程
  Java软件架构设计七大原则
  【Web服务开发】基于Java开发代驾定位系统,2天完成脚手架
  网红框架SpringBoot2.x之定制参数浅析
  Spring Boot集成shiro ehcache(使用shiro的缓存管理)
  Spring与MyBatis整合
  大话微服务」深入聊聊SpringCloud之客户端负载均衡机制
  更多...
 IPIP: 已设置保密
楼主      
1页 0条记录 当前第1
发表一个新主题 开启一个新投票 回复文章


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