chinese直男口爆体育生外卖, 99久久er热在这里只有精品99, 又色又爽又黄18禁美女裸身无遮挡, gogogo高清免费观看日本电视,私密按摩师高清版在线,人妻视频毛茸茸,91论坛 兴趣闲谈,欧美 亚洲 精品 8区,国产精品久久久久精品免费

0
  • 聊天消息
  • 系統(tǒng)消息
  • 評(píng)論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線課程
  • 觀看技術(shù)視頻
  • 寫(xiě)文章/發(fā)帖/加入社區(qū)
會(huì)員中心
創(chuàng)作中心

完善資料讓更多小伙伴認(rèn)識(shí)你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

Spark優(yōu)化:小文件合并的步驟

如意 ? 來(lái)源:segmentfault.com ? 作者:華為云開(kāi)發(fā)者社區(qū) ? 2020-08-13 17:53 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

我們知道,大部分Spark計(jì)算都是在內(nèi)存中完成的,所以Spark的瓶頸一般來(lái)自于集群(standalone, yarn, mesos, k8s)的資源緊張,CPU,網(wǎng)絡(luò)帶寬,內(nèi)存。Spark的性能,想要它快,就得充分利用好系統(tǒng)資源,尤其是內(nèi)存和CPU。有時(shí)候我們也需要做一些優(yōu)化調(diào)整來(lái)減少內(nèi)存占用,例如將小文件進(jìn)行合并的操作。

一、問(wèn)題現(xiàn)象

我們有一個(gè)15萬(wàn)條總數(shù)據(jù)量133MB的表,使用SELECT * FROM bi.dwd_tbl_conf_info全表查詢耗時(shí)3min,另外一個(gè)500萬(wàn)條總數(shù)據(jù)量6.3G的表ods_tbl_conf_detail,查詢耗時(shí)23秒。兩張表均為列式存儲(chǔ)的表。

大表查詢快,而小表反而查詢慢了,為什么會(huì)產(chǎn)生如此奇怪的現(xiàn)象呢?

二、問(wèn)題探詢

數(shù)據(jù)量6.3G的表查詢耗時(shí)23秒,反而數(shù)據(jù)量133MB的小表查詢耗時(shí)3min,這非常奇怪。我們收集了對(duì)應(yīng)的建表語(yǔ)句,發(fā)現(xiàn)兩者沒(méi)有太大的差異,大部分為String,兩表的列數(shù)也相差不大。

CREATE TABLE IF NOT EXISTS `bi`。`dwd_tbl_conf_info` ( `corp_id` STRING COMMENT ‘’, `dept_uuid` STRING COMMENT ‘’, `user_id` STRING COMMENT ‘’, `user_name` STRING COMMENT ‘’, `uuid` STRING COMMENT ‘’, `dtime` DATE COMMENT ‘’, `slice_number` INT COMMENT ‘’, `attendee_count` INT COMMENT ‘’, `mr_id` STRING COMMENT ‘’, `mr_pkg_id` STRING COMMENT ‘’, `mr_parties` INT COMMENT ‘’, `is_mr` TINYINT COMMENT ‘R’, `is_live_conf` TINYINT COMMENT ‘’ ) CREATE TABLE IF NOT EXISTS `bi`。`ods_tbl_conf_detail` ( `id` string, `conf_uuid` string, `conf_id` string, `name` string, `number` string, `device_type` string, `j_time` bigint, `l_time` bigint, `media_type` string, `dept_name` string, `UPDATETIME` bigint, `CREATETIME` bigint, `user_id` string, `USERAGENT` string, `corp_id` string, `account` string )

因?yàn)閮蓮埍砭鶠楹芎?jiǎn)單的SELECT查詢操作,無(wú)任何復(fù)雜的聚合join操作,也無(wú)UDF相關(guān)的操作,所以基本確認(rèn)查詢慢的應(yīng)該發(fā)生的讀表的時(shí)候,我們將懷疑的點(diǎn)放到了讀表操作上。通過(guò)查詢兩個(gè)查詢語(yǔ)句的DAG和任務(wù)分布,我們發(fā)現(xiàn)了不一樣的地方。

查詢快的表,查詢時(shí)總共有68個(gè)任務(wù),任務(wù)分配比如均勻,平均7~9s左右,而查詢慢的表,查詢時(shí)總共1160個(gè)任務(wù),平均也是9s左右。如下圖所示:

Spark優(yōu)化:小文件合并的步驟

至此,我們基本發(fā)現(xiàn)了貓膩所在。大表6.3G但文件個(gè)數(shù)小,只有68個(gè),所以很快跑完了。而小表雖然只有133MB,但文件個(gè)數(shù)特別多,導(dǎo)致產(chǎn)生的任務(wù)特別多,而由于單個(gè)任務(wù)本身比較快,大部分時(shí)間花費(fèi)在任務(wù)調(diào)度上,導(dǎo)致任務(wù)耗時(shí)較長(zhǎng)。

那如何才能解決小表查詢慢的問(wèn)題呢?

三、業(yè)務(wù)調(diào)優(yōu)

那現(xiàn)在擺在我們面前就存在現(xiàn)在問(wèn)題:

為什么小表會(huì)產(chǎn)生這么小文件 已經(jīng)產(chǎn)生的這么小文件如何合并

帶著這兩個(gè)問(wèn)題,我們和業(yè)務(wù)的開(kāi)發(fā)人員聊了一個(gè)發(fā)現(xiàn)小表是業(yè)務(wù)開(kāi)發(fā)人員從原始數(shù)據(jù)表中,按照不同的時(shí)間切片查詢并做數(shù)據(jù)清洗后插入到小表中的,而由于時(shí)間切片切的比較小,導(dǎo)致這樣的插入次數(shù)特別多,從而產(chǎn)生了大量的小文件。

那么我們需要解決的問(wèn)題就是2個(gè),如何才能把這些歷史的小文件進(jìn)行合并以及如何才能保證后續(xù)的業(yè)務(wù)流程中不再產(chǎn)生小文件,我們指導(dǎo)業(yè)務(wù)開(kāi)發(fā)人員做了以下優(yōu)化:

使用INSERT OVERWRITE bi.dwd_tbl_conf_info SELECT * FROM bi.dwd_tbl_conf_info合并下歷史的數(shù)據(jù)。由于DLI做了數(shù)據(jù)一致性保護(hù),OVERWRITE期間不影響原有數(shù)據(jù)的讀取和查詢,OVERWRITE之后就會(huì)使用新的合并后的數(shù)據(jù)。合并后全表查詢由原來(lái)的3min縮短到9s內(nèi)完成。 原有表修改為分區(qū)表,插入時(shí)不同時(shí)間放入到不同分區(qū),查詢時(shí)只查詢需要的時(shí)間段內(nèi)的分區(qū)數(shù)據(jù),進(jìn)一步減小讀取數(shù)據(jù)量。

聲明:本文內(nèi)容及配圖由入駐作者撰寫(xiě)或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點(diǎn)僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場(chǎng)。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問(wèn)題,請(qǐng)聯(lián)系本站處理。 舉報(bào)投訴
  • cpu
    cpu
    +關(guān)注

    關(guān)注

    68

    文章

    11331

    瀏覽量

    225904
  • 數(shù)據(jù)庫(kù)
    +關(guān)注

    關(guān)注

    7

    文章

    4083

    瀏覽量

    68547
  • SPARK
    +關(guān)注

    關(guān)注

    1

    文章

    108

    瀏覽量

    21290
收藏 人收藏
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

    評(píng)論

    相關(guān)推薦
    熱點(diǎn)推薦

    首屆中國(guó)NVIDIA DGX Spark黑客松大賽開(kāi)啟報(bào)名

    倒計(jì)時(shí)啟動(dòng)!首屆中國(guó) NVIDIA DGX Spark 黑客松(Hackathon)將于 3 月 13 日 - 3 月 28 日正式開(kāi)啟報(bào)名!本屆賽事以“算力破局、AI 落地”為核心導(dǎo)向,依托
    的頭像 發(fā)表于 03-14 16:39 ?2722次閱讀

    NVIDIA DGX Spark助力高等教育領(lǐng)域重大項(xiàng)目

    在全球各地的頂尖高校,NVIDIA DGX Spark 桌面超級(jí)計(jì)算機(jī)正將數(shù)據(jù)中心級(jí)的 AI 能力帶到實(shí)驗(yàn)室臺(tái)前、教師辦公室里和學(xué)生的終端設(shè)備上。在地球最南端的南極,也有一臺(tái) DGX Spark 正在威斯康星大學(xué)麥迪遜分校運(yùn)營(yíng)的 IceCube 中微子天文臺(tái)中高速運(yùn)轉(zhuǎn)。
    的頭像 發(fā)表于 03-09 16:33 ?685次閱讀

    全新軟件與模型優(yōu)化為NVIDIA DGX Spark注入強(qiáng)大動(dòng)力

    自發(fā)布以來(lái),NVIDIA 通過(guò)持續(xù)的軟件優(yōu)化以及與軟件合作伙伴和開(kāi)源社區(qū)的緊密協(xié)作,不斷提升基于 Grace Blackwell 架構(gòu)的 DGX Spark 的性能。這些舉措在推理、訓(xùn)練和創(chuàng)意工作流方面都取得了顯著的成效。
    的頭像 發(fā)表于 01-09 10:17 ?861次閱讀

    如何在DGX Spark上運(yùn)行NVIDIA Omniverse

    首先感謝 Vigor 同學(xué)第一時(shí)間的分享,以下是具體如何在 DGX Spark 上運(yùn)行 Omniverse 的方法。
    的頭像 發(fā)表于 12-17 10:13 ?927次閱讀
    如何在DGX <b class='flag-5'>Spark</b>上運(yùn)行NVIDIA Omniverse

    如何在CANape合并多個(gè)MDF格式的測(cè)量文件

    實(shí)現(xiàn)步驟:1、點(diǎn)擊Tools|FunctionsEditor進(jìn)入函數(shù)編輯界面:2、新建腳本,展開(kāi)Scripts,右鍵單擊Projectdirectory并選擇New:3、創(chuàng)建腳本,給腳本命名,按下圖
    的頭像 發(fā)表于 12-02 10:21 ?524次閱讀
    如何在CANape<b class='flag-5'>合并</b>多個(gè)MDF格式的測(cè)量<b class='flag-5'>文件</b>

    NVIDIA DGX Spark系統(tǒng)恢復(fù)過(guò)程與步驟

    在使用 NVIDIA DGX Spark 的過(guò)程中,可能會(huì)出現(xiàn)配置故障,而導(dǎo)致開(kāi)發(fā)中斷的問(wèn)題,本篇教程將帶大家了解如何一步步完成系統(tǒng)恢復(fù)。
    的頭像 發(fā)表于 11-28 09:46 ?5929次閱讀
    NVIDIA DGX <b class='flag-5'>Spark</b>系統(tǒng)恢復(fù)過(guò)程與<b class='flag-5'>步驟</b>

    NVIDIA DGX Spark助力構(gòu)建自己的AI模型

    2025 年 1 月 6 日,NVIDIA 正式宣布其 Project DIGITS 項(xiàng)目,并于 3 月 18 日更名為 NVIDIA DGX Spark,進(jìn)一步公布了產(chǎn)品細(xì)節(jié)。DGX Spark
    的頭像 發(fā)表于 11-21 09:25 ?1546次閱讀
    NVIDIA DGX <b class='flag-5'>Spark</b>助力構(gòu)建自己的AI模型

    NVIDIA DGX Spark快速入門(mén)指南

    NVIDIA DGX Spark 已正式向 AI 開(kāi)發(fā)者交付,對(duì)于剛?cè)胧值娜?DGX Spark,該如何進(jìn)行初始化設(shè)置?本篇文章將引導(dǎo)您完成 DGX Spark 首次設(shè)置。在初始設(shè)置的過(guò)程中,您
    的頭像 發(fā)表于 11-17 14:11 ?7097次閱讀
    NVIDIA DGX <b class='flag-5'>Spark</b>快速入門(mén)指南

    程序運(yùn)行速度很慢如何優(yōu)化?

    頻率: 過(guò)高頻率的中斷會(huì)占用大量CPU時(shí)間。優(yōu)化ISR代碼,使其盡可能短小精悍。能合并的中斷盡量合并。 使用RTOS特性: 如果使用了RTOS,確保任務(wù)優(yōu)先級(jí)設(shè)置合理,避免高優(yōu)先級(jí)任務(wù)長(zhǎng)時(shí)間阻塞低優(yōu)先級(jí)任務(wù)。利用信號(hào)量、消息隊(duì)列
    發(fā)表于 11-17 06:12

    安泰新能源發(fā)布新一代智能跟蹤支架AT-Spark,為大型光伏電站提供一體化解決方案

    發(fā)電效率和更低平準(zhǔn)化度電成本(LCOE)日益增長(zhǎng)的需求,通過(guò)提供一體化解決方案來(lái)優(yōu)化整個(gè)項(xiàng)目生命周期的性能。 結(jié)構(gòu)設(shè)計(jì)升級(jí)后,穩(wěn)定性更強(qiáng)、安裝更快、成本效率更高 AT-Spark采用多回轉(zhuǎn)驅(qū)動(dòng)系統(tǒng)和八角扭矩管,剛度提升40%,強(qiáng)度提升50%,同時(shí)材料成本降低30%。其
    的頭像 發(fā)表于 11-13 21:08 ?340次閱讀

    訂單拆單合并處理接口設(shè)計(jì)與實(shí)現(xiàn)

    ? 在電商或訂單管理系統(tǒng)中,訂單拆單和合并是常見(jiàn)的優(yōu)化操作。拆單指將一個(gè)訂單拆分成多個(gè)子訂單(例如基于庫(kù)存位置或物流需求),而合并則是將多個(gè)訂單整合成一個(gè)(例如減少配送成本)。一個(gè)高效的訂單拆單
    的頭像 發(fā)表于 10-16 14:47 ?843次閱讀
    訂單拆單<b class='flag-5'>合并</b>處理接口設(shè)計(jì)與實(shí)現(xiàn)

    NVIDIA DGX Spark桌面AI計(jì)算機(jī)開(kāi)啟預(yù)訂

    DGX Spark 現(xiàn)已開(kāi)啟預(yù)訂!麗臺(tái)科技作為 NVIDIA 授權(quán)分銷(xiāo)商,提供從產(chǎn)品到服務(wù)的一站式解決方案,助力輕松部署桌面 AI 計(jì)算機(jī)。
    的頭像 發(fā)表于 09-23 17:20 ?1548次閱讀
    NVIDIA DGX <b class='flag-5'>Spark</b>桌面AI計(jì)算機(jī)開(kāi)啟預(yù)訂

    鴻蒙5開(kāi)發(fā)寶藏案例分享---優(yōu)化應(yīng)用包體積大小問(wèn)題

    問(wèn)題 :多個(gè)模塊依賴同一庫(kù)的不同版本,打包時(shí)全量合并,體積爆炸。優(yōu)化方案1 **(OHPM <1.5.0):在項(xiàng)目級(jí) **<span class=\"ne-text
    發(fā)表于 06-13 10:09

    HarmonyOS優(yōu)化應(yīng)用文件上傳下載慢問(wèn)題性能優(yōu)化

    : 圖2 上傳數(shù)量和耗時(shí)對(duì)比圖表 由于上傳耗時(shí)受到網(wǎng)絡(luò)狀態(tài)影響,偏差較大,結(jié)果取的幾次測(cè)量結(jié)果的最小值。但是仍然可以從數(shù)據(jù)中看出,優(yōu)化前的耗時(shí)基本為線性增長(zhǎng),壓縮優(yōu)化后的耗時(shí)在上傳文件數(shù)量較低時(shí)并不
    發(fā)表于 05-27 16:19

    HarmonyOS優(yōu)化應(yīng)用文件上傳下載慢問(wèn)題性能優(yōu)化

    : 圖2 上傳數(shù)量和耗時(shí)對(duì)比圖表 由于上傳耗時(shí)受到網(wǎng)絡(luò)狀態(tài)影響,偏差較大,結(jié)果取的幾次測(cè)量結(jié)果的最小值。但是仍然可以從數(shù)據(jù)中看出,優(yōu)化前的耗時(shí)基本為線性增長(zhǎng),壓縮優(yōu)化后的耗時(shí)在上傳文件數(shù)量較低時(shí)并不
    發(fā)表于 05-22 10:54