前言:2007年,编写Pig虽然比MapReduce编程简单,但是还是要学习。于是Facebook发布了Hive,支持使用SQL语法进行大数据计算,写个Select语句进行数据查询,Hive会将SQL语句转化成MapReduce计算程序。这样,熟悉数据库的数据分析师和工程师便可以无门槛地使用大数据进行数据分析和处理了,Hive出现后大大降低了Hadoop的使用难度,迅速得到开发者和企业的追捧。


一、Hive简介

Hive 是一个构建在 Hadoop 之上的数据仓库,它可以将结构化的数据文件映射成表,并提供类 SQL 查 询功能,用于查询的 SQL 语句会被转化为 MapReduce 作业,然后提交到 Hadoop 上运行。

​Hive是基于Hadoop的一个数据仓库工具,用来进行数据提取、转化、加载,这是一种可以存储、查询和分析存储在Hadoop中的大规模数据的机制。hive数据仓库工具能将结构化的数据文件映射为一张数据库表,并提供SQL查询功能,能将SQL语句转变成MapReduce任务来执行。Hive的优点是学习成本低,可以通过类似SQL语句实现快速MapReduce统计,使MapReduce变得更加简单,而不必开发专门的MapReduce应用程序。hive十分适合对数据仓库进行统计分析。​

Hive特点

  • 简单、容易上手 (提供了类似 sql 的查询语言 hql),使得精通 sql 但是不了解 Java 编程的人也能很好地进行大数据分析;

  • 灵活性高,可以自定义用户函数 (UDF) 和存储格式;

  • 为超大的数据集设计的计算和存储能力,集群扩展容易;

  • 统一的元数据管理,可与 prestoimpalasparksql 等共享数据;

  • 执行延迟高,不适合做数据的实时处理,但适合做海量数据的离线处理。


二、Hive的体系架构

2.1 command-line shell & thrift/jdbc

可以用 command-line shell thriftjdbc 两种方式来操作数据:

command-line shell:通过 hive 命令行的的方式来操作数据;

thriftjdbc:通过 thrift 协议按照标准的 JDBC 的方式操作数据。

2.2 Metastore

Hive 中,表名、表结构、字段名、字段类型、表的分隔符等统一被称为元数据。所有的元数据默认 存储在 Hive 内置的 derby 数据库中,但由于 derby 只能有一个实例,也就是说不能有多个命令行客户 端同时访问,所以在实际生产环境中,通常使用 MySQL 代替 derby

Hive 进行的是统一的元数据管理,就是说你在 Hive 上创建了一张表,然后在 prestoimpala

sparksql 中都是可以直接使用的,它们会从 Metastore 中获取统一的元数据信息,同样的你在 presto /impalasparksql 中创建一张表,在 Hive 中也可以直接使用。

2.3 HQL的执行流程

Hive 在执行一条 HQL 的时候,会经过以下步骤:

1. 语法解析:Antlr 定义 SQL 的语法规则,完成 SQL 词法,语法解析,将 SQL 转化为抽象 语法树

AST Tree

2. 语义解析:遍历 AST Tree,抽象出查询的基本组成单元 QueryBlock

3. 生成逻辑执行计划:遍历 QueryBlock,翻译为执行操作树 OperatorTree

4. 优化逻辑执行计划:逻辑层优化器进行 OperatorTree 变换,合并不必要的

ReduceSinkOperator,减少 shuffle 数据量;

5. 生成物理执行计划:遍历 OperatorTree,翻译为 MapReduce 任务;

6. 优化物理执行计划:物理层优化器进行 MapReduce 任务的变换,生成最终的执行计划。


三、Hive数据类型

3.1 基本数据类型

Hive 表中的列支持以下基本数据类型:

TIMESTAMP 和 TIMESTAMP WITH LOCAL TIME ZONE 的区别如下:

  • TIMESTAMP WITH LOCAL TIME ZONE:用户提交时间给数据库时,会被转换成数据库所

  • 在的时区来保存。查询时则按照查询客户端的不同,转换为查询客户端所在时区的时间。

  • TIMESTAMP :提交什么时间就保存什么时间,查询时也不做任何转换。

3.2 隐式转换

Hive 中基本数据类型遵循以下的层次结构,按照这个层次结构,子类型到祖先类型允许隐式转换。例 如 INT 类型的数据允许隐式转换为 BIGINT 类型。额外注意的是:按照类型层次结构允许将 STRING 类 型隐式转换为 DOUBLE 类型。

3.3 复杂类型

3.4 示例

如下给出一个基本数据类型和复杂数据类型的使用示例:

CREATE TABLE students( name STRING,-- 姓名 ageINT, -- 年龄 subjectARRAY,--学科 score MAP, --各个学科考试成绩 addressSTRUCT --家庭居住地址) ROW FORMAT DELIMITED FIELDS TERMINATED BY "\t";

四、Hive内容格式

当数据存储在文本文件中,必须按照一定格式区别行和列,如使用逗号作为分隔符的 CSV 文件

(Comma-Separated Values) 或者使用制表符作为分隔值的 TSV 文件 (Tab-Separated Values)。但此时 也存在一个缺点,就是正常的文件内容中也可能出现逗号或者制表符。

所以 Hive 默认使用了几个平时很少出现的字符,这些字符一般不会作为内容出现在文件中。Hive默认 的行和列分隔符如下表所示。

使用示例如下:

CREATE TABLE page_view(viewTime INT, userid BIGINT) ROW FORMAT DELIMITEDFIELDS TERMINATED BY '\001'COLLECTION ITEMS TERMINATED BY '\002'MAP KEYS TERMINATED BY '\003' STORED AS SEQUENCEFILE;

五、Hive存储格式

5.1 支持的存储格式

Hive 会在 HDFS 为每个数据库上创建一个目录,数据库中的表是该目录的子目录,表中的数据会以文 件的形式存储在对应的表目录下。Hive 支持以下几种文件存储格式:

5.2 指定存储格式

通常在创建表的时候使用 STORED AS 参数指定:

各个存储文件类型指定方式如下:

  • STORED AS TEXTFILE

  • STORED AS SEQUENCEFILE

  • STORED AS ORC

  • STORED AS PARQUET

  • STORED AS AVRO

  • STORED AS RCFILE


六、内部表和外部表

内部表又叫做管理表 (Managed/Internal Table),创建表时不做任何指定,默认创建的就是内部表。想 要创建外部表 (External Table),则需要使用 External 进行修饰。 内部表和外部表主要区别如下:


六、Linux环境下Hive的安装

6.1、安装Hive

(1)下载并解压

下载所需版本的 Hive,这里我下载版本为 cdh5.15.2 。下载地址:http://archive.cloudera.com/cdh

5/cdh/5/

# 下载后进行解压 tar -zxvf hive-1.1.0-cdh5.15.2.tar.gz

(2)配置环境变量

添加环境变量:

vim /etc/profileexport HIVE_HOME=/usr/app/hive-1.1.0-cdh5.15.2export PATH=$HIVE_HOME/bin:$PATH

使得配置的环境变量立即生效:

source /etc/profile

(3)修改配置

1. hive-env.sh

进入安装目录下的 conf/ 目录,拷贝 Hive 的环境配置模板 flumeenv.sh.template

cp hive-env.sh.template hive-env.sh

修改 hiveenv.sh ,指定 Hadoop 的安装路径:

HADOOP_HOME=/usr/app/hadoop-2.6.0-cdh5.15.2

2. hive-site.xml

新建 hive-site.xml 文件,内容如下,主要是配置存放元数据的 MySQL 的地址、驱动、用户名和密码等信息:

 javax.jdo.option.ConnectionURLjdbc:mysql://hadoop001:3306/hadoop_hive?createDatabaseIfNotExist=true javax.jdo.option.ConnectionDriverNamecom.mysql.jdbc.Driver javax.jdo.option.ConnectionUserNameroot javax.jdo.option.ConnectionPasswordroot 

(4)拷贝数据库驱动

MySQL 驱动包拷贝到 Hive 安装目录的 lib 目录下, MySQL 驱动的下载地址为:https://dev.mysql. com/downloads/connector/j/

(5)初始化元数据库

  • 当使用的 hive 1.x 版本时,可以不进行初始化操作,Hive 会在第一次启动的时候会自动进行初始化,但不会生成所有的元数据信息表,只会初始化必要的一部分,在之后的使用中用到其余表时会自动创建;

  • 当使用的 hive 2.x 版本时,必须手动初始化元数据库。初始化命令:

# schematool 命令在安装目录的 bin 目录下,由于上面已经配置过环境变量,在任意位置执行即可schematool -dbType mysql -initSchema

这里我使用的是 CDH hive1.1.0cdh5.15.2.tar.gz ,对应 Hive 1.1.0 版本,可以跳过这一

步。

(6)启动

由于已经将 Hive bin 目录配置到环境变量,直接使用以下命令启动,成功进入交互式命令行后执行 show databases 命令,无异常则代表搭建成功。

Mysql 中也能看到 Hive 创建的库和存放元数据信息的表

6.2、HiveServer2/beeline

Hive 内置了 HiveServer HiveServer2 服务,两者都允许客户端使用多种编程语言进行连接,但是 HiveServer 不能处理多个客户端的并发请求,因此产生了 HiveServer2HiveServer2HS2)允许远 程客户端可以使用各种编程语言向 Hive 提交请求并检索结果,支持多客户端并发访问和身份验证。 HS2 是由多个服务组成的单个进程,其包括基于 Thrift Hive 服务(TCP HTTP)和用于 Web UI 的 Jetty Web 服务。

HiveServer2 拥有自己的 CLI 工具——BeelineBeeline 是一个基于 SQLLine JDBC 客户端。由于 目前 HiveServer2 Hive 开发维护的重点,所以官方更加推荐使用 Beeline 而不是 Hive CLI。以下主 要讲解 Beeline 的配置方式。

6.2.1 修改Hadoop配置

修改 hadoop 集群的 core-site.xml 配置文件,增加如下配置,指定 hadoop root 用户可以代理本机 上所有的用户。

hadoop.proxyuser.root.hosts*hadoop.proxyuser.root.groups*

之所以要配置这一步,是因为 hadoop 2.0 以后引入了安全伪装机制,使得 hadoop 不允许上层系统 (如 hive)直接将实际用户传递到 hadoop 层,而应该将实际用户传递给一个超级代理,由该代理在 hadoop 上执行操作,以避免任意客户端随意操作 hadoop。如果不配置这一步,在之后的连接中可能 会抛出 AuthorizationException 异常。

6.2.2 启动hiveserver2

由于上面已经配置过环境变量,这里直接启动即可:

# nohup hiveserver2 &

6.2.3 使用beeline

可以使用以下命令进入 beeline 交互式命令行,出现 Connected 则代表连接成功。

# beeline -u jdbc:hive2://hadoop001:10000 -n root