當(dāng)前位置:首頁 > IT技術(shù) > 數(shù)據(jù)庫 > 正文

Phoenix——實現(xiàn)向HBase發(fā)送標(biāo)準(zhǔn)SQL語句
2021-09-13 11:36:24

寫在前面一:

本文總結(jié)基于HBase的SQL查詢系統(tǒng)——Salesforce?phoenix

Phoenix——實現(xiàn)向HBase發(fā)送標(biāo)準(zhǔn)SQL語句_sql

寫在前面二:

環(huán)境說明:

Phoenix——實現(xiàn)向HBase發(fā)送標(biāo)準(zhǔn)SQL語句_java_02

一、什么是Phoenix

摘自官網(wǎng):

Phoenix——實現(xiàn)向HBase發(fā)送標(biāo)準(zhǔn)SQL語句_sql_03

Phoenix是一個提供hbase的sql操作的框架,Phoenix是構(gòu)建在HBase之上的一個SQL中間層。

Phoenix全然使用Java編寫,代碼位于GitHub上,而且提供了一個client可嵌入的JDBC驅(qū)動。對于簡單的低延遲查詢,其性能量級為毫秒。對于百萬級別的行數(shù)來說,其性能量級為秒。Phoenix并非像HBase那樣
用于map-reduce job的,而是通過標(biāo)準(zhǔn)化的語言來訪問HBase數(shù)據(jù)的。

Phoenix最值得關(guān)注的特性:
1、嵌入式的JDBC驅(qū)動,實現(xiàn)了大部分的java.sql接口。包含元數(shù)據(jù)API
2、能夠通過多部行鍵或是鍵/值單元對列進行建模
3、完好的查詢支持,能夠使用多個謂詞以及優(yōu)化的掃描鍵
4、DDL支持:通過CREATE TABLE、DROP TABLE及ALTER TABLE來加入/刪除列
5、版本號化的模式倉庫:當(dāng)寫入數(shù)據(jù)時,快照查詢會使用恰當(dāng)?shù)哪J?br/>6、DML支持:用于逐行插入的UPSERT VALUES、用于同樣或不同表之間大量傳輸數(shù)據(jù)的UPSERT SELECT、用于刪除行的DELETE
7、通過client的批處理實現(xiàn)的有限的事務(wù)支持
8、單表——還沒有連接,同一時候二級索引也在開發(fā)其中
9、緊跟ANSI SQL標(biāo)準(zhǔn)

二、Phoenix原理

Phoenix基本原理是將一個對于HBase client來說比較復(fù)雜的查詢轉(zhuǎn)換成一系列Region Scan,結(jié)合coprocessor和custom ?filter在多臺Region Server上進行并行查詢。匯總各個Scan結(jié)果。

種種跡象表明。Phoenix應(yīng)該不是個優(yōu)化的OLAP系統(tǒng),更像是一個用于簡單單表查詢,過濾。排序,檢索的OLTP系統(tǒng)。 Phoenix 能夠為我們眼下大數(shù)據(jù)平臺提供比較便捷的數(shù)據(jù)操作能力(直接用jdbc方式),性能比較不錯。注意不要使用多表查詢就可以 。

?

三、Phoenix安裝配置

?

1、下載
phoenix-3.0.0-incubating.tar.gz
http://phoenix.incubator.apache.org/download.html#Installation
2、拷貝phoenix-3.0.0-incubating/common/phoenix-core-3.0.0-incubating.jar至$HBASE_HOME/lib/下
3、重新啟動HBase集群

若通過client訪問phoenix,需進行下面操作:
把phoenix-3.0.0-incubating/hadoop-1/phoenix-3.0.0-incubating-client.jar加入到Phoenix客戶端的類路徑下

四、訪問Phoenix

4.1、通過命令行

進入phoenix

cd?/home/yujianxin/hbase/phoenix/phoenix-3.0.0-incubating/bin
./sqlline.py slave3:2181

出現(xiàn)下面響應(yīng),說明成功安裝

Phoenix——實現(xiàn)向HBase發(fā)送標(biāo)準(zhǔn)SQL語句_數(shù)據(jù)_04

4.2、通過Java

?

<span style="font-family:Times New Roman;">Class.forName("org.apache.phoenix.jdbc.PhoenixDriver"); 
// connection string: jdbc:phoenix [ :<zookeeper quorum> [ :<port number> ] [ :<root node> ] ]
Connection connection = DriverManager.getConnection("jdbc:phoenix:slave3:2181");</span>

Phoenix——實現(xiàn)向HBase發(fā)送標(biāo)準(zhǔn)SQL語句_java_05

4.3、通過SQLclientSQuirrel訪問

下載地址:http://squirrel-sql.sourceforge.net/

再進行安裝配置就可以。


五、使用Phoenix

?

使用phoenix-3.0.0-incubating.tar.gz自帶的數(shù)據(jù)進行測試

Phoenix——實現(xiàn)向HBase發(fā)送標(biāo)準(zhǔn)SQL語句_java_06

當(dāng)中。WEB_STAT.sql的內(nèi)容例如以下:

Phoenix——實現(xiàn)向HBase發(fā)送標(biāo)準(zhǔn)SQL語句_數(shù)據(jù)_07

運行以上命令后,查看phoenix中的表:

Phoenix——實現(xiàn)向HBase發(fā)送標(biāo)準(zhǔn)SQL語句_安裝配置_08

Phoenix——實現(xiàn)向HBase發(fā)送標(biāo)準(zhǔn)SQL語句_java_09

Phoenix支持模糊查詢:

Phoenix——實現(xiàn)向HBase發(fā)送標(biāo)準(zhǔn)SQL語句_sql_10

查看HBase中的表,例如以下:

Phoenix——實現(xiàn)向HBase發(fā)送標(biāo)準(zhǔn)SQL語句_sql_11

就可以通過Phoenix這個構(gòu)建在HBase之上的SQL中間層,向HBase發(fā)送標(biāo)準(zhǔn)sql語句。對HBase進行操作。

?

?
?
?
?

本文摘自 :https://blog.51cto.com/u

開通會員,享受整站包年服務(wù)立即開通 >