码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • 面试官:什么是TCP粘包?粘包原因?如何解决?


    文章目录

      • 1、什么是TCP粘包?
      • 2、TCP粘包的原因?
      • 3、如何解决粘包问题?
      • 4、UDP会有粘包问题吗?

    1、什么是TCP粘包?

    TCP粘包是指发送方将多个数据包发送到接收方的缓冲区,应用程序读取到接收方缓冲区中多个首尾相连粘在一起的数据包。

    举例
    比如发送方分别发了123456789和abcdef这两个数据,本来应该分别读的,但是读取时,可能第一次只读了123456,下一次读了789abcdef,这就造成粘包。

    2、TCP粘包的原因?

    主要从发送方和接收方两方面来分析

    发送方:由于TCP协议默认使用Nagle算法(通过合并数据,从而减少发送数量来提升TCP/IP传输效率),这个算法会收集多个数据包分组,将多个数据量小数据包合并成一个大的数据块,这样会导致接收方难以分辨原来数据包,故Nagle算法可能会导致发送方出现粘包问题。
    在这里插入图片描述

    接收方:由于TCP 连接的每一方都有固定大小的缓冲空间,TCP连接的接收方接收到的数据包就会放在其缓冲区中,等待应用程序(应用层)来读取。但有时会出现接收数据的速率大于应用程序读取的速率,这就会导致多个首尾相连的数据包被应用程序视为一个包读取,就出现粘包问题。

    注:这里需要知道一个概念,就是TCP协议是将HTTP请求分成一段段的数据包分组,并按一定顺序一段段发送到接收方,接收方也是一段段接收,然后再重组成原来HTTP请求,如果读取的是多个粘在一起的包,那么就无法重组成之前的请求,进而无法完成请求,所以就要排查解决请求在网络通信的问题。

    3、如何解决粘包问题?

    主要也可从发送方和接收方两方面来分析

    发送方:因为主要是Nagle算法合并导致,故可通过不使用Nagle算法来解决,发送方用TCP_NODELAY选项来关闭。

    接收方:这里接收方解决指的是应用层方面,即格式化数据包和附带数据包长度发送,格式化数据包是指为数据包加上开始符和结束符,那么应用程序读取时就能区分出每个数据包的开始和结束。附带数据包长度发送是指在数据包头部定义出数据包的长度,那么程序在读取时,会按照长度读取对应字节数据,保证读取的是单个包,且数据完整,这样就能保证数据包是单个且完整。

    4、UDP会有粘包问题吗?

    UDP不存在粘包问题,因为UDP连接的接收方每次只接收一条独立的数据包,而TCP协议可以将多个数据包一起发送并接收(前提是接收方缓冲区剩余大小要能接收这多个数据),即接收方不保证一次只接收一条信息,所以TCP才存在粘包问题。

  • 相关阅读:
    LeetCode 300. 最长递增子序列
    【Spring Cloud系列】Config详解与应用
    8岁上海小学生B站教编程惊动苹果,库克亲送生日祝福
    阿里云云平台的物理安全防御措施
    阿里高级架构内产的 SpringBoot 保姆级笔记,面面俱到,Java开发迟早用得到的成神笔记
    Linux| jq命令对JSON格式数据操作
    关于如何编写好金融科技客户端SDK的思考
    顺序读写函数的介绍:fscanf & fprintf
    VS2019 C#中文控制台显示为问号
    华为机试真题 C++ 实现【过滤组合字符串】【2022.11 Q4新题】
  • 原文地址:https://blog.csdn.net/weixin_39615182/article/details/126556648
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号