Spark中的閉包引用和廣播變數

来源:https://www.cnblogs.com/ji-lei/p/18171507
-Advertisement-
Play Games

閉包引用 概念 所有編程語言都有閉包的概念,閉包就是在一個函數中引用了函數外的變數。 Spark中,普通的變數是在Driver程式中創建的,RDD的計算是在分散式集群中的task程式上進行的。因此,當分散式運算元的函數引用了外部的變數時,Driver會把該變數序列化後通過網路發送給每一個task(只針 ...


閉包引用

概念

所有編程語言都有閉包的概念,閉包就是在一個函數中引用了函數外的變數。

Spark中,普通的變數是在Driver程式中創建的,RDD的計算是在分散式集群中的task程式上進行的。因此,當分散式運算元的函數引用了外部的變數時,Driver會把該變數序列化後通過網路發送給每一個task(只針對普通對象)。

spark中所謂"閉包引用",只是看起來類似各種編程語言中的閉包。而本質上就是對某個對象進行序列化+複製,即Driver把分散式運算元中引用的外部變數序列化後,發送給每個task來使用。

在閉包函數內對外部變數進行修改,閉包外的變數並不會改變。因為在閉包函數內的修改,只是在task上對複製過來的閉包對象副本的修改,並不會影響到driver端的原對象,他們是存在於兩台機器上的獨立的文件,互不影響。

好處

應用於大表join小表的場景,將小表數據(字典表、維度表)發送到大表所在節點的記憶體中,在map階段完成join,無需通過兩個rdd去join,省去了shuffle操作。

適用條件

1、閉包引用的對象,必須實現序列化介面:extends Serializable。

2、被引用的對象,數據量不能太大,否則會導致task端記憶體溢出。

單例對象的閉包引用

單例對象(object對象)只在每個executor進程中持有一份,由其中的多個task線程共用。不要在task中對單例對象進行修改操作,否則會產生線程安全問題。而普通對象在每個task線程中都持有一份,不存線上程安全問題。

廣播變數

閉包引用的場景中,Spark為每個task都複製了一份它需要的數據,當數據量較大且task較多時,必然會給網路io和記憶體資源造成很大壓力,而廣播變數只給每個executor發送一份變數副本,由多個task共用。

和閉包引用的區別

1、閉包引用中,是由driver給每個executor直接發送數據。廣播變數中,是通過bittorrent協議來發送數據的,可以減少通信成本。(所有executor遵循了人人為我,我為人人的原則)。

2、閉包引用中,每個task持有一份引用對象的副本,並可以修改(只在該task線程生效);廣播變數中,一個executor只持有一份廣播變數的副本,由多個task共用,該數據是只讀的,不可修改。


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • title: 進程 cover: https://img2.imgtp.com/2024/04/30/ZamtkUJE.jpg tags: - 進程 - linux categories: linux系統編程 程式與進程 程式:是可執行文件,其本質是是一個文件,程式是靜態的,同一個程式可以運行多次, ...
  • Cortex M0/M0+相對於Cortex M3/M4性能稍弱, 但是優勢在於低價格和低功耗, 這使得M0特別適合性能要求不高且電池供電的便攜類應用, 比如遙控器, 墨水屏, 電子寵物, 電子煙等. 根據 PY32F0 各型號的數據手冊, 對比其最低功耗狀態(STOP模式)下的電流, 全系列可以大... ...
  • 痞子衡嵌入式半月刊: 第 99 期 這裡分享嵌入式領域有用有趣的項目/工具以及一些熱點新聞,農曆年分二十四節氣,希望在每個交節之日準時發佈一期。 本期刊是開源項目(GitHub: JayHeng/pzh-mcu-bi-weekly),歡迎提交 issue,投稿或推薦你知道的嵌入式那些事兒。 上期回顧 ...
  • Prometheus 使用一種稱為 TSDB(時間序列資料庫)的存儲引擎來存儲時間序列數據。以下是 Prometheus 存儲時間序列數據的基本原理: 時間序列結構: Prometheus 中的每個時間序列都由一個唯一的指標名稱(metric name)和一組鍵值對標簽(label pairs)組成 ...
  • 軟中斷處理流程 目錄軟中斷處理流程軟中斷處理的時機中斷退出時軟中斷調度機制 軟中斷處理的時機 標準linux內核關搶占的情況下,軟中斷只在下麵兩個時機調度 中斷退出時(中斷上下文) 軟中斷線程處理 中斷退出時軟中斷調度機制 判斷是否屬於中斷上下文以及是否有軟中斷處與pending狀態 判斷軟中斷線程 ...
  • 一:創建nat網路模式 主要就是nat模式的話,網橋沒有連接宿主機的物理網卡,就是創建出來一個網橋,會自動的虛擬出來2個介面(2個網卡的配置文件),一個是網橋的配置文件,另外一個就是nic的配置文件,主要作用就是虛擬機與宿主機進行通信用的 1:命令行的操作 思路主要就是,通過配置文件來進行定義, 還 ...
  • Bridge(橋)是Linux上用來做TCP/IP二層協議交換的設備,與現實世界中的交換機功能相似。Bridge設備實例可以和Linux上其他網路設備實例連接,既attach一個從設備,類似於在現實世界中的交換機和一個用戶終端之間連接一根網線。當有數據到達時,Bridge會根據報文中的MAC信息進行... ...
  • 背景介紹: 在實習的過程中,公司需要將一臺裝有win7的mac筆記本電腦遷移到戴爾G15上,提出的方案是將此筆記本的win7系統虛擬化,在戴爾G15的VmWare虛擬機上運行。作為公司的技術實習生,研究了兩天最後決定使用DiskGenius工具來進行操作。 在最一開始,公司的技術發了一個名為Veri ...
一周排行
    -Advertisement-
    Play Games
  • .Net8.0 Blazor Hybird 桌面端 (WPF/Winform) 實測可以完整運行在 win7sp1/win10/win11. 如果用其他工具打包,還可以運行在mac/linux下, 傳送門BlazorHybrid 發佈為無依賴包方式 安裝 WebView2Runtime 1.57 M ...
  • 目錄前言PostgreSql安裝測試額外Nuget安裝Person.cs模擬運行Navicate連postgresql解決方案Garnet為什麼要選擇Garnet而不是RedisRedis不再開源Windows版的Redis是由微軟維護的Windows Redis版本老舊,後續可能不再更新Garne ...
  • C#TMS系統代碼-聯表報表學習 領導被裁了之後很快就有人上任了,幾乎是無縫銜接,很難讓我不想到這早就決定好了。我的職責沒有任何變化。感受下來這個系統封裝程度很高,我只要會調用方法就行。這個系統交付之後不會有太多問題,更多應該是做小需求,有大的開發任務應該也是第二期的事,嗯?怎麼感覺我變成運維了?而 ...
  • 我在隨筆《EAV模型(實體-屬性-值)的設計和低代碼的處理方案(1)》中介紹了一些基本的EAV模型設計知識和基於Winform場景下低代碼(或者說無代碼)的一些實現思路,在本篇隨筆中,我們來分析一下這種針對通用業務,且只需定義就能構建業務模塊存儲和界面的解決方案,其中的數據查詢處理的操作。 ...
  • 對某個遠程伺服器啟用和設置NTP服務(Windows系統) 打開註冊表 HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\Services\W32Time\TimeProviders\NtpServer 將 Enabled 的值設置為 1,這將啟用NTP伺服器功 ...
  • title: Django信號與擴展:深入理解與實踐 date: 2024/5/15 22:40:52 updated: 2024/5/15 22:40:52 categories: 後端開發 tags: Django 信號 松耦合 觀察者 擴展 安全 性能 第一部分:Django信號基礎 Djan ...
  • 使用xadmin2遇到的問題&解決 環境配置: 使用的模塊版本: 關聯的包 Django 3.2.15 mysqlclient 2.2.4 xadmin 2.0.1 django-crispy-forms >= 1.6.0 django-import-export >= 0.5.1 django-r ...
  • 今天我打算整點兒不一樣的內容,通過之前學習的TransformerMap和LazyMap鏈,想搞點不一樣的,所以我關註了另外一條鏈DefaultedMap鏈,主要調用鏈為: 調用鏈詳細描述: ObjectInputStream.readObject() DefaultedMap.readObject ...
  • 後端應用級開發者該如何擁抱 AI GC?就是在這樣的一個大的浪潮下,我們的傳統的應用級開發者。我們該如何選擇職業或者是如何去快速轉型,跟上這樣的一個行業的一個浪潮? 0 AI金字塔模型 越往上它的整個難度就是職業機會也好,或者說是整個的這個運作也好,它的難度會越大,然後越往下機會就會越多,所以這是一 ...
  • @Autowired是Spring框架提供的註解,@Resource是Java EE 5規範提供的註解。 @Autowired預設按照類型自動裝配,而@Resource預設按照名稱自動裝配。 @Autowired支持@Qualifier註解來指定裝配哪一個具有相同類型的bean,而@Resourc... ...