Spark 的 Http Broadcast 和 Torrent Broadcast 广播实现类的对比
在 Apache Spark 中,广播机制用于高效地将小型只读数据分发到集群中的各个执行器(Executor)。Spark 中主要有两种不同的广播实现方式:Http Broadcast 和 Torrent Broadcast。这两种方式的核心目标都是将数据高效地分发给所有工作节点,但它们在实现方式、效率和性能方面存在显著差异。以下是对这两种机制的详细对比:
1. 实现机制
- Http Broadcast:
- Http Broadcast 是早期的广播机制,Spark 会在驱动节点上启动一个内嵌的 HTTP 服务器,并将广播的数据上传到该服务器。
- 每个执行器在需要广播数据时,会通过 HTTP 请求从驱动程序的 HTTP 服务器下载数据。
- 驱动程序充当单一数据源,所有执行器从该源获取广播数据。
- Torrent Broadcast:
- Torrent Broadcast 是 Spark 1.5 版本引入的默认广播机制,采用类似 BitTorrent 的分布式数据传输方式。
- 驱动程序首先将广播数据分片成多个小块(chunks),这些块会首先发送给部分执行器。
- 执行器在接收到数据块后,会同时处理这些数据块,并像种子一样,将数据块进一步分发给其他执行器。这种方式形成链式的广播,提高了并发性。
- 每个执行器不仅仅从驱动获取数据,也可以从其他已经持有数据的执行器获取数据。
2. 效率与扩展性
-
Http Broadcast:
- 效率较低:由于每个执行器都必须从驱动节点的 HTTP 服务器下载广播数据,当集群规模较大时,驱动程序会成为瓶颈,导致广播的效率下降。驱动程序的带宽和计算资源都会受到限制,不能充分利用集群的带宽资源。
- 可扩展性差:在大规模集群中,多个执行器同时从驱动程序下载数据时会产生高负载,驱动程序可能会因为过多的网络请求而过载。这种集中式的广播方式难以扩展到大型集群。
-
Torrent Broadcast:
- 高效并发传输:Torrent Broadcast 通过将数据分块,并在多个节点之间形成链式传播,显著提高了广播数据的并发传输效率。每个执行器不必都从驱动程序获取数据,可以从其他执行器获取数据块,从而减轻了驱动节点的负载。
- 可扩展性强:由于数据传输是分布式的,不依赖于单一的驱动程序,Torrent Broadcast 在大规模集群中能够充分利用网络带宽资源,具备更好的扩展性。
3. 网络负载
- Http Broadcast:
- 集中式负载:驱动程序承载了所有广播数据的下载请求,因此网络负载集中在驱动节点。网络传输压力集中在驱动程序与各执行器之间的网络链路,容易形成传输瓶颈。
- Torrent Broadcast:
- 分布式负载:数据块通过多个节点以链式方式传播,网络负载分散在各个执行器之间。每个执行器既是数据的消费者也是数据的传播者,网络负载能够均匀分配,避免了集中式的网络瓶颈。
4. 容错性
- Http Broadcast:
- 容错性低:如果驱动程序的 HTTP 服务器出现故障,所有广播数据的分发都将受到影响。此时,广播任务可能会失败,甚至导致作业无法完成。
- Torrent Broadcast:
- 容错性强:由于 Torrent Broadcast 采用分布式传播方式,即使部分节点出现故障,其他节点仍可以继续传播数据。Spark 可以通过重试从其他节点获取数据块,从而具备更强的容错能力。
5. 驱动程序的负担
- Http Broadcast:
- 驱动程序压力大:由于所有执行器都从驱动节点的 HTTP 服务器下载广播数据,随着集群规模的增长,驱动程序承受的负载会显著增加。
- Torrent Broadcast:
- 驱动程序压力小:驱动程序只需要向一部分执行器发送数据块,之后这些执行器会承担起数据的传播工作。驱动节点的负载大大减轻,尤其是在大规模集群中表现尤为明显。
6. 使用场景
- Http Broadcast:
- 适用于较小规模的集群和广播数据量较小的场景。在这些场景中,驱动程序的负载不会太重,且广播效率能够满足要求。
- Torrent Broadcast:
- 适用于大规模集群和需要频繁广播大量数据的场景。Torrent Broadcast 能更好地利用集群的网络资源,减轻驱动节点的压力,提升整体广播效率。
7. 默认设置
-
Http Broadcast:在 Spark 1.5 版本之前,Spark 默认使用 Http Broadcast 作为广播机制。
-
Torrent Broadcast:自 Spark 1.5 起,Torrent Broadcast 成为默认的广播机制。该机制在大规模分布式计算环境中的性能要远远优于 Http Broadcast。
8. 性能对比
- Http Broadcast:
- 延迟较高:由于所有执行器都从同一源获取数据,当执行器数量较多时,网络拥塞和等待时间会显著增加。
- Torrent Broadcast:
- 延迟较低:通过分块并行传输,多个执行器可以同时接收不同的数据块,并相互之间传递数据,传输效率大大提升,延迟减少。
总结对比表
| 特性 | Http Broadcast | Torrent Broadcast |
|---|---|---|
| 实现方式 | 中央化的 HTTP 服务器传输 | 分布式数据块传输,链式传播 |
| 效率 | 随着集群规模增大,效率迅速下降 | 高效并发,适合大规模集群 |
| 可扩展性 | 可扩展性差 | 可扩展性强,适合大型集群 |
| 网络负载 | 网络负载集中在驱动节点 | 网络负载分散在多个节点之间 |
| 容错性 | 容错性较差,驱动程序故障会导致广播失败 | 容错性强,部分节点故障不会影响整体传播 |
| 驱动程序负担 | 驱动程序负载较高 | 驱动程序负担轻,依赖分布式节点传播 |
| 适用场景 | 小规模集群和小数据集 | 大规模集群和频繁的大数据广播 |
| Spark 默认方式 | Spark 1.5 之前 | Spark 1.5 之后 |
总结
- Http Broadcast 是 Spark 早期采用的广播机制,它简单且适合小规模集群,但随着集群规模的增大,它的效率和可扩展性会显著下降。
- Torrent Broadcast 是更现代的广播机制,通过分块并行传输、分布式传播和链式分发,大大提高了广播数据的传输效率,并且适用于大规模集群的场景。因此,自 Spark 1.5 起,Torrent Broadcast 成为了默认的广播机制。
在大规模分布式计算场景中,Torrent Broadcast 具有明显的性能优势,减少了驱动程序的负载,提升了广播的效率和容错性。
相关文章:
Spark 的 Http Broadcast 和 Torrent Broadcast 广播实现类的对比
在 Apache Spark 中,广播机制用于高效地将小型只读数据分发到集群中的各个执行器(Executor)。Spark 中主要有两种不同的广播实现方式:Http Broadcast 和 Torrent Broadcast。这两种方式的核心目标都是将数据高效地分发给所有工作节…...
030_Subplot_In_Matlab中多图绘制之subplot函数
基于子图的多图方法 专业的论文中通常涉及到多个有逻辑关系的图拼接在一起,构成相互支持或者对照。所以很早之前,Matlab就有这个子图的函数subplot。 这个函数的基本语义有三类: 在图窗上划分出一个矩形区域建立一个坐标系,并指…...
免费云服务器有什么使用限制和注意事项?
在数字化时代,云计算已经成为许多企业和个人用户的重要工具。对于初创企业、开发者和学生来说,免费的云服务器提供了一个低成本的解决方案,使他们能够进行项目开发、学习和实验。但在使用过程中也存在一些限制和注意事项。以下是主要的使用限…...
3-ZYNQ 折腾记录 -PS_PL AXI Interfaces
Zynq UltraScale MPSoC集成了功能丰富的四核或双核Arm Cortex-A53 MPCore基于处理系统(Processing System, PS)和可编程逻辑(Programmable Logic, PL)的单一设备。 PS和PL可以使用多个接口和其他信号进行紧密或松散的耦合。这使设计人员能够有效地将用户创建的硬件加速器和其他…...
总结test
1.IO流 |-- 字节流操作任何类型文件|-- 字符流操作纯字符类文件|-- BIO 传统IO流,阻塞型的,也就是BIO,当执行IO流时,CPU只能等待执行完当前任务,才能去执行其他线程任务|-- NIO非阻塞型IO流,CPU可以同时执行…...
在 On hold 期刊 eLife 上发表一篇生信文章需要什么工作量?
生信碱移 科研圈动态 根据弗雷赛斯以及相关媒体最新消息,中科院一区TOP,著名生命科学期刊 eLife [IF: 6.4]已被科睿唯安官方 On hold! ▲ 官网截图。图片来源:https://mjl.clarivate.com/home eLife是一本专注于生物医学和生命科…...
使用Django框架开发企业级Web应用
💖 博客主页:瑕疵的CSDN主页 💻 Gitee主页:瑕疵的gitee主页 🚀 文章专栏:《热点资讯》 使用Django框架开发企业级Web应用 1 引言 2 Django简介 3 安装Python与Django 4 创建Django项目 5 设计应用结构 6 创…...
认识线程 — JavaEE
目录 认识线程(Thread) 1 线程是什么? 2 为什么要有线程 3 进程和线程的区别 区别一 区别二 区别三 区别四 4. Java的线程和操作系统线程的关系 认识线程(Thread) 1 线程是什么? 一个线程就是一个 "执行流"。…...
【C++单调栈】853. 车队|1678
本文涉及的基础知识点 C单调栈 LeetCode853. 车队 在一条单行道上,有 n 辆车开往同一目的地。目的地是几英里以外的 target 。 给定两个整数数组 position 和 speed ,长度都是 n ,其中 position[i] 是第 i 辆车的位置, speed[i…...
第十届文荣奖华丽开幕,郁葱以青春与努力绽放青年演员光芒
10月27日,第十届文荣奖在众人的期待中盛大开启,内地青年女演员郁葱受邀出席,作为国内颇具影响力的影视奖项,文荣奖一直以来都致力于发掘和表彰优秀的影视作品和青年影视人才,为影视行业的发展注入新的活力,…...
CMake 生成器表达式介绍
【写在前面】 生成器表达式在构建系统生成期间进行评估,以生成特定于每个构建配置的信息。它们的形式为 $<...>。例如: target_include_directories(tgt PRIVATE /opt/include/$<CXX_COMPILER_ID>) 这将扩展为 “/opt/include/GNU”、“/opt…...
ubuntu 20.04编译驱动报gcc-12 not found错误
最近在自己安装的Ubuntu 系统上编译自定义驱动,发现无法编译.ko,错误如下: 按照如下操作,发现可以解决,记录下,主要是Ubuntu缺少g-12的包 安装包以后发现可以正常编译...
docker sameersbn/bind dns服务器
1. 安装 #下载docker 镜像 docker pull sameersbn/bind#运行 53端口若被占用会启动失败 docker run --name dns -d --restartalways \ --publish 53:53/tcp \ --publish 53:53/udp \ --publish 10000:10000/tcp \ -v /etc/localtime:/etc/localtime \ -v /data/bind/:/data \…...
错误:无法推送一些引用到 ‘https://gitee.com/chek_kk/python-electron-app.git‘
这个错误提示说明在提交时某个文件的大小超过了 Gitee 仓库的单文件大小限制(100MB)。你需要从Git 历史中彻底移除这个大文件,否则无法推送到远程仓库。 解决步骤 1. 确认大文件信息 使用以下命令找出超过限制的大文件: git re…...
深度剖析美区代理IP的多元应用与优势
在当今数字时代,代理IP(Proxy IP)已成为互联网使用中的一项关键技术。尤其在美区,代理IP在数据采集、网络安全及在线隐私保护等领域发挥着越来越重要的作用。本文将深入探讨代理IP的基本概念、应用场景以及它带来的诸多优势&#…...
基于KV260的基础视频链路通路(MIPI+Demosaic+VDMA)
目录 1. 简介 1.1 要点 1.2 背景 1.2.1 Got stuck 1.2.2 Cant be Initialized 2. Overlay 2.1 参考 Overlay 2.1.1 KV260 Base 2.1.2 Pynq-CV-OV5640 2.2 自建 Overlay 2.2.1 IIC IP 2.2.2 MIPI CSI-2 Rx 2.2.3 AXI4-S Subset 2.2.4 Demosaic 2.2.5 Pixel Pack …...
Uni-App-04
主页开发 保存主页数据 <script> import { indexData, base } from /serviceexport default {data() {return {base, //把服务器基础地址变量设置为数据属性carousels:[], //轮播广告条目列表menuItems:[], //当前用户选中的功能菜单列表activities:[], //最新的…...
ElasticSearch分片
本文内容参考了田雪松老师编著的《Elastic Stack应用宝典》 ElasticSearch作为一个搜索引擎,会存储海量的数据。而存储海量的数据,就要解决如何存储的问题,并且保证数据不会丢失,同时还需要保证数据检索的效率,尽可能…...
spring高手之路
以下是一些可以快速入门Spring的方法: 1. 学习基础知识 阅读官方文档:Spring官方文档是最权威的学习资料。它详细介绍了Spring的各个模块、概念和使用方法。从核心模块开始,了解如依赖注入(DI)和控制反转(…...
工字钢与H型钢有什么区别?90%的工程师都搞错了!
这里为大家做一个详尽的解答:很多人认为工字钢是国内的叫法,H型钢是国外的叫法,其实这个认知是错误的。H型钢和工字钢从形状上来说是不一样的,见下图: 工字钢 工字钢主要分为普通工字钢、轻型工字钢和宽翼缘工字钢。按…...
【2024独家首发】Red Cabbage印相参数矩阵表:17组实测--no stylize值×--sref权重×色域压缩阈值,精准复现植物染料氧化还原曲线
更多请点击: https://intelliparadigm.com 第一章:Red Cabbage印相的化学机理与Midjourney参数映射原理 花青素的pH响应性与图像显影基础 红甘蓝(Red Cabbage)提取液富含花青素(anthocyanin),…...
告别Navicat后,我用DBeaver的这10个设置让效率翻倍(含豆沙绿护眼教程)
从Navicat到DBeaver:10个高效设置与健康护眼方案 当公司技术栈调整要求从Navicat迁移到DBeaver时,许多数据库开发者面临的不仅是工具切换,更是工作习惯的重构。作为一款开源的多数据库管理工具,DBeaver在功能深度和可定制性上其实…...
【信息科学与工程学】【财务管理】 第二十三篇 ICT行业商业逻辑分析框架03
136. 硅光子集成芯片的激光器外延片 行业代码 行业名称 行业级别 产品/服务 商业逻辑核心 投资者类型与代表公司/机构 外部关系类型与关联公司 销售与买卖经营 供应链经营 利益/利润设计/资源绑定/信息宣传 分销商/代理商/关系节点 销售策略、打法与复杂关系网络 3…...
3分钟掌握:网易云音乐无损FLAC批量下载终极指南
3分钟掌握:网易云音乐无损FLAC批量下载终极指南 【免费下载链接】NeteaseCloudMusicFlac 根据网易云音乐的歌单, 下载flac无损音乐到本地.。 项目地址: https://gitcode.com/gh_mirrors/nete/NeteaseCloudMusicFlac 还在为无法保存高品质音乐而烦恼吗&#x…...
英雄联盟智能助手League Akari:重新定义你的游戏体验边界
英雄联盟智能助手League Akari:重新定义你的游戏体验边界 【免费下载链接】League-Toolkit An all-in-one toolkit for LeagueClient. Gathering power 🚀. 项目地址: https://gitcode.com/gh_mirrors/le/League-Toolkit 在英雄联盟的竞技世界中&…...
别再死记硬背了!用Python代码动画演示组合数11个核心性质(附完整源码)
用Python动画拆解组合数:11个核心性质的动态演绎 数学公式总是让人望而生畏?当组合数学遇上Python动画,抽象概念瞬间变得鲜活起来。这不是又一篇枯燥的公式推导文章,而是一场用代码演绎数学之美的视觉盛宴。我们将用matplotlib和…...
ComfyUI图像修复终极指南:5个高效技巧解决安装与使用难题
ComfyUI图像修复终极指南:5个高效技巧解决安装与使用难题 【免费下载链接】comfyui-inpaint-nodes Nodes for better inpainting with ComfyUI: Fooocus inpaint model for SDXL, LaMa, MAT, and various other tools for pre-filling inpaint & outpaint areas…...
OpenClaw赚钱实录:从“养龙虾“到可持续变现的实践指南——OpenClaw一人公司-[一人公司的终极技术栈,从0到变现的完整光谱]
【限时99元】专栏原价299元,在专栏未完结的持续更新期间享受99元早鸟价,现在订阅同享后续专栏所有文章! 【专栏介绍】《OpenClaw赚钱实录:从“养龙虾“到可持续变现的实践指南》专栏介绍 有任何疑问均可联系博主微信(微信号:NeumannAI),作者将亲自解答并持续优化文章内…...
构建企业级日志监控:免费Syslog服务器部署方案
构建企业级日志监控:免费Syslog服务器部署方案 【免费下载链接】visualsyslog Syslog Server for Windows with a graphical user interface 项目地址: https://gitcode.com/gh_mirrors/vi/visualsyslog 在分布式系统架构中,网络设备、服务器和应…...
文献管理软件//Zotero文献导入实战:从新手到高手的五种核心路径(九)
1. 从零开始:Zotero文献导入的底层逻辑与核心价值 第一次接触Zotero时,我盯着空荡荡的文献库发呆了半小时——就像刚搬进新家的人面对空房间,明明知道需要填满它,却不知从何下手。文献管理软件的核心价值在于建立个人知识库&#…...
