spark大數(shù)據(jù)任務(wù)提交參數(shù)的優(yōu)化記錄分析
起因
新接觸一個spark集群,明明集群資源(core,內(nèi)存)還有剩余,但是提交的任務(wù)卻申請不到資源。

分析
環(huán)境
spark 2.2.0 基于yarn集群
參數(shù)
spark任務(wù)提交參數(shù)中最重要的幾個:
spark-submit --master yarn --driver-cores 1 --driver-memory 5G --executor-cores 2 --num-executors 16 --executor-memory 4G
driver-cores driver端核數(shù) driver-memory driver端內(nèi)存大小 executor-cores 每個執(zhí)行器的核數(shù) num-executors 此任務(wù)申請的執(zhí)行器總數(shù) executor-memory 每個執(zhí)行器的內(nèi)存大小
那么,該任務(wù)將申請多少資源呢?
申請的執(zhí)行器總內(nèi)存數(shù)大小=num-executor * (executor-memory +spark.yarn.executor.memoryOverhead) = 16 * (4 + 2) = 96 申請的總內(nèi)存=執(zhí)行器總內(nèi)存+dirver端內(nèi)存=101 申請的總核數(shù)=num-executor*executor-core + yarn.AM(默認(rèn)為1)=33 運行的總?cè)萜?contanier) = num-executor + yarn.AM(默認(rèn)為1) = 17
所以這里還有一個關(guān)鍵的參數(shù) spark.yarn.executor.memoryOverhead
這個參數(shù)是什么意思呢? 堆外內(nèi)存,每個executor歸spark 計算的內(nèi)存為executor-memory,每個executor是一個單獨的JVM,這個JAVA虛擬機(jī)本向在的內(nèi)存大小即為spark.yarn.executor.memoryOverhead,不歸spark本身管理。在spark集群中配置。
也可在代碼中指定 spark.set("spark.yarn.executor.memoryOverhead", 1)
這部份實際上是存放spark代碼本身的究竟,在executor-memory內(nèi)存不足的時候也能應(yīng)應(yīng)急頂上。
問題所在
假設(shè)一個節(jié)點16G的內(nèi)存,每個executor-memory=4,理想情況下4x4=16,那么該節(jié)點可以分配出4個節(jié)點供spark任務(wù)計算所用。 1.但應(yīng)考慮到spark.yarn.executor.memoryOverhead. 如果spark.yarn.executor.memoryOverhead=2,那么每個executor所需申請的資源為4+2=6G,那么該節(jié)點只能分配2個節(jié)點,剩余16-6x2=4G的內(nèi)存,無法使用。
如果一個集群共100個節(jié)點,用戶將在yarn集群主界面看到,集群內(nèi)存剩余400G,但一直無法申請到資源。
2.core也是一樣的道理。
很多同學(xué)容易忽略spark.yarn.executor.memoryOverhead此參數(shù),然后陷入懷疑,怎么申請的資源對不上,也容易陷入優(yōu)化的誤區(qū)。
優(yōu)化結(jié)果
最終優(yōu)化結(jié)果,將spark.yarn.executor.memoryOverhead調(diào)小,并根據(jù)node節(jié)點資源合理優(yōu)化executor-memory,executor-core大小,將之前經(jīng)常1.6T的內(nèi)存占比,降到1.1左右。并能較快申請到資源。
以上就是spark任務(wù)提交參數(shù)的優(yōu)化記錄分析的詳細(xì)內(nèi)容,更多關(guān)于spark任務(wù)提交參數(shù)優(yōu)化的資料請關(guān)注腳本之家其它相關(guān)文章!
相關(guān)文章
vscode通過多個跳板機(jī)連接目標(biāo)機(jī)的方法(兩種方案親測成功)
這篇文章主要介紹了vscode通過多個跳板機(jī)連接目標(biāo)機(jī)的方法,本文給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友參考下吧2024-03-03
詳解scratch3.0二次開發(fā)之scratch-blocks中的blocks的類型、定義和使用方法
scratch-blocks是scratch-gui依賴的一個基本模塊,blocks的作用是通過拖曳的方法組成blocks堆塊,今天通過本文給大家分享scratch3.0二次開發(fā)之scratch-blocks的免編譯修改方法,感興趣的朋友一起看看吧2021-08-08
性能測試監(jiān)控網(wǎng)絡(luò)吞吐量過程詳解
這篇文章是關(guān)于性能的文章,主要介紹了性能測試中測試監(jiān)控網(wǎng)絡(luò)吞吐量過程,文中給了詳細(xì)的示例分析,有需要的朋友可以借鑒參考下2021-09-09
HTTP協(xié)議詳解_動力節(jié)點Java學(xué)院整理
這篇文章主要介紹了HTTP協(xié)議詳解,超文本傳輸協(xié)議(HTTP)是一種通信協(xié)議,它允許將超文本標(biāo)記語言(HTML)文檔從Web服務(wù)器傳送到客戶端的瀏覽器2017-07-07

