当前位置: 首页 > article >正文

MPTCP 聚合吞吐

只破不立假把式,前面连续喷 MPTCP 是个错误,今天说说如何克服。

到底谁在阻碍 MPTCP 聚合吞吐一定要搞清楚,是算法硬伤,是数据不足。前文说过,将一个窗口内的数据多路径 spray 有损吞吐,想要聚合吞吐,非得按窗口 spray 不可。这很容易理解,一条路径窗口填满,不可继续发送时,其它路径接力,方可聚合能量。尽量避免同步协调,串接合力总是比并联来得容易。

但必须注意,子路径必须不能太异构,聚合 Wi-Fi,5G,4G,想都别想,不是说不能提升,而是不划算。我并没说 MPTCP 无法聚合绝对吞吐,我始终在说,用 MPTCP 这样做不值得,如果能不用 MPTCP 达到等价效果(比如用两条标准 TCP 流),性价比则更高。

考虑异构子路径,同理,一条路径不能继续再发时另外的路径接力,困难在于两点:

  • 何时不能继续发送;
  • 原路径等待是否比另外的路径更划算;

这两点困难随着路径异构而加强,比如,如果将接下来的数据调度到一条延时很高的子路径,反而不如原路径等待,如果子路径丢包率高,重传时延亦叠加在内,反而得不偿失了。这些实际困难仅凭 TCP 层面的信息根本无法克服,我就不再重复证明。

数据不足比算法硬伤更严重,所谓巧妇难为无米之炊,与没有 buffer 便无法公平收敛一样,没有足够的数据,调度策略就不能发挥作用,比方说我设计的慢路径倒着发的策略,本意是笨鸟先飞,如果发送队列只有 1,2,3 这 3 个数据,慢路径发 3 就体现不出有多先。

说几个极好的动力叠加的例子。

端午当天参加了亲子龙舟赛。第一局就输了。想起我优化 MPTCP 的教训,第二局预备,我大喊 “所有小学幼儿园小朋友,收起浆,浆不要入水!”,第二局就赢了,但小朋友们也缺失了体验,这怪我。

这么多人频率,方向,力道均一致才能叠加速度,频率不一致会减速,方向,左右力道不一致会减速并跑偏。非常费力,但并不意味着力大就快,后面力量小了或者慢了就会阻碍前面,力量并不能叠加,反而掣肘卸力。这就是最形象的多路径传输优化要点。

再说高铁动车组,多节车厢同时提供动力需要对这些动力同步协调,如果动力加速度稍有不同,就会有损车钩,相当于不同的车厢不断冲撞拉开,这还不如让多节车厢分别自己开,所以高铁的动力控制协调系统非常重要。

风力发电机组是另一个例子,当本质上无法叠加风向和风力时,就分别运行而叠加结果,不至于并行卸力。

无论如何,涉及聚合,叠加的案例,都不是简单的加法,都需要方向的一致性,同步协调性,结构稳定性三要素,而作为端到端协议,TCP 天然缺失同步协调性和结构稳定性,这些是尽力而为网络的属性特征,TCP/IP 并不具备任何调优支撑,任何的优化都可以说是粗暴的运气。

而用这个天然不可优化的尽力而为网络去适配数据中心高速网络的任何设计必然携带天然缺陷,要用不同的思路,总之 TCP/IP 向左,高速网络向右就对了。这个颇具哲学意味的话题,下周再谈。

浙江温州皮鞋湿,下雨进水不会胖。

http://www.lryc.cn/news/2396839.html

相关文章:

  • JavaScript性能优化实战技术文章大纲
  • LabelImg: 开源图像标注工具指南
  • 计算机网络 TCP篇常见面试题总结
  • 树欲静而风不止,子欲养而亲不待
  • Kotlin中的::操作符详解
  • 【Linux】(1)—进程概念-③Linux进程概念与PCB
  • 神经网络中的梯度消失与梯度爆炸
  • 深入详解编译与链接:翻译环境和运行环境,翻译环境:预编译+编译+汇编+链接,运行环境
  • 系统架构设计师案例分析----经典架构风格特点
  • 基于大模型的急性乳腺炎全病程风险预测与综合治疗方案研究
  • HTML实战:爱心图的实现
  • 定时任务:springboot集成xxl-job-core(二)
  • DeviceNET转EtherCAT网关:医院药房自动化的智能升级神经中枢
  • 一:UML类图
  • 数据库三范式的理解
  • Java 中 MySQL 索引深度解析:面试核心知识点与实战
  • DeepSeek 部署中的常见问题及解决方案
  • Nvidia Intern 笔试回忆
  • 鸿蒙OS基于UniApp的WebRTC视频会议系统实践:从0到1的HarmonyOS适配之路#三方框架 #Uniapp
  • 设计模式之结构型:装饰器模式
  • mysql分布式教程
  • MySQL安装及启用详细教程(Windows版)
  • Vue3.5 企业级管理系统实战(二十一):菜单权限
  • kafka幂等生产者和事务生产者区别
  • 【HarmonyOS Next之旅】DevEco Studio使用指南(二十九) -> 开发云数据库
  • 批量导出CAD属性块信息生成到excel——CAD C#二次开发(插件实现)
  • 可视化大屏如何制作
  • Goreplay最新版本的安装和简单使用
  • Android Studio 解决报错 not support JCEF 记录
  • SMT高速贴片机核心技术深度剖析