HBase实践 —— hive-hbase交互集成实践总结

8 篇文章 2 订阅

hive和hbase那些版本是相互兼容的

官网说,hive0.90hbase0.92是兼容的,
早期的hive版本与hbase0. 890.0兼容;
hive1.xhbase0.98.x或则更低版本是兼容的。
hive2.xhbase1.x及比hbase1.x更高版本兼容;

由于笔者在实践中使用的是hbase1.xhive1.x。如果想hbase1.xhive1.x整合,需要编译hive-hbase-handler代码。

交互配置:

1、配置hive、hbase环境变量,已有不在配

#配置hive、hbase环境变量,已有不在配
ln -s $HBASE_HOME/lib/hbase-common-1.4.9.jar  $HIVE_HOME/lib/hbase-common-1.4.9.jar
ln -s $HBASE_HOME/lib/hbase-server-1.4.9.jar $HIVE_HOME/lib/hbase-server-1.4.9.jar
ln -s $HBASE_HOME/lib/hbase-client-1.4.9.jar $HIVE_HOME/lib/hbase-client-1.4.9.jar
ln -s $HBASE_HOME/lib/hbase-protocol-1.3.1.jar $HIVE_HOME/lib/hbase-protocol-1.3.1.jar
ln -s $HBASE_HOME/lib/hbase-it-1.4.9.jar $HIVE_HOME/lib/hbase-it-1.4.9.jar
ln -s $HBASE_HOME/lib/htrace-core-3.1.0-incubating.jar $HIVE_HOME/lib/htrace-core-3.1.0-incubating.jar
ln -s $HBASE_HOME/lib/hbase-hadoop2-compat-1.4.9.jar $HIVE_HOME/lib/hbase-hadoop2-compat-1.4.9.jar
ln -s $HBASE_HOME/lib/hbase-hadoop-compat-1.4.9.jar $HIVE_HOME/lib/hbase-hadoop-compat-1.4.9.jar

2、在$HIVE_HOME/conf/hive-site.xml中修改Zookeeper配置:

<property>
	<name>hive.zookeeper.quorum</name>
	<value>kb-testhadoop01</value>
	<description>
		List of ZooKeeper servers to talk to. This is needed for:
		1. Read/write locks - when hive.lock.manager is set to
		org.apache.hadoop.hive.ql.lockmgr.zookeeper.ZooKeeperHiveLockManager,
		2. When HiveServer2 supports service discovery via Zookeeper.
		3. For delegation token storage if zookeeper store is used, if
		hive.cluster.delegation.token.store.zookeeper.connectString is not set
		4. LLAP daemon registry service
	</description>
</property>
<property>
	<name>hive.zookeeper.client.port</name>
	<value>2181</value>
	<description>
		The port of ZooKeeper servers to talk to.
		If the list of Zookeeper servers specified in hive.zookeeper.quorum
		does not contain port numbers, this value is used.
	</description>
</property>

测试:

1、在Hive中创建表同时关联HBase

CREATE TABLE test.hive_hbase_user_info_table
(
   id string,
   name string,
   age int,
   sex string
) 
STORED BY 'org.apache.hadoop.hive.hbase.HBaseStorageHandler'
WITH SERDEPROPERTIES ("hbase.columns.mapping" = ":key,info:name,info:age,info:sex") 
TBLPROPERTIES ("hbase.table.name" = "hbase_user_info_table");

完成之后,可以分别进入Hive(use test ;show tables;)HBase(list)查看,都生成了对应的表。

2、建立中间表进行数据交互

#建立中间表
CREATE TABLE test.user_info(
   id string,
   name string,
   age int,
   sex string)
row format delimited fields terminated by '\t';
#加载数据到中间表
load data local inpath '/home/hadoop/datas/emp.txt' into table test.user_info;
#将中间表数据插入到hive-hbase映射表中
insert into table test.hive_hbase_user_info_table select * from test.user_info;
#在hive-hbase映射表中查询数据
select * from test.hive_hbase_user_info_table;
#在hbase中查询数据
scan 'hbase_user_info_table';

3、建立外部表进行映射,用于hive分析查询hbase

#建立hive分析映射表
CREATE EXTERNAL TABLE relevance_hbase_user_info(
   id string,
   name string,
   age int,
   sex string)
STORED BY 'org.apache.hadoop.hive.hbase.HBaseStorageHandler'
WITH SERDEPROPERTIES ("hbase.columns.mapping" = ":key,info:name,info:age,info:sex") 
TBLPROPERTIES ("hbase.table.name" = "hbase_user_info_table");
#查询数据
select * from relevance_hbase_user_info;

结果:

经过以上操作可以从 hive中查询到了hbase的数据。
在这里插入图片描述

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

扫地增

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值