`

Hive:用Java代码通过JDBC连接Hiveserver

    博客分类:
  • hive
 
阅读更多

我们可以通过CLI、Client、Web UI等Hive提供的用户接口来和Hive通信,但这三种方式最常用的是CLI;Client 是Hive的客户端,用户连接至 Hive Server。在启动 Client 模式的时候,需要指出Hive Server所在节点,并且在该节点启动 Hive Server。 WUI 是通过浏览器访问 Hive。今天我们来谈谈怎么通过HiveServer来操作Hive。
  Hive提供了jdbc驱动,使得我们可以用Java代码来连接Hive并进行一些类关系型数据库的sql语句查询等操作。同关系型数据库一样,我们也需要将Hive的服务打开;在Hive 0.11.0版本之前,只有HiveServer服务可用,你得在程序操作Hive之前,必须在Hive安装的服务器上打开HiveServer服务,如下:

1 [wyp@localhost /home/q/hive-0.11.0]$ bin/hive --service hiveserver -p 10002
2 Starting Hive Thrift Server

上面代表你已经成功的在端口为10002(默认的端口是10000)启动了hiveserver服务。这时候,你就可以通过Java代码来连接hiveserver,代码如下:

01 package com.wyp;
02 /**
03  * User: 过往记忆
04  * Blog: http://www.iteblog.com/
05  * Date: 13-11-27
06  * Time: 下午5:52
07  */
08 import java.sql.SQLException;
09 import java.sql.Connection;
10 import java.sql.ResultSet;
11 import java.sql.Statement;
12 import java.sql.DriverManager;
13  
14 public class HiveJdbcTest {
15      
16     private static String driverName =
17                    "org.apache.hadoop.hive.jdbc.HiveDriver";
18    
19     public static void main(String[] args)
20                             throws SQLException {
21         try {
22             Class.forName(driverName);
23         catch (ClassNotFoundException e) {
24             e.printStackTrace();
25             System.exit(1);
26         }
27  
28         Connection con = DriverManager.getConnection(
29                            "jdbc:hive://localhost:10002/default""wyp""");
30         Statement stmt = con.createStatement();
31         String tableName = "wyphao";
32         stmt.execute("drop table if exists " + tableName);
33         stmt.execute("create table " + tableName +
34                                      " (key int, value string)");
35         System.out.println("Create table success!");
36         // show tables
37         String sql = "show tables '" + tableName + "'";
38         System.out.println("Running: " + sql);
39         ResultSet res = stmt.executeQuery(sql);
40         if (res.next()) {
41             System.out.println(res.getString(1));
42         }
43  
44         // describe table
45         sql = "describe " + tableName;
46         System.out.println("Running: " + sql);
47         res = stmt.executeQuery(sql);
48         while (res.next()) {
49             System.out.println(res.getString(1) + "\t" + res.getString(2));
50         }
51  
52  
53         sql = "select * from " + tableName;
54         res = stmt.executeQuery(sql);
55         while (res.next()) {
56             System.out.println(String.valueOf(res.getInt(1)) + "\t"
57                                                + res.getString(2));
58         }
59  
60         sql = "select count(1) from " + tableName;
61         System.out.println("Running: " + sql);
62         res = stmt.executeQuery(sql);
63         while (res.next()) {
64             System.out.println(res.getString(1));
65         }
66     }
67 }

编译上面的代码,之后就可以运行(我是在集成开发环境下面运行这个程序的),结果如下:

01 Create table success!
02 Running: show tables 'wyphao'
03 wyphao
04 Running: describe wyphao
05 key                     int                
06 value                   string             
07 Running: select count(1) from wyphao
08 0
09  
10 Process finished with exit code 0
  如果你想在脚本里面运行,请将上面的程序打包成jar文件,并将上面的依赖库放在/home/wyp/lib/(这个根据你自己的情况弄)中,同时加入到运行的环境变量,脚本如下:

 

01 #!/bin/bash
02 HADOOP_HOME=/home/q/hadoop-2.2.0
03 HIVE_HOME=/home/q/hive-0.11.0-bin
04  
05 CLASSPATH=$CLASSPATH:
06  
07 for i in /home/wyp/lib/*.jar ; do
08     CLASSPATH=$CLASSPATH:$i
09 done
10  
11 echo $CLASSPATH
12 /home/q/java/jdk1.6.0_20/bin/java -cp  \
13    $CLASSPATH:/export1/tmp/yangping.wu/OutputText.jar  com.wyp.HiveJdbcTest

上面是用Java连接HiveServer,而HiveServer本身存在很多问题(比如:安全性、并发性等);针对这些问题,Hive0.11.0版本提供了一个全新的服务:HiveServer2,这个很好的解决HiveServer存在的安全性、并发性等问题。这个服务启动程序在${HIVE_HOME}/bin/hiveserver2里面,你可以通过下面的方式来启动HiveServer2服务:

1 $HIVE_HOME/bin/hiveserver2

也可以通过下面的方式启动HiveServer2

1 $HIVE_HOME/bin/hive --service hiveserver2

两种方式效果都一样的。但是以前的程序需要修改两个地方,如下所示:

01 private static String driverName = "org.apache.hadoop.hive.jdbc.HiveDriver";
02 改为
03 private static String driverName = "org.apache.hive.jdbc.HiveDriver";
04  
05  
06  
07 Connection con = DriverManager.getConnection(
08                            "jdbc:hive://localhost:10002/default""wyp""");
09 改为
10 Connection con = DriverManager.getConnection(
11                            "jdbc:hive2://localhost:10002/default""wyp""");

其他的不变就可以了。

  这里顺便说说本程序所依赖的jar包,一共有以下几个:

 

1 hadoop-2.2.0/share/hadoop/common/hadoop-common-2.2.0.jar
2 $HIVE_HOME/lib/hive-exec-0.11.0.jar
3 $HIVE_HOME/lib/hive-jdbc-0.11.0.jar
4 $HIVE_HOME/lib/hive-metastore-0.11.0.jar 
5 $HIVE_HOME/lib/hive-service-0.11.0.jar  
6 $HIVE_HOME/lib/libfb303-0.9.0.jar  
7 $HIVE_HOME/lib/commons-logging-1.0.4.jar 
8 $HIVE_HOME/lib/slf4j-api-1.6.1.jar

  如果你是用Maven,加入以下依赖

01 <dependency>
02         <groupId>org.apache.hive</groupId>
03         <artifactId>hive-jdbc</artifactId>
04         <version>0.11.0</version>
05 </dependency>
06  
07 <dependency>
08         <groupId>org.apache.hadoop</groupId>
09         <artifactId>hadoop-common</artifactId>
10         <version>2.2.0</version>
11 </dependency>

本博客文章除特别声明,全部都是原创!
尊重原创,转载请注明: 转载自过往记忆(http://www.iteblog.com/)
本文链接: 【Hive:用Java代码通过JDBC连接Hiveserver】(http://www.iteblog.com/archives/846)

分享到:
评论

相关推荐

    计算机发展与计算机应用概述.pdf

    计算机发展与计算机应用概述.pdf

    计算机二级公共基础知识全集合.pdf

    计算机二级公共基础知识全集合.pdf

    计算机机试答案.pdf

    计算机机试答案.pdf

    基于STM32F103的750W全桥逆变器并离网设计方案及其实现

    内容概要:本文详细介绍了基于STM32F103RCT6的750W全桥逆变器设计方案,涵盖硬件电路设计、软件编程以及保护机制等方面。硬件部分包括主控芯片的选择、PWM配置、Boost升压电路、PCB布局优化等;软件部分涉及并离网切换的状态机设计、过流保护、风扇控制算法、并机功能实现等。文中还分享了许多实战经验和调试技巧,如死区时间配置、电流采样方法、并网同步算法等。 适合人群:具有一定电子电路和嵌入式开发基础的技术人员,尤其是从事逆变器及相关电力电子产品开发的工程师。 使用场景及目标:适用于希望深入了解逆变器工作原理和技术实现的开发者,特别是那些需要掌握并离网切换、高效电源管理及可靠保护机制的人群。目标是帮助读者构建一个稳定可靠的逆变器系统,能够应对各种复杂的工作环境。 其他说明:本文不仅提供了详细的理论讲解,还有丰富的代码片段和实践经验分享,有助于读者更好地理解和应用相关技术。

    基于Simulink的单相全桥逆变器仿真与优化:MATLAB环境下的详细实现

    内容概要:本文详细介绍了如何利用Simulink在MATLAB环境中搭建单相全桥逆变器的仿真模型。首先,通过构建H桥结构,连接直流电源和RL负载,并引入PWM控制器进行开关管的控制。接着,针对仿真过程中遇到的各种问题,如谐波失真、开关管直通等问题,提出了具体的解决方案,包括加入LC滤波器、设置死区时间和优化PWM参数等。此外,还探讨了通过MATLAB脚本自动化测试不同参数组合的方法,以及如何提高电压利用率和降低谐波失真。最终,通过对仿真结果的分析,验证了所提方法的有效性和优越性。 适合人群:电力电子工程师、科研人员、高校学生等对逆变器仿真感兴趣的群体。 使用场景及目标:适用于研究和开发高效、稳定的逆变器系统,旨在通过仿真手段减少实验成本,优化设计方案,提高系统的性能指标。 其他说明:文中提供了详细的建模步骤和技术细节,帮助读者更好地理解和掌握相关技术和方法。同时,强调了仿真参数的选择和优化对于获得理想仿真结果的重要性。

    计算机红外通信.pdf

    计算机红外通信.pdf

    软考考试学习必备资料.md

    软考考试学习必备资料.md

    基于cornerstonejs开发移动端

    基于cornerstonejs开发移动端

    JavaScript网页设计高级案例:构建交互式图片画廊#JavaScript

    构建交互式图片画廊

    在学习Wpf的过程中,手搓了一个2048

    源码

    Bosch Rexroth IndraWorks Ds IndraWorks Ds 14V16.310.0

    Bosch Rexroth IndraWorks Ds IndraWorks Ds 14V16.310.0

    java面向对象 - 类与对象

    java面向对象 - 类与对象

    电机控制领域无感FOC算法的AT32平台实现及其鲁棒性优化

    内容概要:本文详细介绍了基于AT32平台的无感FOC(Field-Oriented Control)控制算法,特别是针对永磁同步电机(PMSM)和无刷直流电机(BLDC)的位置速度观测器实现。文章首先展示了启动策略的独特之处,即跳过传统前馈强拖阶段,直接利用矢量控制环和观测器协同启动。接着深入探讨了磁链观测器的核心算法,包括磁链积分、反正切求角度以及速度估算部分使用的改良版PLL。此外,文中还提到了容差配置模块,用于提高系统的鲁棒性和稳定性。最后,强调了模块间良好的解耦设计,使得各功能模块拥有明确的输入输出接口,增强了代码的可维护性和移植性。 适合人群:从事电机控制系统开发的技术人员,尤其是对无感FOC算法感兴趣的工程师。 使用场景及目标:适用于需要高精度、快速响应的电机控制系统开发项目,旨在提升系统的鲁棒性和稳定性,特别是在电机参数存在偏差的情况下依然能够保持良好性能。 其他说明:文章不仅提供了详细的代码实现,还分享了许多实用的经验和技术细节,如启动策略、磁链观测器的物理本质、速度估算方法等,有助于读者更好地理解和应用无感FOC算法。

    计算机机房de设置与维护.pdf

    计算机机房de设置与维护.pdf

    《Java 面试进阶指北 》 质量很高,专为面试打造

    《Java 面试进阶指北 》 质量很高,专为面试打造

    外转子开关磁阻电机多目标优化的NSGA-II算法实现与Matlab代码解析

    内容概要:本文详细介绍了外转子开关磁阻电机(ER-SRM)的多目标优化方法,主要采用NSGA-II算法进行优化。文章首先解释了为什么ER-SRM比传统内转子电机更难以优化,接着展示了如何利用NSGA-II算法解决这一难题。文中提供了详细的Matlab代码,包括种群初始化、交叉变异操作、非支配排序以及目标函数的定义。此外,还讨论了优化过程中的一些注意事项,如初始种群多样性的保持、交叉变异参数的选择、目标函数的设计等。最后,通过具体的案例和图表展示了优化结果及其应用价值。 适合人群:从事电机设计与优化的研究人员和技术人员,尤其是对外转子开关磁阻电机感兴趣的读者。 使用场景及目标:适用于需要同时优化电机效率、转矩波动和制造成本等多种目标的情况。通过NSGA-II算法,可以在多个相互冲突的目标间找到最佳平衡点,从而提高电机的整体性能。 其他说明:文章不仅提供了完整的Matlab代码实现,还分享了许多实践经验,如参数设置的经验公式、常见错误及解决方案等。这对于理解和掌握NSGA-II算法的实际应用非常有帮助。

    "慢行智远"是一款专业的串口数据采集与波形分析软件 软件支持多通道波形显示、数据记录、协议解析等功能,界面友好,操作简便,是您进行串口通信与数据分析的得力助手

    慢行智远V2.0"是一款专业的串口数据采集与信号分析软件,集成了多通道数据采集、实时波形显示、FFT频谱分析、FIR滤波处理等高级功能。软件提供直观的用户界面,支持亮色/暗色两种主题,具备强大的数据处理与可视化能力。核心功能包括: 全面的串口通信支持(多种波特率、数据位、停止位、校验位配置) 多通道(最多4通道)波形实时显示与分析 高级信号处理(FFT频谱分析、FIR滤波、信号平滑等) 智能数据管理(断行数据处理、大数据量优化) 数据记录与导出(文本、CSV、图像多种格式) 自适应界面设计(支持高DPI显示、暗色主题) 适用人群 嵌入式开发工程师:需要通过串口调试单片机、开发板等嵌入式设备 电子工程师:进行电路测试、信号采集与分析的专业人员 工业自动化技术人员:监测工业设备数据、进行状态分析 科研教育工作者:用于实验数据采集、科学研究与教学演示 医疗设备开发人员:分析生物电信号、开发医疗监测设备 物联网开发者:调试传感器网络、分析传感器数据 硬件测试工程师:进行产品质量检测、性能评估 使用场景及目标 研发调试场景 单片机开发:实时监控传感器数据、调试通信协议、观察系统运行状态等等

    计算机基础- 图.pdf

    计算机基础- 图.pdf

    基于MATLAB和YALMIP的孤岛微电网MILP调度优化:最小化甩负荷与发电浪费

    内容概要:本文详细介绍了如何利用MATLAB和YALMIP工具箱构建并优化孤岛微电网的混合整数线性规划(MILP)调度模型。主要内容涵盖模型搭建的关键步骤,如定义决策变量、设置约束条件(尤其是电池充放电互斥约束)、处理光伏出力预测、设定目标函数以及选择求解器参数。文中强调了模型的实际应用场景,即在光伏板发电、电池储能和用户用电之间寻找最佳平衡,确保最小化甩负荷和发电浪费。此外,作者分享了一些实用技巧,如通过调整甩负荷惩罚系数α来优化调度策略,以及如何有效配置GUROBI求解器以缩短计算时间。 适合人群:从事电力系统优化、微电网调度研究的专业人士,以及对混合整数线性规划感兴趣的科研人员和技术开发者。 使用场景及目标:适用于需要精确控制发电、储电和用电的孤岛微电网系统。目标是在满足用户电力需求的同时,最大化利用可再生能源,减少化石燃料消耗,并延长电池使用寿命。 其他说明:文中提供了大量MATLAB代码片段,帮助读者更好地理解和实现具体的建模方法。同时,作者还提到了一些常见的陷阱和优化建议,有助于提高模型性能和求解效率。

    2025大模型时代的新能源汽车自动驾驶发展趋势.pdf

    2025大模型时代的新能源汽车自动驾驶发展趋势

Global site tag (gtag.js) - Google Analytics