粘包问题(TCP面向字节流批量发送数据导致)
粘包问题出现的原因
由于TCP协议网络传输数据的基本单位是字节流,所以当应用程序收到了传输的数据时,看到的是一连串的字节数据,而TCP协议网络传输数据有滑动窗口的机制(核心就是批量传输数据,推荐看TCP中窗口和滑动窗口的含义以及流量控制),所以传输过来的数据可能是多个数据包,因此就不知道从哪个部分到哪个部分是一个完整的应用层数据包
如何避免粘包问题
避免粘包问题的核心就是明确两个包之间的边界
1.对于定长的包,保证每次都按固定大小读取即可
2.对于变长的包,可以在包头的位置,约定一个包总长度的字段,从而就知道了包的结束位置
例子:约定包的前两个字段表示包总长度(程序员规定的),这样约定后,应用程序在获得数据时就会先读取包头的两个字段,读取到包总长度后再根据包总长度准确读取当前数据包的所有数据
后面再重复上述操作即可
3.对于变长的包,可以在包和包之间添加明确的分隔符(应用层协议,程序猿自己来定的,只有保证分隔符不和正文冲突就行)
粘包问题的一些注意点
1.首先要明确,粘包问题中的“包”是应用层的数据包
2.在TCP的协议头中,没有如同UDP一样的”报文长度“这样的字段(有一个首部长度的字段表示的只是TCP报头的长度),但有一个”序号“字段
3.站在传输层的角度,TCP是一个一个报文过来的,按照序号排好序放在缓冲区中
4.站在应用层的角度,看到的只是一连串的字节数据
对于UDP来说是否存在粘包问题呢
UDP是不存在粘包问题的
1.对于UDP,如果上层还没有交付数据,UDP的报文长度依然存在,同时,UDP是一个一个把数据交付给应用层,就有很明确的数据边界
2.站在应用层的角度,使用UDP时,要么收到完整的UDP报文,要么不收,不会出现”半个的情况“
相关文章:
粘包问题(TCP面向字节流批量发送数据导致)
粘包问题出现的原因 由于TCP协议网络传输数据的基本单位是字节流,所以当应用程序收到了传输的数据时,看到的是一连串的字节数据,而TCP协议网络传输数据有滑动窗口的机制(核心就是批量传输数据,推荐看TCP中窗口和滑动窗…...
selenium Chrome驱动下载地址
Chrome驱动官方最新版下载地址:https://googlechromelabs.github.io/chrome-for-testing/ 有稳定版,开发版等版本可以选择下载 选择 操作系统复制下载链接直接下载...
Linux命令200例:tar命令主要用于创建、查看和提取归档文件(常用)
🏆作者简介,黑夜开发者,全栈领域新星创作者✌。CSDN专家博主,阿里云社区专家博主,2023年6月csdn上海赛道top4。 🏆数年电商行业从业经验,历任核心研发工程师,项目技术负责人。 &…...
【Django】Task4 序列化及其高级使用、ModelViewSet
【Django】Task4 序列化及其高级使用、ModelViewSet Task4主要了解序列化及掌握其高级使用,了解ModelViewSet的作用,ModelViewSet 是 Django REST framework(DRF)中的一个视图集类,用于快速创建处理模型数据的 API 视…...
FFMPEG RTMP流打开速度慢优化方法一
先上使用方法: codec_ctx->flags | AVFMT_FLAG_NOBUFFER; AVFMT_FLAG_NOBUFFER 标记如果没有设置,就会导致打开时探测的数据包丢AVFormatContext的缓存区中。 播放的时候,就从这些数据包开始,但是整个探测过程时间可能较长&…...
NextJs - Middleware(中间件)
中间件允许您在请求完成之前运行代码。然后,根据传入的请求,您可以通过重写、重定向、修改请求或响应标头或直接响应来修改响应。 中间件在缓存内容和路由匹配之前运行。 使用规则 使用项目根目录中的文件 middleware.ts(或 .js)…...
记录几个Hudi Flink使用问题及解决方法
前言 如题,记录几个Hudi Flink使用问题,学习和使用Hudi Flink有一段时间,虽然目前用的还不够深入,但是目前也遇到了几个问题,现在将遇到的这几个问题以及解决方式记录一下 版本 Flink 1.15.4Hudi 0.13.0 流写 流写…...
Go:测试框架GoConvey 简介
快速开始 GoConvey是一个完全兼容官方Go Test的测试框架,一般来说这种第三方库都比官方的功能要强大、更加易于使用、开发效率更高,闲话少说,先看一个example: package utils import (. "github.com/smartystreets/goconvey…...
JavaWeb-特殊文件(propertis与XML)
目录 Properties文件 一.properties介绍 二.properties使用 三.解决中文乱码问题 XML文件 一.XML介绍 二.XML文件的语法规则 三.XML的使用 Properties文件 一.properties介绍 1.什么是properties文件 Properties文件是一种常用的配置文件格式,用于存储键值…...
ffmpeg合并mp4视频文件
下载ffmpeg Download FFmpeg 2配置环境 右键此电脑-》属性-》高级系统设置 环境变量-》path 解压上面ffmpeg压缩包,找到bin目录,复制完整路径,添加到path环境变量中 测试ffmpeg ffmpeg合并MP4文件 创建一个文本文件,例如inpu…...
ATF BL1/BL2 ufs_read_blocks/ufs_write_blocks使用分析
ATF BL1/BL2 ufs_read_blocks/ufs_write_blocks使用分析 1 ATF的下载链接2 ATF BL1/BL2 ufs_read_blocks/ufs_write_blocks处理流程2.1 ATF BL1/BL2 ufs_read_blocks2.2 ATF BL1/BL2 ufs_write_blocks 3 UFS System Model4 ufs_read_blocks/ufs_write_blocks详细分析4.1 ufs_re…...
Elasticsearch(十二)搜索---搜索匹配功能③--布尔查询及filter查询原理
一、前言 本节主要学习ES匹配查询中的布尔查询以及布尔查询中比较特殊的filter查询及其原理。 复合搜索,顾名思义是一种在一个搜索语句中包含一种或多种搜索子句的搜索。 布尔查询是常用的复合查询,它把多个子查询组合成一个布尔表达式,这些…...
解决Windows下的docker desktop无法启动问题
以管理员权限运行cmd 报错: docker: error during connect: Post http://%2F%2F.%2Fpipe%2Fdocker_engine/v1.40/containers/create: open //./pipe/docker_engine: The system cannot find the file specified. In the default daemon configuration on Windows,…...
LLM生成式 AI 项目生命周期Generative AI project lifecycle
在本课程的其余部分中,您将学习开发和部署LLM驱动应用所需的技巧。在这个视频中,您将了解一个能帮助您完成此工作的生成式AI项目生命周期。此框架列出了从构思到启动项目所需的任务。到课程结束时,您应该对您需要做的重要决策、可能遇到的困难…...
java高并发系列 - 第13天:JUC中的Condition对象
java高并发系列 - 第13天:JUC中的Condition对象 java高并发系列第13篇文章 本文内容 synchronized中实现线程等待和唤醒Condition简介及常用方法介绍及相关示例使用Condition实现生产者消费者使用Condition实现同步阻塞队列Object对象中的wait(),notify()方法,用于线程等待…...
【TTY子系统】printf与printk深入驱动解析
tty子系统解析 tty子系统是一个庞大且复杂,也是内核维护者所头大的子系统。 At a first glance, the TTY layer wouldn’t seem like it should be all that challenging. It is, after all, just a simple char device which is charged with transferring byte-o…...
无涯教程-PHP - 全局变量函数
全局变量 与局部变量相反,可以在程序的任何部分访问全局变量。通过将关键字 GLOBAL 放置在应被识别为全局变量的前面,可以很方便地实现这一目标。 <?php$somevar15;function addit() {GLOBAL $somevar;$somevar;print "Somevar is $somevar";}addit(); ?> …...
shell脚本之循环语句
循环语句 循环含义 将某代码段重复运行多次,通常有进入循环的条件和退出循环的条件 for循环语句 一般知道循环次数使用for循环 第一类 格式1: for名称 in 取值次数;do;done; 格式2: for 名称 in {取值列表} do done# 打印20次 for i i…...
派森 #P122. 峰值查找
描述 给定一个长度为n的列表nums,请你找到峰值并返回其索引。数组可能包含多个峰值,在这种情况下,返回任何一个所在位置即可。 (1)峰值元素是指其值严格大于左右相邻值的元素。严格大于即不能有等于; &…...
基础网络详解4--HTTP CookieSession 思考
一、cookie技术思考 一台多用户浏览器发起了三笔请求,将某款产品放入购物车中,A一次,选择了篮球;B两次,第一次选了足球,第二次选了钢笔。如何确认选择篮球、足球、钢笔的请求属于谁呢?如果不确认…...
ARM调试接口技术:SWD与JTAG协议切换机制详解
1. ARM调试接口技术深度解析 在嵌入式系统开发领域,调试接口如同工程师的"听诊器",是连接开发环境与目标芯片的重要通道。作为行业标准,ARM架构提供了两种主流的调试协议:串行线调试(SWD)和JTAG。这两种协议各有特点&am…...
AI智能体如何通过MCP协议标准化调用外部工具
1. 项目概述:当AI智能体学会“使用工具” 最近在探索AI智能体开发时,我遇到了一个非常有意思的项目: agentsimdev/agentsim-mcp 。乍一看这个名字,可能有些朋友会感到困惑,这“MCP”是什么?是“模型上下文…...
SDEP协议解析:嵌入式通信中的总线无关二进制封装方案
1. SDEP协议:嵌入式通信的“通用语言”在嵌入式开发和物联网设备互联的世界里,通信协议就像是设备之间对话的“语言”。当你的微控制器(MCU)需要通过蓝牙低功耗(BLE)模块与手机或云端通信时,你可…...
KokonutUI:基于React的现代化UI组件库设计与实践
1. 项目概述:一个为现代Web应用而生的UI组件库如果你最近在寻找一个既现代又实用的React UI组件库,那么kokonutui这个名字可能已经出现在你的视野里了。它不是一个横空出世、试图颠覆一切的庞然大物,而更像是一个由一线开发者精心打磨的工具箱…...
AI分类及AI大模型分类
什么是AI AI的核心目标是让机器能够执行通常需要人类智能的任务,例如语言理解、突袭图像图识别、复杂问题解决等。 早期阶段:以规则为基础的专家系统,依赖预设的逻辑和规则。机器学习时代:通过数据训练模型,使机器能够…...
分布式电动汽车转向稳定性控制【附代码】
✨ 长期致力于分布式电动汽车、控制系统、参数估计、转向稳定性研究工作,擅长数据搜集与处理、建模仿真、程序编写、仿真设计。 ✅ 专业定制毕设、代码 ✅ 如需沟通交流,点击《获取方式》 (1)基于扩展卡尔曼滤波的车辆状态参数联合…...
别再死记硬背MPNN公式了!用“邻居传纸条”的比喻彻底搞懂消息传递神经网络
用"班级传纸条"游戏理解消息传递神经网络 想象一下,你正坐在教室里,老师突然宣布要进行一个特殊的游戏——每个同学可以给任意一位朋友传递一张写有秘密信息的纸条。这个看似简单的游戏,恰恰揭示了人工智能领域最前沿的图神经网络(…...
ARM架构TRFCR寄存器:调试与性能分析核心
1. ARM架构TRFCR寄存器深度解析在ARMv8/v9架构的调试系统中,Trace Filter Control Register(TRFCR)扮演着至关重要的角色。这个32位系统寄存器专门用于控制处理器在EL1(特权模式)下的跟踪功能,是性能分析和…...
【NotebookLM数据可视化黄金法则】:20年AI工具实战总结的7大避坑指南
更多请点击: https://intelliparadigm.com 第一章:NotebookLM数据可视化的核心价值与适用边界 NotebookLM 是 Google 推出的基于用户上传文档构建语义理解模型的实验性工具,其原生不支持传统图表渲染,但可通过导出结构化数据并联…...
SuperMap GIS 三维性能跃迁:从硬件选型到显卡驱动的深度调优指南
1. 为什么你的SuperMap三维场景总是卡顿? 每次打开大型三维场景时,是不是总遇到画面卡顿、加载缓慢的问题?作为从业十年的GIS工程师,我见过太多项目因为硬件配置不当导致性能浪费的情况。上周刚帮某规划院优化了一个城市级三维项目…...
