HBase和Hive整合

HBase版本:1.2.6
Hive版本:1.2.1

1. 把HIVE_HOME/lib/hive-hbase-handler-1.2.1.jar 复制到HBASE_HOME/lib/下

2. 把HBASE_HOME/lib下所有的jar 复制到HIVE_HOME/lib/下

# -n 表示对于目标路径下已经存在的文件,则不复制过去
cp -n $HBASE_HOME/lib/* $HIVE_HOME/lib/

3. 修改hive-site.xml文件,增加hbase的zookeeper集群信息

<property>
    <name>hbase.zookeeper.quorum</name>
    <value>node01:2181,node02:2181,node03:2181</value>
</property>

hive集群和hbase集群的所有机器都要做以上修改

4. 验证

(1) 创建hbase表”student”

其中内容如下:

hbase(main):025:0> scan 'student'
ROW     COLUMN+CELL                                                                            
 0001   column=info:age, timestamp=1516139523768, value=15                                     
 0001   column=info:name, timestamp=1516139523388, value=Madeline                              
 0002   column=info:age, timestamp=1516139523820, value=16                                     
 0002   column=info:name, timestamp=1516139523469, value=Jed                                   
 0003   column=info:age, timestamp=1516139523862, value=17                                     
 0003   column=info:name, timestamp=1516139523607, value=Olivia                                
 0004   column=info:age, timestamp=1516139523908, value=18                                     
 0004   column=info:name, timestamp=1516139523680, value=Jed                                   
 0005   column=info:age, timestamp=1516139525527, value=19                                     
 0005   column=info:name, timestamp=1516139523725, value=Sarah

(2) 创建与该hbase表关联的hive表,需为外部表

  1. 关联所有列
CREATE EXTERNAL TABLE hive_student (key string,info map<string, string>)
STORED BY 'org.apache.hadoop.hive.hbase.HBaseStorageHandler'
WITH SERDEPROPERTIES ("hbase.columns.mapping" = ":key,info:")  
TBLPROPERTIES ("hbase.table.name" = "student");
hive> select * from hive_student;
OK
0001    {"age":"15","name":"Madeline"}
0002    {"age":"16","name":"Jed"}
0003    {"age":"17","name":"Olivia"}
0004    {"age":"18","name":"Jed"}
0005    {"age":"19","name":"Sarah"}

hive> select key, info['name'], info['age'] from hive_student;
OK
0001    Madeline    15
0002    Jed         16
0003    Olivia      17
0004    Jed         18
0005    Sarah       19
  1. 关联指定列
CREATE EXTERNAL TABLE hive_student_name (key string,name string)
STORED BY 'org.apache.hadoop.hive.hbase.HBaseStorageHandler'
WITH SERDEPROPERTIES ("hbase.columns.mapping" = ":key,info:name")  
TBLPROPERTIES ("hbase.table.name" = "student");
hive> select * from hive_student_name;
OK
0001    Madeline
0002    Jed
0003    Olivia
0004    Jed
0005    Sarah

5. 说明

1-3步骤不是必须的,如果没有进行1-3步骤的设置,那么想要让hive和hbase整合,每次进入hive命令行后,需要进行如下配置:

(1) 指定 hbase 所使用的 zookeeper 集群的地址:默认端口是 2181,可以不写

set hbase.zookeeper.quorum=node01:2181,node02:2181,node03:2181;

(2) 指定 hbase 在 zookeeper 中使用的根目录

set zookeeper.znode.parent=/var/zookeeper/local;

# 该路径在hbase-site.xml可以查询,你在搭建hbase集群的时候,这个参数是必须设置的
<property>
    <name>hbase.zookeeper.property.dataDir</name>
    <value>/var/zookeeper/local</value>
</property>

(3) 加入指定的处理 jar

add jar /home/hadoop/apps/hive-1.2.1/lib/hive-hbase-handler-1.2.1.jar;
    原文作者:CoderJed
    原文地址: https://www.jianshu.com/p/e788253fafc8
    本文转自网络文章,转载此文章仅为分享知识,如有侵权,请联系博主进行删除。
点赞