黄视频网站在线免费观看-黄视频网站在线看-黄视频网站在线观看-黄视频网站免费看-黄视频网站免费观看-黄视频网站免费

千鋒教育-做有情懷、有良心、有品質的職業教育機構

手機站
千鋒教育

千鋒學習站 | 隨時隨地免費學

千鋒教育

掃一掃進入千鋒手機站

領取全套視頻
千鋒教育

關注千鋒學習站小程序
隨時隨地免費學習課程

當前位置:首頁  >  技術干貨  > Spark 數據傾斜調優10策(二)

Spark 數據傾斜調優10策(二)

來源:千鋒教育
發布人:wjy
時間: 2022-06-22 17:40:00 1655890800

  二、 如何避免數據傾斜

  2.1 避免數據源傾斜-HDFS

  Spark通過 textFile(path, minPartitions) 方法讀取文件時,使用 TextInputFormat。對于不可切分的文件,每個文件對應一個 Split 從而對應一個 Partition。此時各文件大小是否一致,很大程度上決定了是否存在數據源側的數據傾斜。另外,對于不可切分的壓縮文件,即使壓縮后的文件大 小一致,它所包含的實際數據量也可能差別很多,因為源文件數據重復度越高,壓縮比越高。反過來, 即使壓縮文件大小接近,但由于壓縮比可能差距很大,所需處理的數據量差距也可能很大。此時可通過在數據生成端將不可切分文件存儲為可切分文件,或者保證各文件包含數據量相同的方式避免數據傾斜。

  # 對于不可切分文件可能出現數據傾斜,對于可切分文件,一般來說,不存在數據傾斜問題。

  1. 可切分: 基本上不會! 默認數據塊大小:128M

  2. 不可切分: 源文件不均勻,最終導致 分布式引用程序計算產生數據傾斜 日志:每一個小時生成一個日志文件

  2.2 避免數據源傾斜-Kaka

  Topic 主題: 分布式的組織形式: 分區, 既然要進行數據分區,那就有可能產生數據分布不均勻

  以 Spark Stream 通過 DirectStream 方式讀取 Kafka 數據為例。由于 Kafka 的每一個 Partition 對應 Spark 的一個 Task(Partition),所以 Kafka 內相關 Topic 的各 Partition 之間數據是否平衡,直接決 定 Spark 處理該數據時是否會產生數據傾斜。

  Kafka 某一 Topic 內消息在不同 Partition 之間的分布,主要由 Producer 端所使用的 Partitioner 實現 類決定。如果使用隨機 Partitioner,則每條消息會隨機發送到一個 Partition 中,從而從概率上來講, 各 Partition 間的數據會達到平衡。此時源 Stage(直接讀取 Kafka 數據的 Stage)不會產生數據傾斜。

  但很多時候,業務場景可能會要求將具備同一特征的數據順序消費,此時就需要將具有相同特征的數據 放于同一個 Partition 中。一個典型的場景是,需要將同一個用戶相關的PV信息置于同一個 Partition 中。此時,如果產生了數據傾斜,則需要通過其它方式處理。

  * 以 Spark Stream 通過 DirectStream 方式讀取 Kafka 數據為例。由于 Kafka 的每一個 Partition 對應 Spark 的一個 Task(Partition),所以 Kafka 內相關 Topic 的各 Partition 之間數據是否平衡,直接決 定 Spark 處理該數據時是否會產生數據傾斜。

  * Kafka 某一 Topic 內消息在不同 Partition 之間的分布,主要由 Producer 端所使用的 Partitioner 實現 類決定。如果使用隨機 Partitioner,則每條消息會隨機發送到一個 Partition 中,從而從概率上來講, 各 Partition 間的數據會達到平衡。此時源 Stage(直接讀取 Kafka 數據的 Stage)不會產生數據傾斜。

  * 但很多時候,業務場景可能會要求將具備同一特征的數據順序消費,此時就需要將具有相同特征的數據 放于同一個 Partition 中。一個典型的場景是,需要將同一個用戶相關的PV信息置于同一個 Partition 中。此時,如果產生了數據傾斜,則需要通過其它方式處理。

  2.3 定位處理邏輯 - Stage 和 Task

  歸根結底,數據傾斜產生的原因,就是兩個 stage 中的 shuffle 過程導致的。所以我們只需要研究Shuffle 算子即可。我們知道了導致數據傾斜的問題就是 shuffle 算子,所以我們先去找到代碼中的 shuffle 的算子,比如 distinct、groupByKey、reduceByKey、aggergateByKey、join、cogroup、repartition 等,那么問 題一定就出現在這里。spark的執行,按照hsuffle算子分成多個stage來執行。

  * 如果 Spark Application 運行過程中,出現數據傾斜,可以通過 web 管理監控界面,查看 各stage 的運行情況,如果某一個 stage 的運行很長,并且這個 stage 的大部分Task都運行很快,則

  2.4 查看導致傾斜的key的數據分布情況

  知道了數據傾斜發生在哪里之后,通常需要分析一下那個執行了shuffle操作并且導致了數據傾斜的 RDD/Hive表,查看一下其中key的分布情況。這主要是為之后選擇哪一種技術方案提供依據。針對不同 的key分布與不同的shuffle算子組合起來的各種情況,可能需要選擇不同的技術方案來解決。此時根據你執行操作的情況不同,可以有很多種查看key分布的方式:

  1. 如果是Spark SQL中的group by、join語句導致的數據傾斜,那么就查詢一下 SQL 中使用的表的key 分布情況。

  2. 如果是對 Spark RDD執行shuffle算子導致的數據傾斜,那么可以在Spark作業中加入查看 key 分布 的代碼,比如 RDD.countByKey()。然后對統計出來的各個key出現的次數,collect/take到客戶端打印 一下,就可以看到key的分布情況。

Spark 數據傾斜調優10策

  舉例來說,對于上面所說的單詞計數程序,如果確定了是 stage1 的 reduceByKey 算子導致了數據傾 斜,那么就應該看看進行 reduceByKey 操作的 RDD 中的 key 分布情況,在這個例子中指的就是 pairs RDD。如下示例,我們可以先對 pairs 采樣 10% 的樣本數據,然后使用 countByKey 算子統計出每個 key 出現的次數,最后在客戶端遍歷和打印樣本數據中各個 key 的出現次數。

  val sampledPairs = pairs.sample(false, 0.1)

  val sampledWordCounts = sampledPairs.countByKey()

  sampledWordCounts.foreach(println(_))

  采樣!(離線處理:無放回采樣, 流式處理:魚塘采樣)

tags:
聲明:本站稿件版權均屬千鋒教育所有,未經許可不得擅自轉載。
10年以上業內強師集結,手把手帶你蛻變精英
請您保持通訊暢通,專屬學習老師24小時內將與您1V1溝通
免費領取
今日已有369人領取成功
劉同學 138****2860 剛剛成功領取
王同學 131****2015 剛剛成功領取
張同學 133****4652 剛剛成功領取
李同學 135****8607 剛剛成功領取
楊同學 132****5667 剛剛成功領取
岳同學 134****6652 剛剛成功領取
梁同學 157****2950 剛剛成功領取
劉同學 189****1015 剛剛成功領取
張同學 155****4678 剛剛成功領取
鄒同學 139****2907 剛剛成功領取
董同學 138****2867 剛剛成功領取
周同學 136****3602 剛剛成功領取
相關推薦HOT
毛片的网站| 久久久成人网| 国产国产人免费视频成69堂| 国产麻豆精品| 美女免费精品视频在线观看| 高清一级片| 精品视频在线看 | 国产成人精品综合在线| 国产美女在线观看| 午夜精品国产自在现线拍| 成人在免费观看视频国产| 四虎影视久久久| 精品国产一区二区三区免费 | 黄视频网站免费| 91麻豆爱豆果冻天美星空| 欧美激情伊人| 久久国产精品自由自在| 久草免费在线观看| 日韩专区第一页| 韩国三级视频网站| 青青久热| 欧美大片毛片aaa免费看| 欧美激情影院| 欧美一区二区三区性| 国产一区二区精品在线观看| 国产一区二区精品尤物| 国产一区二区精品尤物| 午夜激情视频在线播放| 精品毛片视频| 国产成人欧美一区二区三区的| 黄色免费三级| 毛片的网站| 国产精品自拍一区| 国产一区二区高清视频| 四虎影视久久| 欧美激情一区二区三区视频| 国产麻豆精品免费密入口| 精品国产香蕉伊思人在线又爽又黄| 可以免费看污视频的网站| 韩国三级一区| 精品在线免费播放| 国产激情一区二区三区| 久久精品店| 99热精品在线| 成人a级高清视频在线观看| 精品国产一区二区三区久久久蜜臀 | 精品视频在线看| 可以免费看污视频的网站| 久草免费在线观看| 久久福利影视| 久久99欧美| 免费的黄视频| 国产精品免费精品自在线观看| 91麻豆精品国产自产在线| 久久国产影院| 尤物视频网站在线观看| 可以免费看污视频的网站| 超级乱淫伦动漫| 国产激情一区二区三区| 久久99中文字幕| 国产麻豆精品视频| 国产精品自拍在线| 国产a一级| 精品国产三级a| 国产原创视频在线| 毛片高清| 午夜在线影院| 国产网站在线| 99久久视频| 久草免费在线观看| 亚洲 激情| 国产91丝袜在线播放0| 91麻豆tv| 日韩中文字幕在线播放| 欧美大片毛片aaa免费看| 国产高清视频免费观看| 成人影视在线观看| 国产麻豆精品免费视频| 中文字幕97| 毛片高清| 精品视频一区二区三区免费| 亚欧成人乱码一区二区| 黄视频网站在线看| 香蕉视频久久| 国产原创中文字幕| 亚洲女人国产香蕉久久精品| 欧美a级片视频| 一a一级片| 久久成人性色生活片| 亚洲精品中文一区不卡| 国产亚洲精品aaa大片| 国产亚洲精品成人a在线| 日日夜夜婷婷| 国产激情一区二区三区| 日韩一级黄色| 二级片在线观看| 青青青草视频在线观看| 精品国产香蕉在线播出| 精品毛片视频| 国产一区免费在线观看| 99色播| 青青久热| 国产成人啪精品视频免费软件| 美女被草网站| 午夜在线亚洲男人午在线| 亚洲精品中文一区不卡| 一a一级片| 一本高清在线| 精品视频在线观看免费| 精品国产三级a∨在线观看| 日日夜夜婷婷| 久久99中文字幕| 欧美激情一区二区三区在线播放| 精品视频在线观看一区二区| 久久久久久久久综合影视网| 麻豆系列 在线视频| 久久久成人影院| 免费一级片在线观看| 日韩在线观看免费| 一级女人毛片人一女人| 国产91精品一区| 亚欧视频在线| 精品国产一区二区三区国产馆| 精品在线免费播放| 亚洲 激情| 成人a级高清视频在线观看| 亚飞与亚基在线观看| 尤物视频网站在线| 国产成人精品一区二区视频| 亚洲第一页乱| 国产伦久视频免费观看视频| 精品久久久久久综合网| 亚洲精品影院一区二区| 黄视频网站免费| 欧美一级视| 日韩免费在线视频| 沈樵在线观看福利| 国产国语对白一级毛片| 九九免费精品视频| 成人免费观看的视频黄页| 99色视频在线| 亚洲wwwwww| 国产成人精品一区二区视频| 色综合久久久久综合体桃花网| 欧美激情一区二区三区视频高清 | 免费一级片在线| 日韩专区第一页| 欧美一区二区三区性| 午夜精品国产自在现线拍| 精品久久久久久影院免费| 久久久成人影院| 日韩男人天堂| 精品久久久久久综合网| 黄视频网站免费看| 国产一区二区福利久久| 国产伦久视频免费观看视频| 亚洲精品影院一区二区| 韩国毛片免费| 国产极品白嫩美女在线观看看| 成人免费观看视频| 日韩女人做爰大片| 国产视频久久久| 成人在激情在线视频| 精品视频在线看| 高清一级淫片a级中文字幕| 日本特黄特色aaa大片免费| 人人干人人插| 国产高清视频免费观看| 精品国产亚洲人成在线| 青青久久精品| 成人影院一区二区三区| 欧美激情影院| 韩国毛片基地| 国产麻豆精品免费视频| 99色视频| 91麻豆国产福利精品| 日本伦理黄色大片在线观看网站| 国产网站在线| 青青久久网| 国产麻豆精品| 青青久热| 免费的黄视频| 久久成人综合网| 国产91精品露脸国语对白| 999久久狠狠免费精品| 色综合久久天天综线观看| 国产视频一区二区在线播放| 欧美a级大片| 亚飞与亚基在线观看| 久草免费在线观看| 国产亚洲免费观看| 久久99中文字幕| 国产不卡在线观看| 99色视频| 天天做日日干| 999精品视频在线| a级黄色毛片免费播放视频| 91麻豆高清国产在线播放| 国产精品自拍在线观看| 国产亚洲精品aaa大片|