面试六--TCP粘包问题

1.流式传输协议

        流式传输协议(Streaming Protocol)是一种用于在网络上传输数据的通信协议,它允许数据以连续的流的形式进行传输,而不是一次性发送完整的数据包。流式传输协议即协议的内容是像流水一样的字节流,内容与内容之间没有明确的分界标志。

流式传输协议的关键特点包括:

1. 实时性:数据可以边生成边传输,无需等待所有数据都准备好后再发送。

2. 低延迟:流式传输减少了数据传输的延迟,使得接收端可以更快地接收到数据。

3. 可扩展性:流式传输协议通常设计为可以处理大量并发连接,这对于需要同时服务多个用户的服务尤其重要。

4. 容错性:即使在网络不稳定的情况下,流式传输协议也能够通过重传丢失的数据包来维持数据的完整性。

5. 按需传输:流式传输可以根据接收端的请求动态调整传输的数据,例如,视频流可以根据用户的带宽和设备性能调整分辨率。

2. TCP粘包问题

        粘包出现的根本原因是不确定消息的边界。接收端在面对"无边无际"的二进制流的时候,根本不知道收了多少 01 才算一个消息。一不小心拿多了就说是粘包。其实粘包根本不是 TCP 的问题,是使用者对于 TCP 的理解有误导致的一个问题。TCP 的首部没有表示数据长度的字段

        发送方在发送数据时未按照正确的消息边界进行划分,或者接收方在接收数据时未按照正确的方式进行解析和处理。

        2.1 出现的原因

https://segmentfault.com/a/1190000039691657

(1)发送方原因

TCP默认使用Nagle算法(主要作用:减少网络中报文段的数量),而Nagle算法主要做两件事:

只有上一个分组得到确认,才会发送下一个分组
收集多个小分组,在一个确认到来时一起发送
Nagle算法造成了发送方可能会出现粘包问题

(2)接收方原因

TCP接收到数据包时,并不会马上交到应用层进行处理,或者说应用层并不会立即处理。实际上,TCP将接收到的数据包保存在接收缓存里,然后应用程序主动从缓存读取收到的分组。这样一来,如果TCP接收数据包到缓存的速度大于应用程序从缓存中读取数据包的速度,多个包就会被缓存,应用程序就有可能读取到多个首尾相接粘到一起的包。

        2.2 解决方法

TCP数据粘包的处理 | 爱编程的大丙 (subingwen.cn)

1. 使用标准的应用层协议(比如:http、htps)来封装要传输的不定长的数据包

2. 加入标志,但是在接收的时候按字节寻找标志的时候,浪费时间

3. 加入数据头,表示数据长度

 

3. udp不会发生粘包

硬核图解|tcp为什么会粘包?背后的原因让人暖心 - golang小白成长记 - SegmentFault 思否

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/537887.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

【Flutter】报错Target of URI doesn‘t exist ‘package:flutter/material.dart‘

运行别人项目 包无法导入报错:Target of URI doesn’t exist ‘package:flutter/material.dart’ 解决方法 flutter packages get成功 不会报错

BIT-1-深度剖析数据在内存中的存储(C语言进阶)

本章重点 数据类型详细介绍 整形在内存中的存储:原码、反码、补码大小端字节序介绍及判断浮点型在内存中的存储解析 1. 数据类型介绍 前面我们已经学习了基本的内置类型: char //字符数据类型 short //短整型 int //整形 long //长整型…

如何在Windows系统安装Node.js环境并制作html页面发布公网远程访问?

文章目录 前言1.安装Node.js环境2.创建node.js服务3. 访问node.js 服务4.内网穿透4.1 安装配置cpolar内网穿透4.2 创建隧道映射本地端口 5.固定公网地址 前言 Node.js 是能够在服务器端运行 JavaScript 的开放源代码、跨平台运行环境。Node.js 由 OpenJS Foundation&#xff0…

代码随想录算法训练营第八天|344. 反转字符串

344. 反转字符串 已解答 简单 相关标签 相关企业 提示 编写一个函数,其作用是将输入的字符串反转过来。输入字符串以字符数组 s 的形式给出。 不要给另外的数组分配额外的空间,你必须原地修改输入数组、使用 O(1) 的额外空间解决这一问题。 示例 1&#…

供应IMX290LQR-C芯片现货

长期供应各品牌芯片现货,SONY索尼SONY索尼CMOS/CCD芯片全系列全新现货优势出: IMX225LQR-C IMX415-AAQR-C IMX290LQR-C imx273llr-C IMX397CLN-C IMX637-AAMJ-C IMX647-AAMJ-C IMX991-A***-C IMX991-AABJ-C IMX287LLR-C IMX287LQR-C IMX297L…

缓存更新策略(旁路更新策略)

文章目录 前言旁路更新策略读操作写操作 总结 前言 Redis ,是基于内存的数据库,我们常将其做为缓存,在数据访问时,达到更高的性能。 那么该如何使用 Redis 做为缓存呢?本篇文章介绍缓存的更新策略——Cache-Aside&am…

创新指南 | 工业软件企业如何采用 C端线上推广 与免费试用策略快速扩展工程师用户群

在工业4.0的浪潮下,工业软件企业正站在数字化转型的风口浪尖,面对传统B端市场的增长瓶颈,企业急需找寻新的增长动力。在此背景下,转向C端市场,利用线上渠道直接触达终端工程师用户,通过免费试用模式快速扩展…

【数学建模】熵权法 Python代码

熵权法是一种客观的赋权方法,它可以靠数据本身得出权重。 依据的原理:指标的变异程度越小,所反映的信息量也越少,其对应的权值也应该越低。 import numpy as np#自定义对数函数mylog,用于处理输入数组中的0元素 def m…

义乌购关键字搜索API接口技术详解与代码示例

义乌购关键字搜索API接口技术详解与代码示例 在电子商务蓬勃发展的今天,义乌购作为国内知名的批发市场平台,为广大商家和消费者提供了丰富的商品资源。为了方便开发者快速接入义乌购平台,实现商品信息的搜索与获取,义乌购开放了关…

数码管的静态显示(二)

1.原理 要按照上图的顺序传递位选和段选的数据。 因为q0是最高位,共阳极数码管结构是dp....a,所以应该先传入低位a,而a在上图中的8段2进制编码中是seg[7],所以段选信号的顺序是seg[0],...seg[7]。 因为输出信号是两个时钟&#x…

HTML CSS入门:从基础到实践

🌐 HTML & CSS入门:从基础到实践 🎨 📖 引言 HTML和CSS是构建网页的基石。HTML(超文本标记语言)用于创建网页内容,而CSS(层叠样式表)则用于美化这些内容。无论你是…

unity学习(57)——选择角色界面--删除角色2

1.客户端添加点击按钮所触发的事件&#xff0c;在selectMenu界面中增加myDelete函数&#xff0c;当点击“删除角色”按钮时触发该函数的内容。 public void myDelete() {string message nowPlayer.id;//string m Coding<StringDTO>.encode(message);NetWorkScript.get…