CPU 和带宽之间的时空权衡
在 从一道面试题看 TCP 的吞吐极限 一文的开始,我提到在环形域上两个数字比较大小的前提是在同一个半圆内,进而得到滑动窗口最大值被限定在一个环形域的一半。
现在来看更为基本的问题。如果序列号只有 2bit,甚至仅有 1bit,保序传输的吞吐极限是多少?
由于时间戳是一个天然的单调递增标识,假设时间戳可达任意精度,只要为报文打时间戳即可,甚至连 1bit 的序列号都不需要,时间戳本身就是序列号。这种情况下,极限吞吐没有上限。
但由于处理器指令存在最小粒度,且调度周期存在最小时间,时间戳精度毕竟有限,可称之为时间戳量子,在一个时间戳量子内发出去的报文就需要序列号来标识顺序,于是序列号空间越大,一个时间戳量子内能发出去的数据量越大,支持的吞吐越大。
总吞吐极限正比于时间戳量子大小和序列号空间的乘积。
这里存在一个时空权衡。时间戳量子越小,处理器开销越大,所需的序列号空间越小,时间换空间,反之,时间戳量子越大,处理器开销越小,但所需序列号空间越大,越消耗有效带宽(报头变长了),空间换时间。
问题是,时间戳量子真的需要和时间关联吗?它只是一个单调递增的序号,只需要保证协议序列号越过一个半圆时让它加 1 即可。但如果它果真不与时间关联,这个序号就只是扩展了序列号空间而已,sender 也就无法精确控制吞吐,因此,时间量子的大小本身就是吞吐的因子。除了时空权衡,但凡量子性质,都有测不准的量,不管怎么说,你越想获取精确的 pacing 快照,对测量吞吐的干扰越大。
序列号 + 时间戳(或任何二级序号,whatever)分级的序号编码方式简化了 receiver 重排序,平坦的序列号一股脑发送,receiver 需要在一个平坦的空间重排序,O(NlgN) 中的 N 数值较大,但分级序列号只需多趟归并,N 减小很多,减轻了排序负担,由于同一链路传输过程大概率保序,分级序号将排序过程平滑在传输过程中。
分级序号非常便于多路径传输,比如 MPTCP,MPQUIC,SRD。
浙江温州皮鞋湿,下雨进水不会胖。
相关文章:
CPU 和带宽之间的时空权衡
在 从一道面试题看 TCP 的吞吐极限 一文的开始,我提到在环形域上两个数字比较大小的前提是在同一个半圆内,进而得到滑动窗口最大值被限定在一个环形域的一半。 现在来看更为基本的问题。如果序列号只有 2bit,甚至仅有 1bit,保序传…...
ES+Redis+MySQL,这个高可用架构设计太顶了!
一、背景 会员系统是一种基础系统,跟公司所有业务线的下单主流程密切相关。如果会员系统出故障,会导致用户无法下单,影响范围是全公司所有业务线。所以,会员系统必须保证高性能、高可用,提供稳定、高效的基础服务。 …...
【Maven】Maven的常用命令
目录 一、Maven的常用命令 1、compile 编译命令 2、test 测试命令 3 、clean 清理命令 4、package 打包命令 5、 install 安装命令 6、Maven 指令的生命周期 二、maven 的概念模型 💟 创作不易,不妨点赞💚评论❤️收藏💙一…...
python的循环结构
python中有for循环和while循环两种形式。 1. for 循环 可以用for循环来遍历不同类型的对象,如数组、列表、元组、字典、集合或字符串,并对每个元素执行一段代码。 1.1 数组的for循环 用for循环遍历一个数组,并打印出每个元素:…...
五种Python中字典的高级用法
1. 引言 Python中的字典是一种非常有用的数据结构,它允许大家存储键值对。通常来说,字典灵活、高效且易于使用,是Python中最常用的数据结构之一。字典通常被用于统计频率、映射值等任务,但在Python中使用字典也可以达到许多意想不…...
[蓝桥杯单片机]——八到十一届初赛决赛客观题
第八届初赛 一、填空题 采用外部12MHz晶振,经过系统12分频时定时器获得最大定时长度,此时定时器定时脉冲为1MHz,周期为1s,而定时器计时均为16位加法计数器,即计时长度为。 二、 选择题 ①带阻滤波器是指能通过大多数频…...
多线程(初阶)
文章目录一.初始线程(Thread)1.1.线程的概念1.2.线程的优势1.2.1.线程比进程更轻量1.2.2.并发编程1.3.线程和进程的区别二.Thread类方法2.1. java 中创建线程的方法2.1.1. 继承Thread,重写run2.1.2. 实现Ruuable接口2.1.3. 使用匿名内部类,继承Thread2.1.4.使用匿名内部类,实现…...
【Vue从入门到进阶】Node.js安装与配置
✅作者简介:CSDN一位小博主,正在学习前端,欢迎大家一起来交流学习🏆 📃个人主页:白月光777的CSDN博客 🔥系列专栏:Vue从入门到进阶 💬个人格言:但行好事&…...
python 正则使用详解
python 正则使用详解什么是正则在 python 中使用正则一些正则的定义python 正则的方法match 从字符串开头匹配正则返回的结果分析(重要)fullmatch 严格匹配整个字符串search 任意位置开始匹配sub 替换匹配内容subn 以元组方式返回替换结果split 正则切割…...
一个深度学习项目需要什么
DataLoader1.数据预处理在将数据提供给模型之前,DataLoader需要对数据进行预处理。预处理可以包括数据增强、归一化、裁剪、缩放等操作。这些操作可以提高模型的性能和准确度。在处理点云数据时,可以通过最远点下采样到固定的点数。2.读取标签文件我 1 2…...
【Java进阶篇】—— 常用类和基础API
一、String类 1.1 String的特性 java.lang.String 类代表字符串,由final关键字修饰,在赋值后不能改变(常量),不能继承String类String 对象的字符内容是存储在一个字符数组 value[]中的 我们来看一下String在JDK8中的…...
手敲Mybatis(六)-反射工具天花板
历时漫长的岁月,终于鼓起勇气继续研究Mybatis的反射工具类们,简直就是把反射玩出花,但是理解起来还是很有难度的,涉及的内容代码也颇多,所以花费时间也比较浩大,不过当了解套路每个类的功能也好,…...
内含18禁~~关于自学\跳槽\转行做网络安全行业的一些建议
作者:Eason_LYC 悲观者预言失败,十言九中。 乐观者创造奇迹,一次即可。 一个人的价值,在于他所拥有的。所以可以不学无术,但不能一无所有! 技术领域:WEB安全、网络攻防 关注WEB安全、网络攻防。…...
春分策划×运维老王主讲:CMDB数据运营精准化公开课启动报名啦!
『CMDB数据运营精准化』 公开直播课 要来了! 👆扫描海报二维码,预约直播 CMDB似乎是运维中永恒的老话题。 提到CMDB很多人都是又爱又恨,爱的是它给我们提供了一个美好的未来,有了CMDB我们可以解决诸多运维中的难题。…...
制作INCA和CANape通用的A2L
文章目录 前言制作A2LA2ML定义MOD_COMMON定义MOD_PAR定义MEMORY_SEGMENTTransportLayer定义PROTOCOL_LAYERDAQ总结前言 由于INCA和CANape是两个不同的公司对XCP协议的实现,所以A2L中也会有不一样的地方,但是在标定时若每次都用两个A2L,是非常不方便的,本文介绍如何设计A2L…...
Python人脸识别
#头文件:import cv2 as cvimport numpy as npimport osfrom PIL import Imageimport xlsxwriterimport psutilimport time#人脸录入def get_image_name(name):name_map {f.split(.)[1]:int(f.split(.)[0]) for f in os.listdir("./picture")}if not name…...
我用Python写了一个下载网站所有内容的软件,可见即可下,室友表示非常好用
Python 写一个下载网站内容的GUI工具,所有内容都能下载,真的太方便了!前言本次要实现的功能效果展示代码实战获取数据GUI部分最后前言 哈喽大家好,我是轻松。 今天我们分享一个用Python写下载视频弹幕评论的代码。 之前自游写了…...
【M365运维】扩充OneDrive存储空间
【问题】E3,E5等订阅许可下,默认的OneDrive存储空间为 1TB,满了之后该如何扩充?【解决】1.运行Powershell2. 链接到Sharepoint Online: Connect-SPOSerivce -url https://<这里通常是公司名>-admin.sharepoint.com3. 定义三个扩充空间时…...
hashcat(爆破工具,支持GPU,精)
目录 简介 分类 参数 -m hash的类型 -a 攻击方式 掩码 使用方法 字典破解 简介 虽然John the R...
【机器学习】什么是监督学习、半监督学习、无监督学习、自监督学习以及弱监督学习
监督学习(Supervised Learning):利用大量的标注数据来训练模型,模型最终学习到输入与输出标签之间的相关性。半监督学习(Semi- supervised Learning):利用少量有标签数据和大量无标签数据来训练…...
神经渲染新范式:体素网格技术全解析与实战指南
神经渲染新范式:体素网格技术全解析与实战指南 引言 在追求极致真实感与实时交互的3D数字世界中,神经渲染技术正掀起一场革命。其中,神经体素网格作为神经辐射场(NeRF)与显式体素表示融合的产物,以其在高…...
开源中间件IoTDM:破解物联网数据孤岛,实现异构设备统一管理
1. 项目概述:开源中间件如何成为物联网的“粘合剂”在物联网(IoT)领域摸爬滚打了十几年,我见过太多“数据孤岛”的困境。智能家居、工业传感器、可穿戴设备……每个设备、每个平台都像一座座信息孤岛,数据格式五花八门…...
RT-DTER最新创新改进系列:融合BoTNet模块,ResNet的最后三个的卷积层替换成MHSA层,融合CNN+自然语言处理技术的优势,提升检测效果!打造创新点!!!
RT-DTER最新创新改进系列:融合BoTNet模块,ResNet的最后三个的卷积层替换成MHSA层,融合CNN自然语言处理技术的优势,提升检测效果!打造创新点!!! 购买相关资料后畅享一对一答疑&#…...
Java AI开发实战:基于ai4j的低版本JDK大模型集成与Agent构建指南
1. 项目概述与定位如果你是一个Java开发者,最近想在自己的项目里集成大模型能力,或者想搞点AI Agent的自动化流程,大概率会面临一个选择难题:是用Spring AI,还是LangChain4j?前者对Spring Boot 3.x和Java 1…...
Redis分布式锁进阶第五十七篇
Redis分布式锁进阶第二十五篇:联锁深度拆解 多资源交叉死锁根治 复杂业务多级加锁绝对有序方案一、本篇前置衔接 第二十四篇我们完成了全系列终局复盘,整理了故障排查SOP与企业级落地铁律。常规单资源锁、热点分片锁、隔离锁全部讲透,但真实…...
Playwright MCP终极指南:让大语言模型拥有浏览器自动化的超能力
Playwright MCP终极指南:让大语言模型拥有浏览器自动化的超能力 【免费下载链接】playwright-mcp Playwright MCP server 项目地址: https://gitcode.com/gh_mirrors/pl/playwright-mcp Playwright MCP(Model Context Protocol)是微软…...
ARM虚拟化关键寄存器HIFAR与HMAIR详解
1. ARM架构中的HIFAR与HMAIR寄存器概述 在ARMv7和ARMv8架构的虚拟化扩展中,Hyp模式(即EL2)提供了一套完整的系统寄存器来支持虚拟化功能。其中HIFAR(Hyp Instruction Fault Address Register)和HMAIR(Hyp M…...
Windows HEIC缩略图终极指南:3分钟让iPhone照片在资源管理器完美预览
Windows HEIC缩略图终极指南:3分钟让iPhone照片在资源管理器完美预览 【免费下载链接】windows-heic-thumbnails Enable Windows Explorer to display thumbnails for HEIC/HEIF files 项目地址: https://gitcode.com/gh_mirrors/wi/windows-heic-thumbnails …...
混合量子-经典工作流编排的云原生实践
1. 混合量子-经典工作流编排的挑战与机遇量子计算正从实验室走向实际应用,但当前NISQ(Noisy Intermediate-Scale Quantum)时代的量子设备仍面临量子比特数量有限、噪声干扰强等限制。这使得混合量子-经典工作流(Hybrid Quantum–C…...
copaw1.1:非侵入式调试与性能分析工具实战指南
1. 项目概述与核心价值最近在折腾一个挺有意思的开源项目,叫copaw1.1,是mattchentj-debug这个仓库下的一个工具。别看它名字有点抽象,其实它是一个专门用来辅助调试和性能分析的“瑞士军刀”。简单来说,它能在你运行程序的时候&am…...
