1、Hive入门基本概念

Hadoop:Spark、Hive、Kafka(MQ消息队列/大数据、Java)

大数据解决的问题:海量数据的传输、存储、查询问题

Hive只是一个协调HDFS和Yarn的客户端,不属于大数据框架,但它是分布式的。

第1章 Hive基本概念

1.1 什么是Hive

       Hive:由Facbook开源用于解决海量结构化日志的数据统计。

       Hive是基于Hadoop的一个数据仓库工具,可以将结构化数据文件映射为一张表,并提供类SQL的查询功能。

       本质:将HQL转化为MapReduce程序。

  1. Hive处理的数据存储在HDFS
  2. Hive分析数据底层的默认实现是MapReduce
  3. 执行程序运行在Yarn上

1.2 Hive的优缺点

1.2.1 优点

  1. 操作接口采用类SQL语法,提供快速开发能力。
  2. 避免写MapReduce,减少开发人员学习成本。
  3. Hive的执行延迟较高,因此Hive常用语数据分析,对实时性要求不高的场合。
  4. Hive的优势在于处理大数据,对于处理小数据没有优势,因为Hive的执行延迟较高。
  5. Hive支持用户自定义函数,用户可根据需要实现函数。

1.2.2 缺点

(1)Hive的HQL表达能力有限

  • 迭代式算法无法表达
  • 数据挖掘方面不擅长

(2)Hive的效率比较低

  • Hive自动生成的MapReduce作业,通常情况下不够智能
  • Hive调优比较困难,粒度教粗

1.3 Hive架构原理(面试重点)

Hive架构原理:解析器、编译器、优化器、执行器

Hive运行机制:用户创建表,建立表和数据的映射关系。编写查询分析语句。

 

 

 1.4 Hive和数据库比较

 1.4.1 查询语言

        由于SQL被广泛应用于数据仓库中,因此专门针对Hive特性设计类SQL的查询语言HQL。熟悉SQL开发者可用Hive开发。

1.4.2 数据存储位置

       Hive建立在Hadoop上,所有Hive的数据都是存储在HDFS上。数据库则将数据保存在块设备或者本地文件系统中。

1.4.3 数据更新

       由于Hive针对数据仓库设计,数据仓库内容是读多写少。因此Hive中不建议对数据改写,所有数据都是在加载时确定好的。而数据库中的数据通常是需要经常修改的,因此可以使用INSERT INTO...VALUES添加数据,使用UPDATE...SET修改数据。

1.4.4 索引

        Hive在加载过程中不会对数据做任何处理,甚至不会对数据进行扫描,因此没有对数据中某些Key建立索引。Hive访问数据中满足条件的特定值时需要暴力扫描整个数据,因此延迟高。由于MapReduce的引入,Hive可以并行访问数据,因此即使没有索引,依旧能在大数据量访问中体现优势。

        数据库中通常会对列建立索引,因此对于少量特定条件的数据的访问,数据库可以有很高的效率,较低的延迟。由于数据的访问延迟较高,决定了Hive不适合在线数据查询。

1.4.5 执行

        Hive中大多数查询执行时通过Hadoop的MapReduce实现的,而数据库有自己的执行引擎。

1.4.6 执行延迟

        Hive查询数据时,因为没有索引需要扫描整个表,因此延迟较高。 另一个延迟因素是MapReduce框架。MapReduce自身具有较高延迟,因此利用MapReduce执行Hive查询时会有较高延迟。相对,数据库执行延迟低。(注:前提是数据规模小,超出数据库处理能力适合用Hive,其并行计算优势更高。)

1.4.7 可扩展性

      Hive建立在Hadoop上,因此Hive的可扩展性和Hadoop的可扩展性一致。(世界UI大的Hadoop集群在Yahoo!2009年规模在4000台节点左右)。而数据库由于ACID语言严格限制(三范式原则),扩展极为有限。目前最先进的并行数据库Oracle在理论上扩展能力也仅100台左右。

1.4.8 数据规模

      由于Hive建立在集群上可以利用MapReduce进行并行计算,因此可以支持很大规模的数据;相对应,数据库可支持的数据规模较小。

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

posted @ 2023-03-10 10:48  咪嗞哈嘻  阅读(55)  评论(0编辑  收藏  举报