HiveServer2的HA理解 & 配置实现

好处 & 工作机制

使用HiveServer2的好处:
1. HiveServer2不用直接将HDFS和Metastore暴漏给用户(对比于使用hive-cli方式)
2. 通过HA机制(从Hive 0.14开始引入该机制),解决了负载均衡和并发的问题
3. 可以在Client端通过JDBC的方式,发起操作,与数据进行交互

配置HA之前,HiveServer2的工作机制:
这里写图片描述
对于这种情况,如果遇到Client端的并发比较少,就不会出事,但是一旦并发上去,一个HiveServer2实例挂掉了,那么就会导致所有的应用链接失效

对此,Hive在0.14开始,引入了HA机制,通过Zookeeper来实现HiveServer2的HA功能;Client端可以通过指定一个NameSpace去连接HiveServer2(这点与Hadoop HA类似),而不是通过指定某一个固定的ip:portt去连接:
这里写图片描述

HA配置实现

编辑每台机器上的hive-site.xml文件如下:

<property>
<name>hive.server2.support.dynamic.service.discovery</name>
<value>true</value>
</property>

<property>
<name>hive.server2.zookeeper.namespace</name>
<value>hiveserver2_zk</value>
</property>

<property>
<name>hive.zookeeper.quorum</name>
<value> zkNode1:2181,zkNode2:2181,zkNode3:2181</value>
</property>

<property>
<name>hive.zookeeper.client.port</name>
<value>2181</value>
</property>


<property>
<name>hive.server2.thrift.bind.host</name>
<value>0.0.0.0</value>
</property>

<property>
<name>hive.server2.thrift.port</name>
<value>10001</value> //两个HiveServer2实例的端口号要一致
</property>

注:Zookeeper自己去配置

启动HiveServer2

分别在2台机器上启动HiveServer2,可以发现在zk中,这2个都注册上来了

JDBC连接串解读

JDBC连接的URL格式为:
jdbc:hive2://<zookeeper quorum>/<dbName>;serviceDiscoveryMode=zooKeeper;zooKeeperNamespace=hiveserver2

其中:
<zookeeper quorum> 为Zookeeper的集群链接串,如zkNode1:2181,zkNode2:2181,zkNode3:2181
<dbName>为Hive数据库,默认为default
serviceDiscoveryMode=zooKeeper指定模式为zooKeeper
zooKeeperNamespace=hiveserver2指定ZK中的NameSpace,即参数hive.server2.zookeeper.namespace所定义,这里定义的为hiveserver2_zk

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值