成人午夜视频全免费观看高清-秋霞福利视频一区二区三区-国产精品久久久久电影小说-亚洲不卡区三一区三区一区

hivesql的執(zhí)行及編譯過程

一、hive在執(zhí)行sql時會以mapreduce的方式對數(shù)據(jù)進行接入和處理,其主要包含以下幾個階段:
hive sql的執(zhí)行及編譯過程
1.hive首先根據(jù)sql語句中的表從hdfs文件中獲取數(shù)據(jù),對數(shù)據(jù)文件進行split操作,使其可以一行一行將所需數(shù)據(jù)讀入內(nèi)存;
2.map函數(shù)將內(nèi)存中的數(shù)據(jù)按照key值進行映射,形成一行一行的key-value值,比如用戶表中的性別字段,內(nèi)存中map處理后的記錄如下:
hive sql的執(zhí)行及編譯過程
3.在實際應用中會有多臺機器參與map處理,map完成后需要將帶有相同key的數(shù)據(jù)分發(fā)到同一臺集群去進行后續(xù)處理,此時的操作稱為shuffle;
4.如果sql中包含有join、count、sum,此時還會進行reduce操作,比如count,其完成reduce后數(shù)據(jù)情況如下:
hive sql的執(zhí)行及編譯過程

成都創(chuàng)新互聯(lián)專業(yè)為企業(yè)提供雨山網(wǎng)站建設、雨山做網(wǎng)站、雨山網(wǎng)站設計、雨山網(wǎng)站制作等企業(yè)網(wǎng)站建設、網(wǎng)頁設計與制作、雨山企業(yè)網(wǎng)站模板建站服務,十多年雨山做網(wǎng)站經(jīng)驗,不只是建網(wǎng)站,更提供有價值的思路和整體網(wǎng)絡服務。

二、在hive底層,同時還會將上面的sql進行編譯,其過程主要包含以下六點:
hive sql的執(zhí)行及編譯過程
為便于理解,我們拿一個簡單的查詢語句進行展示,對5月30號的地區(qū)維表進行查詢:

select * from dim.dim_region where dt = '2019-05-30'

1.根據(jù)Antlr定義的sql語法規(guī)則,將相關sql進行詞法、語法解析,轉(zhuǎn)化為抽象語法樹AST Tree

ABSTRACT SYNTAX TREE:
TOK_QUERY
    TOK_FROM 
    TOK_TABREF
           TOK_TABNAME
               dim
                 dim_region
    TOK_INSERT
      TOK_DESTINATION
          TOK_DIR
              TOK_TMP_FILE
        TOK_SELECT
          TOK_SELEXPR
              TOK_ALLCOLREF
        TOK_WHERE
          =
              TOK_TABLE_OR_COL
                  dt
                    '2019-05-30'

2.遍歷AST Tree,抽象出查詢的基本組成單元QueryBlock
AST Tree生成后由于其復雜度依舊較高,不便于翻譯為mapreduce程序,需要進行進一步抽象和結構化,形成QueryBlock。QueryBlock是一條SQL最基本的組成單元,包括三個部分:輸入源,計算過程,輸出。簡單來講一個QueryBlock就是一個子查詢。QB的生成過程為一個遞歸過程,先序遍歷 AST Tree ,遇到不同的Token 節(jié)點(理解為特殊標記),保存到相應的屬性中,主要包含以下幾個過程:

  • TOK_QUERY:創(chuàng)建 QB 對象,循環(huán)遞歸子節(jié)點
  • TOK_FROM:將表名語法部分保存到 QB 對象的 aliasToTabs 等屬性中
  • TOK_INSERT:循環(huán)遞歸子節(jié)點
  • TOK_DESTINATION:將輸出目標的語法部分保存在 QBParseInfo 對象的nameToDest 屬性中
  • TOK_SELECT:分別將查詢表達式的語法部分保存在 destToSelExpr 、destToAggregationExprs 、 destToDistinctFuncExprs 三個屬性中
  • TOK_WHERE:將 Where 部分的語法保存在 QBParseInfo 對象的destToWhereExpr 屬性中

3.遍歷QueryBlock,翻譯為執(zhí)行操作樹OperatorTree
Hive最終生成的MapReduce任務,Map階段和Reduce階段均由OperatorTree組成。邏輯操作符,就是在Map階段或者Reduce階段完成單一特定的操作。
基本的操作符包括TableScanOperator,SelectOperator,F(xiàn)ilterOperator,JoinOperator,GroupByOperator,ReduceSinkOperator
ReduceSinkOperator將Map端的字段組合序列化為Reduce Key/value, Partition Key,只可能出現(xiàn)在Map階段,同時也標志著Hive生成的MapReduce程序中Map階段的結束。
Operator在Map Reduce階段之間的數(shù)據(jù)傳遞都是一個流式的過程。每一個Operator對一行數(shù)據(jù)完成操作后之后將數(shù)據(jù)傳遞給childOperator計算。
由于Join/GroupBy/OrderBy均需要在Reduce階段完成,所以在生成相應操作的Operator之前都會先生成一個ReduceSinkOperator,將字段組合并序列化為Reduce Key/value, Partition Key。

4..Logical Optimizer對OperatorTree進行優(yōu)化操作
使用ReduceSinkOperator,減少shuffle數(shù)據(jù)量。大部分邏輯層優(yōu)化器通過變換 OperatorTree ,合并操作符,達到減少 MapReduce Job ,減少 shuffle 數(shù)據(jù)量的目的。

5.遍歷OperatorTree,并翻譯為MapReduce任務
OperatorTree 轉(zhuǎn)化為 Task tree的過程分為下面幾個階段

對輸出表生成 MoveTask
從 OperatorTree 的其中一個根節(jié)點向下深度優(yōu)先遍歷
ReduceSinkOperator 標示 Map/Reduce 的界限,多個 Job 間的界限
遍歷其他根節(jié)點,遇過碰到 JoinOperator 合并 MapReduceTask
生成 StatTask 更新元數(shù)據(jù)
剪斷 Map 與 Reduce 間的 Operator 的關系

6.物理層優(yōu)化器對MapReduce任務進行優(yōu)化,生成最終的執(zhí)行計劃

分享標題:hivesql的執(zhí)行及編譯過程
鏈接分享:http://jinyejixie.com/article28/posojp.html

成都網(wǎng)站建設公司_創(chuàng)新互聯(lián),為您提供定制開發(fā)、關鍵詞優(yōu)化、響應式網(wǎng)站App設計、營銷型網(wǎng)站建設、靜態(tài)網(wǎng)站

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)

搜索引擎優(yōu)化
茌平县| 榕江县| 台山市| 武夷山市| 延寿县| 仁化县| 句容市| 都昌县| 阳信县| 宁蒗| 竹溪县| 西林县| 永康市| 清镇市| 开化县| 来宾市| 辛集市| 晋城| 邹城市| 固镇县| 池州市| 成武县| 班戈县| 平罗县| 彩票| 台东市| 乐都县| 浮山县| 永年县| 历史| 星座| 临江市| 白城市| 新河县| 始兴县| 徐汇区| 大厂| 元谋县| 东台市| 女性| 遂宁市|