国产日韩精品一区二区_欧美一级片在线播放_久久精品中文字幕电影_久久视频精品在线_亚洲国产成人久久综合一区_久久精品国产精品_国产视频精品免费播放_在线视频中文亚洲_亚洲午夜未满十八勿入免费观看全集_精品亚洲一区二区_国产原创欧美精品_国产色综合天天综合网_九九久久国产精品_欧美极品少妇xxxxⅹ裸体艺术_亚洲国产精品人人爽夜夜爽_尤物九九久久国产精品的分类

  • 首頁 > 數據存儲頻道 > 數據庫頻道 > 操作系統與開源

    字節跳動開源自研 Shuffle 框架——Cloud Shuffle Service

    2022年08月26日 11:16:39 來源:51CTO

      今天,字節跳動宣布,正式開源 Cloud Shuffle Service。

      Cloud Shuffle Service(以下簡稱CSS) 是字節自研的通用 Remote Shuffle Service 框架,支持 Spark/FlinkBatch/MapReduce 等計算引擎,提供了相比原生方案穩定性更好、性能更高、更彈性的數據 Shuffle 能力,同時也為存算分離/在離線混部等場景提供了 Remote Shuffle 解決方案。

      目前,CSS 已在 Github 上開源,歡迎感興趣的同學一起參與共建!

      開源背景

      在大數據計算引擎中,Pull-Based Sort Shuffle 是一種常見的 Shuffle 方案,比如 Spark/MapReduce/FlinkBatch (高于1.15版本)等都將 Sort Shuffle 作為引擎默認方案,但是 Sort Shuffle 實現機制有一定的缺陷,在大規模生產環境下經常因為 Shuffle 問題影響作業穩定性。

      以 Spark 的 Sort Shuffle 為例:

    1.jpg

      如上圖所示鏈路,Sort Shuffle 會存在以下一些問題:

      將多個 Spill 文件合并成一個文件,會額外消耗讀寫 IO;

      假設有 m 個 MapTask & n 個 ReduceTask,會產生 m*n 個網絡鏈接,當數量特別多時:

      大量的網絡請求會導致 Shuffle Service 容易形成積壓;

      Shuffle Service 會產生大量的隨機讀取,容易導致 IO 瓶頸,特別是 HDD 集群;

      Shuffle Service 無法做到 Application 的資源隔離,當有一個異常作業時,可能會影響同一個 Shuffle Service 節點上其它所有作業,問題容易放大;

      MapTask 生成的 Shuffle Data File 只存儲一份到本地,當磁盤壞了也會導致數據丟失,同樣引起 FetchFailed 問題;

      Shuffle Data File 寫到本地磁盤的方式,依賴計算節點上的磁盤,無法做到存算分離

      這些都很容易導致 ShuffleRead 慢或者超時,引起 FetchFailed 相關錯誤,嚴重影響線上作業的穩定性,ShuffleRead 慢也會大大降低資源利用率(CPU&Memory),同時 FetchFailed 也會導致 Stage 中相關 Task 重算,浪費大量資源,拖慢整個集群作業運行;無法存算分離的架構,在在離線混部(在線資源磁盤不足)/Serverless 云原生等場景下,也很難滿足要求。字節跳動使用 Spark 作為主要的離線大數據處理引擎,每天線上運行作業數過百萬,日均 Shuffle 量 300+PB。在 HDFS 混部&在離線混部等場景,Spark 作業的穩定性經常無法得到保障,影響業務 SLA:

      受限 HDD 磁盤 IO 能力/磁盤壞等情況,導致大量的 Shuffle FetchFailed 引起的作業慢/失敗/Stage 重算等問題,影響穩定性&資源利用率

      External Shuffle Service (以下簡稱ESS)  存算無法分離,遇到磁盤容量低的機器經常出現磁盤打滿影響作業運行

      在此背景下,字節跳動自研了 CSS,用來解決 Spark 原生 ESS 方案的痛點問題。自 CSS 在內部上線一年半以來,當前線上節點數 1500+,日均 Shuffle 量 20+PB,大大提高了 Spark 作業的 Shuffle 穩定性,保障了業務的 SLA。

      Cloud Shuffle Service 介紹

      CSS 是字節自研的 Push-Based Shuffle Service,所有 MapTask 通過 Push 的方式將同一個 Partition 的 Shuffle 數據發送給同一個 CSS Worker 節點進行存儲,ReduceTask 直接從該節點通過 CSS Worker 順序讀取該 Partition 的數據,相對于 ESS 的隨機讀取,順序讀的 IO 效率大大提升。

      CSS 架構

    圖片

      Cloud Shuffle Service(CSS) 架構圖CSS Cluster 是獨立部署的 Shuffle Service 服務,主要涉及的組件為:

      CSS Worker

      CSS Worker 啟動后會向 ZooKeeper 節點注冊節點信息,它提供 Push/Fetch 兩種服務請求,Push 服務接受來自 MapTask 的 Push 數據請求,并將同一個 Partition 的數據寫到同一個文件;Fetch 服務接受來自 ReduceTask 的 Fetch 數據請求,讀取對應 Partition 數據文件返回;CSS Worker還負責 Shuffle 數據清理的工作,當 Driver 進行 UnregisterShuffle 請求刪除 ZooKeeper 對應 ShuffleId 的 Znode 時,或者 Application 結束刪除 ZooKeeper 中 ApplicationId 的 Znode 時,CSS Workers 會 Watch 相關事件對 Shuffle 數據進行清理。

      CSS Master

      作業啟動后會在 Spark Driver 中啟動 CSS Master,CSS Master 會從 ZooKeeper 中獲取到 CSS Worker 的節點列表,然后為后續 MapTask 產生的各個 Partition 分配 n 個副本(默認為2)的 CSS Worker 節點,并對這些 Meta 信息進行管理,供 ReduceTask 獲取 PartitionId 所在的 CSS Worker 節點進行拉取,同時在 RegisterShuffle/UnregisterShuffle 過程中會在 ZooKeeper 中創建對應的 ApplicationId/ShuffleId 的 Znode,CSS Worker 會 Watch Delete 事件對 Shuffle 數據進行清理。

      ZooKeeper

      如前描述,用來存儲 CSS Worker 節點信息以及 ShuffleId 等信息。

      CSS 特性

      多引擎支持

      CSS除了支持 Spark(2.x&3.x) 之外,也可以接入其他引擎,目前在字節跳動內部,CSS 還接入了 MapReduce/FlinkBatch 引擎。

      PartitionGroup 支持

      為了解決單個 Partition 太小,Push 效率比較低的問題,實際會將多個連續的 Partition 組合成更大的 PartitionGroup進行 Push。

      高效統一的內存管理

      跟 ESS 類似,MapTask 中的 CSS Buffer 將所有 Partition 的數據都存儲在一起,在 Spill 之前會對數據按照 PartitionId 進行排序,然后按照 PartitionGroup 維度進行數據推送;同時 CSS Buffer 完全納入 Spark 的 UnifiedMemoryManager 內存管理體系,內存相關參數由 Spark 統一管理。

      容錯處理

      Push 失。寒斢|發 Spill 進行 Push PartitionGroup 數據時,每次 Push 的數據大小為 4MB(一個Batch),當某次 Push batch 失敗時,并不影響之前已經 Push 成功的數據,只需要重新分配節點(Reallocate)繼續 Push 當前失敗的數據以及后續還未 Push 的數據,后續 ReduceTask 會從新老節點讀取完整的 Partition 數據;多副本存儲:ReduceTask 從 CSS Worker 讀取某個 Partition 數據是按照 Batch 粒度進行拉取的,當 CSS Worker 異常(如網絡問題/磁盤壞等)導致無法獲取該 Batch 數據,可以繼續選擇另外一個副本節點繼續讀取該 Batch 以及后續 Batch 的數據;數據去重:當作業開啟 Speculative 推測執行會有多個 AttempTask 并發跑,需要在讀取的時候進行去重。在 Push Batch 的時候,會給 Batch 數據加上 Header 信息,Header 信息中包含  MapId + AttempId + BatchId 等信息,ReduceTask 讀取時可以根據這些 ID 信息進行去重。

      Adaptive Query Execution(AQE) 適配

      CSS 完整支持 AQE 相關的功能,包括動態調整 Reduce 個數/ SkewJoin 優化/Join 策略優化。對于SkewJoin,CSS做了更多的適配優化工作,解決了 Skew Partition 數據被多個 ReduceTask 重復讀取問題,大大提高了性能。

      CSS 性能測試

      我們將 CSS 與開源的 ESS 使用獨占 Label 計算資源進行 1TB 的 TPC-DS Benchmark 測試對比,整體端到端的性能提升15%左右,部分 Query 有30%以上的性能提升。同時我們也使用線上混部資源隊列(ESS 穩定較差)進行 1TB 的 TPC-DS Benchmark 測試對比,整體端到端性能提升4倍左右。

    圖片

      CSS 1TB 測試提升 30% 以上的 Query

      未來規劃

      CSS 目前開源了部分 Feature,還有一些 Feature & 優化后續會陸續開放:

      支持 MapReduce/FlinkBatch 引擎;

      CSS 集群增加 ClusterManager 服務角色,管理 CSS Worker 的狀態&負載信息,同時將當前 CSS Master 分配 CSS Worker 的功能提到 ClusterManager;

      基于異構機器(如磁盤能力不同)/負載 等維度的 CSS Worker 分配策略。

      文章內容僅供閱讀,不構成投資建議,請謹慎對待。投資者據此操作,風險自擔。

    海報生成中...

    最新新聞

    熱門新聞

    即時

    全球頂級AI創作社區回歸!海藝AI國內首發“全民娛樂化創作

    海藝AI的模型系統在國際市場上廣受好評,目前站內累計模型數超過80萬個,涵蓋寫實、二次元、插畫、設計、攝影、風格化圖像等多類型應用場景,基本覆蓋所有主流創作風格。

    新聞

    市場占比高達35.8%,阿里云引領中國AI云增長

    9月9日,國際權威市場調研機構英富曼(Omdia)發布了《中國AI云市場,1H25》報告。中國AI云市場阿里云占比8%位列第一。

    企業IT

    華為坤靈發布IdeaHub千行百業體驗官計劃,助力中小企

    9月24日,華為坤靈召開“智能體驗,一屏到位”華為IdeaHub千行百業體驗官計劃發布會。

    3C消費

    雅馬哈推出兩款高端頭戴耳機YH-4000與YH-C3000

    雅馬哈昨日宣布推出兩款頭戴式耳機,分別是平板振膜的YH-4000和動圈原理的YH-C3000。

    研究

    IDC:2025上半年全球智能家居清潔機器人出貨量同比暴

    IDC今日發布的《全球智能家居清潔機器人設備市場季度跟蹤報告,2025年第二季度》顯示,上半年全球智能家居清潔機器人市場出貨1,2萬臺,同比增長33%,顯示出品類強勁的市場需求。

    国产日韩精品一区二区_欧美一级片在线播放_久久精品中文字幕电影_久久视频精品在线_亚洲国产成人久久综合一区_久久精品国产精品_国产视频精品免费播放_在线视频中文亚洲_亚洲午夜未满十八勿入免费观看全集_精品亚洲一区二区_国产原创欧美精品_国产色综合天天综合网_九九久久国产精品_欧美极品少妇xxxxⅹ裸体艺术_亚洲国产精品人人爽夜夜爽_尤物九九久久国产精品的分类
    欧亚一区二区| 88国产精品欧美一区二区三区| 日本电影亚洲天堂| 狠狠色综合日日| 天堂8中文在线最新版在线| 欧美日韩成人在线一区| 99久久99精品久久久久久| 国产精品成人自拍| 久久综合88中文色鬼| 天堂一区二区在线| 欧美午夜视频一区二区| 国产高清成人在线| 一区二区乱码| 亚洲香蕉av| 97久久超碰国产精品| 日韩在线理论| 国产丝袜精品丝袜| 99精品视频一区二区| 国产精品呻吟| 日本免费视频在线观看| 久久精品播放| 欧美一区二区三区白人| 欧美黄色小视频| 一本色道久久综合亚洲精品按摩| 日韩欧美在线视频免费观看| 欧美欧美欧美欧美| 午夜日韩电影| 国产一区亚洲| 欧美与亚洲与日本直播| 亚洲精品精品亚洲| 中文字幕的久久| 欧美日韩激情一区二区三区| 欧美r级电影| 伊人久久久久久久久久| 91丨porny丨国产| 精品国产乱码久久久久久浪潮| 亚洲男人的天堂在线| 精品国产丝袜高跟鞋| 91精品大全| 久久精品免费看| 美女视频黄频大全不卡视频在线播放| 另类中文字幕国产精品| 亚洲精品精品亚洲| 国产日韩一区二区三区在线播放| 欧美人与牛zoz0性行为| 欧美无乱码久久久免费午夜一区| 久久99精品久久久久久青青91| 夜夜爽夜夜爽精品视频| 午夜精品在线看| 91麻豆国产香蕉久久精品| 欧美日韩综合不卡| 国产主播欧美精品| 精品视频色一区| 日韩三级视频| 国产精品久久一区二区三区| 日韩av在线播放网址| 欧日韩一区二区三区| 一区二区三区日本视频| 91久久精品国产| 337p日本欧洲亚洲大胆鲁鲁| 91福利国产成人精品照片| av日韩亚洲| 午夜精品久久久久久久| 91探花福利精品国产自产在线| sm久久捆绑调教精品一区| 日韩高清不卡一区二区三区| 亚洲免费色视频| 超在线视频97| 日韩在线观看免费全| 中文字幕日本欧美| 91av资源在线| 日本高清不卡在线观看| 国产成人在线一区| 亚洲嫩模很污视频| 欧美日韩国产综合草草| 2019亚洲男人天堂| 国产亚洲va综合人人澡精品| 日韩欧美在线一区| 国产精品久久久久久久蜜臀| 经典一区二区三区| 亚洲精品av在线播放| 一区二区激情| 亚洲一区二区三区久久| 成人在线免费看黄| 亚洲福利小视频| 色噜噜一区二区| 亚洲r级在线观看| 蜜桃传媒视频麻豆一区| 亚洲天堂男人天堂女人天堂| 亚洲一二三四在线| 亚洲精品成人图区| 日韩欧美在线视频日韩欧美在线视频| 国产一级精品aaaaa看| 国产国产精品人在线视| 新67194成人永久网站| 国产精品美女久久久久久久久久久| 欧美亚洲精品在线| 亚洲欧美偷拍三级| 在线亚洲一区观看| 91超碰国产精品| 亚洲电影第三页| 一区二区久久久| 日韩成人免费看| 国产亚洲福利一区| 成人不用播放器| 日韩av日韩在线观看| 国产女人18水真多18精品一级做| 国产午夜精品在线| 成人在线视频免费看| 亚洲91精品| 91香蕉视频mp4| 国产精久久久| 日韩一区二区在线观看视频| 欧美片第1页| 欧美tickling挠脚心丨vk| 欧美在线免费| 亚洲宅男天堂在线观看无病毒| 国产69久久精品成人| 亚洲成a人片77777在线播放| 欧美主播一区二区三区美女 久久精品人| 成人动漫视频在线| 国产日韩一区二区三区| 国产美女久久精品香蕉69| 大片网站久久| 蜜月aⅴ免费一区二区三区| 欧美性感一区二区三区| 国产高清精品一区二区| 精品无人码麻豆乱码1区2区| 亚洲欧洲国产专区| 国产欧美日韩精品一区二区三区| 欧美另类高清zo欧美| 亚州国产精品久久久| 日韩午夜电影| 亚洲成人在线观看视频| 自拍偷拍亚洲在线| 日本三级久久久| 97人人香蕉| 亚洲一区第一页| 久久99精品国产麻豆不卡| bt7086福利一区国产| 中文字幕av一区中文字幕天堂| 永久免费毛片在线播放不卡| 色伊人久久综合中文字幕| 欧美丝袜自拍制服另类| 欧美国产日本韩| 亚洲区中文字幕| 午夜精品一区二区三区av| 天堂va蜜桃一区二区三区| 亚洲18色成人| 精品写真视频在线观看| 91国内精品白嫩初高生| 国产乱色国产精品免费视频| 精品久久91| 欧美视频一区在线观看| 日韩精品欧美激情一区二区| 欧美大人香蕉在线| 亚洲综合影视| 啊v视频在线一区二区三区| 97久久超碰| 国产福利精品导航| 日韩专区欧美专区| а√天堂在线官网| 在线亚洲人成电影网站色www| 久久成人综合|