成人国产在线小视频_日韩寡妇人妻调教在线播放_色成人www永久在线观看_2018国产精品久久_亚洲欧美高清在线30p_亚洲少妇综合一区_黄色在线播放国产_亚洲另类技巧小说校园_国产主播xx日韩_a级毛片在线免费

資訊專欄INFORMATION COLUMN

Apache Tajo:一個運行在YARN上支持SQL的分布式數(shù)據(jù)倉庫

gclove / 3254人閱讀

摘要:典型代表是,這種系統(tǒng)的特點是擴展性和容錯性好,但性能低下。借鑒分布式數(shù)據(jù)庫思想。具體見參考資料,下載,下載是韓國大學數(shù)據(jù)庫實驗室開源的基于的分布式數(shù)據(jù)倉庫,目前是的二級項目。此外,使用進行資源管理。

1. 背景

當前,Hadoop之上的SQL引擎已經非常多了,概括起來有兩類系統(tǒng),分別是:

(1)將SQL轉化為MapReduce。典型代表是Apache Hive,這種系統(tǒng)的特點是擴展性和容錯性好,但性能低下。為了彌補SQL on MapReduce的不足,google提出了Tenzing(見參考資料[3]),與Hive不同,Tenzing充分借鑒了MapReduce和DataBase的優(yōu)勢,首先,它對傳統(tǒng)的MapReduce進行了優(yōu)化(比如Map 可以不寫磁盤,Reduce可不必排序等),使其性能更高,采用MapReduce一大優(yōu)勢是使Tenzing具有了很好的擴展性和容錯性,Tenzing論文是這樣表述的:

“Thanks to MapReduce, Tenzing scales to thousands of cores and petabytes of data on cheap, unreliable hardware. We worked closely with the MapReduce team to implement and take advantage of MapReduce optimizations.”

其次,它借鑒了傳統(tǒng)database的優(yōu)勢,嵌有一個cost-based 優(yōu)化器,以對SQL查詢計劃進行充分優(yōu)化。

(2)借鑒分布式數(shù)據(jù)庫思想。典型代表是Google Dremel、Apache Drill和Cloudera Impala,這類系統(tǒng)的特點是性能高(與Hive等系統(tǒng)比),但擴展性(包括集群規(guī)模擴展和SQL類型支持多樣性)和容錯性較差,Google在Dremel論文(見參考資料[4])中這樣描述Dremel的適用場景:

“Dremel is not intended as a replacement for MR and is often used in conjunction with it to analyze outputs of MR pipelines or rapidly prototype larger computations.”

也就是說,Dremel并不是用以取代MR的,而是彌補MR不足,通常用于分析MR產生的數(shù)據(jù)(這些數(shù)據(jù)量小,處理這些數(shù)據(jù)時,對SQL表達能力和框架容錯性要求低)。

Apache tajo(具體見參考資料[1][2],tajo ppt下載,tajo paper下載)是韓國大學數(shù)據(jù)庫實驗室開源的基于YARN的分布式數(shù)據(jù)倉庫,目前是Apache的二級項目。Tajo的設計思想類似于Tenzing,它充分借鑒了MapReduce和DataBase的優(yōu)勢,使其具有Hive的擴展性和容錯性好的優(yōu)點,但同時性能比Hive高不少。

2. Tajo設計架構

Tajo采用了Master-worker架構,具體如下:

(1) TajoMaster:為客戶端提供查詢服務和管理各個QueryMaster。

(2) QueryMaster:負責一個query的解析、優(yōu)化與執(zhí)行,它與多個task runner worker協(xié)同工作,完成一個query的計算。

如下圖所示,Tajo采用傳統(tǒng)數(shù)據(jù)庫技術開發(fā)了SQL解析器,包括SQL解析,生成查詢計劃、優(yōu)化查詢計劃、執(zhí)行查詢技術等,但與傳統(tǒng)數(shù)據(jù)庫不同,Tajo最終執(zhí)行查詢計劃時借鑒了MapReduce的設計思想,它將查詢計劃轉化為一系列任務,這樣,執(zhí)行查詢計劃實際上就是執(zhí)行這些任務,而每個任務是一個計算單位,同Map Task和Reduce Task一樣,它可以重復執(zhí)行、有進度匯報等,這樣,Tajo可以直接使用MapReduce中的容錯、推測執(zhí)行等機制。此外,Tajo使用YARN進行資源管理。

我在前一篇博文《Apache Tez:一個運行在YARN之上支持DAG作業(yè)的計算框架》中介紹了Tez,其中談到Hive+Tez,經Tez優(yōu)化后的Hive是一個非常有前景的項目,此外,Tajo也談到,將來不排除使用Tez作為底層計算框架的可能:

Besides, Tez has some overlapping functions with Tajo. However, Tez is in the pre-alpha stage and may be a prototype. When Tez becomes feasible, Tajo could use Tez as an underlying framework according to the applicability. However, Tajo will still use its row/native columnar execution engine and its optimizer. Tajo may be potentially the first application of Tez.


3.總結

真正可能取代Hive的是Tenzing或者Tajo這樣的系統(tǒng),而不是類似Dremel或者Impala的系統(tǒng)。后者在擴展性、SQL表達能力(主要是它的嵌套存儲模型導致的)和容錯性等方面遠遠差于Hive/Tenzing/Tajo,正如Dremel論文所述,Dremel通常與MR結合使用,設計動機并不是取代MR,而是使某些場景下的計算更加高效。此外,Dremel和Impala是一種計算系統(tǒng),它們需要計算資源,卻沒有集成到當前發(fā)展迅猛的資源管理系統(tǒng)YARN中,這意味著,如果采用Impala這樣的系統(tǒng),你只能多帶帶搭一個獨立的專有集群,無法做到資源共享。即使Impala成熟了,如果Hive的取代品(比如Tajo)沒有成熟,則長期時間內,大部分公司仍然主要采用Hive(這時候,Hortonworks的Hive+Tez就有用武之地了)進行大數(shù)據(jù)處理,而Impala僅用于進一步處理Hive輸出的結果或者用于某一類適合場景的應用(畢竟這類系統(tǒng)的SQL表達能力有限,容錯性和擴展性差)。

就Tajo而言,目前活躍度很低,只有韓國大學的數(shù)據(jù)庫實驗室的幾個人在開發(fā),離真正的可用還有很長時間,但它已經邁出了第一步,即成為Apache的項目,讓更多的人參與進來。

4.參考資料

Tajo’s slide

Tajo: A Distributed Data Warehouse System on Large Clusters.

Tenzing: A SQL Implementation On The MapReduce Framework

Dremel: Interactive Analysis of Web-Scale Datasets


by 西成懂 under CC-BY

文章版權歸作者所有,未經允許請勿轉載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

轉載請注明本文地址:http://systransis.cn/yun/35713.html

相關文章

發(fā)表評論

0條評論

最新活動
閱讀需要支付1元查看
<