自拍偷在线精品自拍偷,亚洲欧美中文日韩v在线观看不卡

一文看懂HIVE和HBASE的區(qū)別

大數(shù)據(jù)
Apache HBase是一種Key/Value系統(tǒng),它運(yùn)行在HDFS之上。和Hive不一樣,Hbase的能夠在它的數(shù)據(jù)庫(kù)上實(shí)時(shí)運(yùn)行,而不是運(yùn)行MapReduce任務(wù)。Hive被分區(qū)為表格,表格又被進(jìn)一步分割為列簇。

兩者分別是什么?

Apache Hive是一個(gè)構(gòu)建在hadoop基礎(chǔ)設(shè)施之上的數(shù)據(jù)倉(cāng)庫(kù)。通過(guò)Hive可以使用HQL語(yǔ)言查詢存放在HDFS上的數(shù)據(jù)。HQL是一種類SQL語(yǔ)言,這種語(yǔ)言最終被轉(zhuǎn)化為Map/Reduce. 雖然Hive提供了SQL查詢功能,但是Hive不能夠進(jìn)行交互查詢–因?yàn)樗荒軌蛟贖aoop上批量的執(zhí)行Hadoop。

[[198301]]

Apache HBase是一種Key/Value系統(tǒng),它運(yùn)行在HDFS之上。和Hive不一樣,Hbase的能夠在它的數(shù)據(jù)庫(kù)上實(shí)時(shí)運(yùn)行,而不是運(yùn)行MapReduce任務(wù)。Hive被分區(qū)為表格,表格又被進(jìn)一步分割為列簇。列簇必須使用schema定義,列簇將某一類型列集合起來(lái)(列不要求schema定義)。例如,“message”列簇可能包含:“to”, ”from” “date”, “subject”, 和”body”. 每一個(gè) key/value對(duì)在Hbase中被定義為一個(gè)cell,每一個(gè)key由row-key,列簇、列和時(shí)間戳。在Hbase中,行是key/value映射的集合,這個(gè)映射通過(guò)row-key來(lái)唯一標(biāo)識(shí)。Hbase利用Hadoop的基礎(chǔ)設(shè)施,可以利用通用的設(shè)備進(jìn)行水平的擴(kuò)展。

兩者的特點(diǎn)

Hive幫助熟悉SQL的人運(yùn)行MapReduce任務(wù)。因?yàn)樗荍DBC兼容的,同時(shí),它也能夠和現(xiàn)存的SQL工具整合在一起。運(yùn)行Hive查詢會(huì)花費(fèi)很長(zhǎng)時(shí)間,因?yàn)樗鼤?huì)默認(rèn)遍歷表中所有的數(shù)據(jù)。雖然有這樣的缺點(diǎn),一次遍歷的數(shù)據(jù)量可以通過(guò)Hive的分區(qū)機(jī)制來(lái)控制。分區(qū)允許在數(shù)據(jù)集上運(yùn)行過(guò)濾查詢,這些數(shù)據(jù)集存儲(chǔ)在不同的文件夾內(nèi),查詢的時(shí)候只遍歷指定文件夾(分區(qū))中的數(shù)據(jù)。這種機(jī)制可以用來(lái),例如,只處理在某一個(gè)時(shí)間范圍內(nèi)的文件,只要這些文件名中包括了時(shí)間格式。

HBase通過(guò)存儲(chǔ)key/value來(lái)工作。它支持四種主要的操作:增加或者更新行,查看一個(gè)范圍內(nèi)的cell,獲取指定的行,刪除指定的行、列或者是列的版本。版本信息用來(lái)獲取歷史數(shù)據(jù)(每一行的歷史數(shù)據(jù)可以被刪除,然后通過(guò)Hbase compactions就可以釋放出空間)。雖然HBase包括表格,但是schema僅僅被表格和列簇所要求,列不需要schema。Hbase的表格包括增加/計(jì)數(shù)功能。

限制

Hive目前不支持更新操作。另外,由于hive在hadoop上運(yùn)行批量操作,它需要花費(fèi)很長(zhǎng)的時(shí)間,通常是幾分鐘到幾個(gè)小時(shí)才可以獲取到查詢的結(jié)果。Hive必須提供預(yù)先定義好的schema將文件和目錄映射到列,并且Hive與ACID不兼容。

HBase查詢是通過(guò)特定的語(yǔ)言來(lái)編寫的,這種語(yǔ)言需要重新學(xué)習(xí)。類SQL的功能可以通過(guò)Apache Phonenix實(shí)現(xiàn),但這是以必須提供schema為代價(jià)的。另外,Hbase也并不是兼容所有的ACID特性,雖然它支持某些特性。最后但不是最重要的–為了運(yùn)行Hbase,Zookeeper是必須的,zookeeper是一個(gè)用來(lái)進(jìn)行分布式協(xié)調(diào)的服務(wù),這些服務(wù)包括配置服務(wù),維護(hù)元信息和命名空間服務(wù)。

應(yīng)用場(chǎng)景

Hive適合用來(lái)對(duì)一段時(shí)間內(nèi)的數(shù)據(jù)進(jìn)行分析查詢,例如,用來(lái)計(jì)算趨勢(shì)或者網(wǎng)站的日志。Hive不應(yīng)該用來(lái)進(jìn)行實(shí)時(shí)的查詢。因?yàn)樗枰荛L(zhǎng)時(shí)間才可以返回結(jié)果。

Hbase非常適合用來(lái)進(jìn)行大數(shù)據(jù)的實(shí)時(shí)查詢。Facebook用Hbase進(jìn)行消息和實(shí)時(shí)的分析。它也可以用來(lái)統(tǒng)計(jì)Facebook的連接數(shù)。

總結(jié)

Hive和Hbase是兩種基于Hadoop的不同技術(shù)–Hive是一種類SQL的引擎,并且運(yùn)行MapReduce任務(wù),Hbase是一種在Hadoop之上的NoSQL 的Key/vale數(shù)據(jù)庫(kù)。當(dāng)然,這兩種工具是可以同時(shí)使用的。就像用Google來(lái)搜索,用FaceBook進(jìn)行社交一樣,Hive可以用來(lái)進(jìn)行統(tǒng)計(jì)查詢,HBase可以用來(lái)進(jìn)行實(shí)時(shí)查詢,數(shù)據(jù)也可以從Hive寫到Hbase,設(shè)置再?gòu)腍base寫回Hive。

責(zé)任編輯:武曉燕 來(lái)源: 36大數(shù)據(jù)
相關(guān)推薦

2021-07-05 00:00:55

TomcatNginxApache

2021-04-15 09:41:30

云計(jì)算PAASSAAS

2020-03-31 14:40:24

HashMap源碼Java

2016-08-18 00:21:12

網(wǎng)絡(luò)爬蟲(chóng)抓取網(wǎng)絡(luò)

2017-05-31 11:47:21

互聯(lián)網(wǎng)

2024-08-12 12:30:27

2023-07-07 11:36:29

人工智能基礎(chǔ)模型

2023-06-27 07:04:39

2023-07-14 08:00:00

ORMRust ORMSQL

2025-01-20 09:15:00

iOS 18.3蘋果iOS 18

2021-08-02 06:56:19

TypeScript編程語(yǔ)言編譯器

2018-02-02 11:17:42

IaaSPaaSSaaS

2019-07-01 09:22:15

Linux操作系統(tǒng)硬件

2019-05-22 09:50:42

Python沙箱逃逸網(wǎng)絡(luò)攻擊

2019-07-09 10:14:04

云計(jì)算行業(yè)科技

2019-07-11 11:39:31

云計(jì)算操作系統(tǒng)IaaS

2020-07-31 12:52:40

OLEDQLEDMicroLED

2018-05-31 09:46:04

車聯(lián)網(wǎng)智能交通ITS

2024-04-10 13:50:41

CentOSUbuntu操作系統(tǒng)

2019-07-05 13:19:43

技術(shù)團(tuán)隊(duì)組建績(jī)效考核
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號(hào)