CDH5.8 HBase安装Phoenix

1、phoenix的简介hbase的java api或者其语法很难用,可以认为phoenix是一个中间件,提供了访问hbase的另外的语法。本文档为在CDH环境上安装Phoenix。

2、下载CDH版Phoenix

git clone https://github.com/chiastic-security/phoenix-for-cloudera.git
cd phoenix-for-cloudera/
git branch –all
git checkout remotes/origin/4.8-HBase-1.2-cdh5.8

3、编译mvn clean package -DskipTests -Dcdh.flume.version=1.6.0

《CDH5.8 HBase安装Phoenix》 mvn

4、将编译打包好后的IdeaWorkspace\phoenix-for-cloudera-4.8-HBase-1.2-cdh5.8\phoenix-assembly\target\phoenix-4.8.0-cdh5.8.0.tar.gz解压phoenix-4.8.0-cdh5.8.0

《CDH5.8 HBase安装Phoenix》 tar zxvf XXXX

5、将phoenix-4.8.0-cdh5.8.0中的phoenix-4.8.0-cdh5.8.0-server.jar拷贝到每一个RegionServer下/opt/cloudera/parcels/CDH/lib/hbase/lib

6、重启hbase集群

7、将phoenix-4.8.0-cdh5.8.0放到我们集群中的某个目录下,进入phoenix-4.8.0-cdh5.8.0/bin目录,使用sqlline.py连接hbase,成功。

./sqlline.py zk:2181/hbase

《CDH5.8 HBase安装Phoenix》 sqlline.py连接hbase.png

8.执行上面一步是出现错误

《CDH5.8 HBase安装Phoenix》 hbase.table.sanity.checks.png

客户端 出现 hbase.table.sanity.checks 错误 将该参数 设置为false 客户端正常登录

<property>
<name>hbase.table.sanity.checks</name>
<value>false</value>
</property>

9.测试
创建STOCK_SYMBOL表

./sqlline.py zk:2181 ../examples/STOCK_SYMBOL.sql

加载测试数据

./psql.py zk ../examples/WEB_STAT.sql ../examples/WEB_STAT.csv ../examples/WEB_STAT_QUERIES.sql

查询数据

select * from WEB_STAT;

《CDH5.8 HBase安装Phoenix》 查询.png

10,创建index

create table TAB_PS_XDR2 ( K VARCHAR NOT NULL PRIMARY KEY, A VARCHAR, B VARCHAR, C VARCHAR, D VARCHAR, V VARCHAR) COMPRESSION=’SNAPPY’,SALT_BUCKETS=12,TTL=’7200′,VERSIONS=’5′;
create index CALLING_NUMBER2 on TAB_PS_XDR2 (A);
create index CALLED_NUMBER2 on TAB_PS_XDR2 (B);
create index IMSI2 on TAB_PS_XDR2 (C);
create index IMEI2 on TAB_PS_XDR2 (D);

《CDH5.8 HBase安装Phoenix》 createIndex.png

<property>
<name>hbase.regionserver.wal.codec</name> <value>org.apache.hadoop.hbase.regionserver.wal.IndexedWALEditCodec</value>
</property>

    原文作者:虾米在海飘
    原文地址: https://www.jianshu.com/p/6d2687cce817
    本文转自网络文章,转载此文章仅为分享知识,如有侵权,请联系博主进行删除。
点赞