Hive的几种启动方式

A. shell客户端启动

使用命令:/export/server/hive/bin/hive 直接启动。

重启hive服务命令 hive服务启动_hive

B. 远程访问Hive

shell客户端启动只能启动本机上的Hive,如果要在别的客户端上启动,就不能使用这个方式,所以这里提供一种远程访问的启动方式。

1. 在Hive的bin目录下可以启动一个服务器来接受远程服务。

进入Hive的安装目录,使用命令:bin/hiveserver2,启动Hive远程服务器。

启动后,光标会在下一行闪烁,不会再有任何进展。

重启hive服务命令 hive服务启动_Hadoop_02

克隆一个会话出来,查看一下进程,会发现多了一个 runjar 的进程,这个进程就是刚刚启动的Hive服务进程。

重启hive服务命令 hive服务启动_hive_03

2. 为了模拟远程访问Hive,先将Hive安装文件复制到node-3 节点上。

在安装Hive的节点上(node-1)上使用命令:scp -r /export/server/hive/ root@node-3:/export/server/

重启hive服务命令 hive服务启动_客户端_04

注意:因为是直接拷贝过来的,所以node-3 上面的元数据库信息需要和系统的保持一致。(这里是ok的)

3. Hive的bin目录下有一个命令能够远程访问Hive服务器。

先进入Hive安装目录,然后启动bin目录下的beeline 程序。

cd /export/server/hive/
bin/beeline

重启hive服务命令 hive服务启动_重启hive服务命令_05

启动完后对准备验证。

在节点 node-3 上使用命令:! connect jdbc:hive2://node-1:10000 开始远程连接Hive

然后输入用户名回车,输入密码回车。

重启hive服务命令 hive服务启动_Hive_06

结果:

重启hive服务命令 hive服务启动_客户端_07

C. 类似A方案

使用命令:bin/hive -e 'sql语句' 进行操作,比如:bin/hive -e 'select * from t_test'

这个与A方案的区别是:A方案操作完后还是在Hive的shell客户端里,但是C方案操作完后还是在Linux的shell客户端里。