构建在Hadoop之上的数据仓库,数据计算使用MR,数据存储使用HDFS
        由于数据计算使用mapreduce。因此通经常使用于进行离线数据处理
Hive 定义了一种类 SQL 查询语言——HQL
        类似SQL,但不全然同样
可觉得是一个HQL-->MR的语言翻译器。
简单,easy上手

有了Hive,还须要自己写MR程序吗?
        Hive的HQL表达的能力有限
                迭代式算法无法表达
                有些复杂运算用HQL不易表达
        Hive效率较低
                Hive自己主动生成MapReduce作业。通常不够智能;
                HQL调优困难,粒度较粗
                可控性差

Hive各模块组成
        用户接口
                包含 CLI,JDBC/ODBC,WebUI
        元数据存储(metastore)
                默认存储在自带的数据库derby中,线上使用时一般换为MySQL
        驱动器(Driver)
                解释器、编译器、优化器、运行器
        Hadoop
                用 MapReduce 进行计算,用 HDFS 进行存储

Hive部署架构-实验环境


Hive部署架构-生产环境

watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQv/font/5a6L5L2T/fontsize/400/fill/I0JBQkFCMA==/dissolve/70/gravity/Center" width="600" alt="" style="border:none">


数据模型

watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQv/font/5a6L5L2T/fontsize/400/fill/I0JBQkFCMA==/dissolve/70/gravity/Center" width="600" alt="" style="border:none">

Partition 和Bucket 
Partition
        为降低不必要的暴力数据扫描,能够对表进行分区
        为避免产生过多小文件。建议仅仅对离散字段进行分区
Bucket
        对于值较多的字段,可将其分成若干个Bucket
        可结合Partition与Bucket使用

select语句
        不支持having和exist in操作, 可转换为LEFT SEMI JOIN操作
        Join(仅支持等值连接),不支持非等值的连接

Order by和Sort by 
Order by
        启动一个reduce task
        数据全局有序
        速度可能会很慢
        Strict模式下,必须与limit连用
Sort by
        能够有多个reduce task
        每一个Reduce Task内部数据有序。但全局无序
        通常与distribute by

Distribute by与Cluster by
distribute by
        相当于MapReduce中的paritioner,默认是基于hash实现的;
        与sort by连用,可发挥非常好的作用
cluster by
        当distribute by与sort by(降序)连用,且尾随的字段 同样时,可使用cluster by简写。

用户自己定义函数UDF:扩展HQL能力的一种方式

HQL支持索引吗?
        HQL运行过程主要是并行地暴力扫描。

眼下Hive仅支持单表索引,但提供了索引创建接口和调用方法,可由用户依据须要实现索引结构;

HQL支持update操作吗?
        不支持。Hive底层是HDFS,HDFS仅支持追加操作。不支持随机写;
Skew Data处理机制?
        指定skew 列:CREATE TABLE list_bucket_single (key STRING, value STRING) SKEWED BY (key) ON (1,5,6);
        为skew task分配很多其它资源(TODO)
        将skew task分解成多个task,再合并结果(TODO)

Hive On HBase
使用HQL处理HBase中的数据
        比直接通过HBase API存取数据方便。
        但性能更低,相当于把在线处理转为批处理
存在问题
        不够成熟;
        不能按时间戳获取数据,默认总是取最新的数据

Hive的类似系统
Stinger
        下一代Hive被称为“Stinger”,其底层的计算引擎将由Tez替换MapReduce。
        Tez相比于MapReduce具有众多优势:
                提供了多种算子(比方Map、Shuffle等)供用户使用;
                将多个作业合并成一个作业,降低磁盘读写IO;
                充分利用内存资源。


Shark
        Hive On Spark(http://spark.incubator.apache.org/);
        Spark是一个内存计算框架,相比于MapReduce,效率更加高效(部分測试表明,速度快100x)。
        Shark全然兼容Hive,底层计算引擎採用Spark。


Impala
        底层计算引擎不再採用MR。而是使用与商用并行关系数据库类似的分布式查询引擎;

性能比較

watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQv/font/5a6L5L2T/fontsize/400/fill/I0JBQkFCMA==/dissolve/70/gravity/Center" width="900" alt="" style="border:none">





大数据- Hive的更多相关文章

  1. [Hadoop大数据]——Hive初识

    Hive出现的背景 Hadoop提供了大数据的通用解决方案,比如存储提供了Hdfs,计算提供了MapReduce思想.但是想要写出MapReduce算法还是比较繁琐的,对于开发者来说,需要了解底层的h ...

  2. [Hadoop大数据]——Hive连接JOIN用例详解

    SQL里面通常都会用Join来连接两个表,做复杂的关联查询.比如用户表和订单表,能通过join得到某个用户购买的产品:或者某个产品被购买的人群.... Hive也支持这样的操作,而且由于Hive底层运 ...

  3. 大白话详解大数据hive知识点,老刘真的很用心(2)

    前言:老刘不敢说写的有多好,但敢保证尽量用大白话把自己复习的内容详细解释出来,拒绝资料上的生搬硬套,做到有自己的了解! 1. hive知识点(2) 第12点:hive分桶表 hive知识点主要偏实践, ...

  4. 大白话详解大数据hive知识点,老刘真的很用心(3)

    前言:老刘不敢说写的有多好,但敢保证尽量用大白话把自己复习的内容详细解释出来,拒绝资料上的生搬硬套,做到有自己的了解! 1. hive知识点(3) 从这篇文章开始决定进行一些改变,老刘在博客上主要分享 ...

  5. 入门大数据---Hive计算引擎Tez简介和使用

    一.前言 Hive默认计算引擎时MR,为了提高计算速度,我们可以改为Tez引擎.至于为什么提高了计算速度,可以参考下图: 用Hive直接编写MR程序,假设有四个有依赖关系的MR作业,上图中,绿色是Re ...

  6. [Hadoop大数据]——Hive数据的导入导出

    Hive作为大数据环境下的数据仓库工具,支持基于hadoop以sql的方式执行mapreduce的任务,非常适合对大量的数据进行全量的查询分析. 本文主要讲述下hive载cli中如何导入导出数据: 导 ...

  7. 大数据 Hive 简介

    第一部分:Hive简介 什么是Hive •Hive是基于Hadoop的一个数据仓库工具,可以将结构化的数据文件映射为一张数据库表,并提供类SQL查询功能. •本质是将SQL转换为MapReduce程序 ...

  8. 入门大数据---Hive是什么?

    这篇文章主要介绍Hive的概念. 简介: Hive中文名叫数据仓库管理系统,之前我们操作MapReduce必须通过编写代码或者通过特殊命令来实现,有了Hive我们通过常用的SQL语句就能操作MapRe ...

  9. 入门大数据---Hive数据查询详解

    一.数据准备 为了演示查询操作,这里需要预先创建三张表,并加载测试数据. 数据文件 emp.txt 和 dept.txt 可以从本仓库的resources 目录下载. 1.1 员工表 -- 建表语句 ...

随机推荐

  1. numpy 数据类型与 Python 原生数据类型

    查看 numpy 数据类型和 Python 原生数据类型之间的对应关系: In [51]: dict([(d, type(np.zeros(1,d).tolist()[0])) for d in (n ...

  2. POJ 1330 Nearest Common Ancestors 倍增算法的LCA

    POJ 1330 Nearest Common Ancestors 题意:最近公共祖先的裸题 思路:LCA和ST我们已经很熟悉了,但是这里的f[i][j]却有相似却又不同的含义.f[i][j]表示i节 ...

  3. C/C++(C++内存管理,内联函数,类型转换,命名空间,string类)

    ---恢复内容开始--- 内存管理 new/delete C语言中提供了 malloc 和 free 两个系统函数,#include "stdlib.h"库函数,完成对堆内存的申请 ...

  4. 关于【搭建LAMP环境时,php测试页面打不开】解决

    关于[搭建LAMP环境时,php测试页面打不开]解决 〇.我的测试页面是: http://172.30.124.10/index.php 用火狐打不开,如下图. 一.httpd已经启动了(system ...

  5. python 发送邮件 <QQ+腾讯企业邮箱>

    一.使用QQ邮箱或者腾讯企业邮箱 python 发送邮件属于网络编程方向的,在工作中,我需要经常用邮件来检测我的程序运行状况.使用起来十分方便,这里我就用腾讯企业邮箱作为我的收发邮箱来使用. 使用py ...

  6. Centos6.5 安装lamp环境

    转载自:http://www.jb51.net/article/37987.htm (转载请注明出处,谢谢) 准备篇: 1.配置防火墙,开启80端口.3306端口vi /etc/sysconfig/i ...

  7. 【Uva 10618】Tango Tango Insurrection

    [Link]: [Description] 玩跳舞机. 有一定的约束. 归纳起来就是以下三点 1.两只脚不能同时踩一个位置 2.如果左脚踩在了右键上,那么下一次移动的一定要是左脚 3.如果右脚踩在了左 ...

  8. HDU 3911 Black And White

    Black And White Time Limit: 3000ms Memory Limit: 32768KB This problem will be judged on HDU. Origina ...

  9. spark系统实现yarn资源的自动调度

    参考: http://blog.csdn.net/dandykang/article/details/48160953     对于Spark应用来说,资源是影响Spark应用执行效率的一个重要因素. ...

  10. 【Swift初见】Swift数组(二)

    在苹果的开发文档中对Array还提供了其它的操作算法: 1.Sort函数: 对数组进行排序.依据指定的排序规则,看以下的代码: var array = [2, 3, 4, 5] array.sort{ ...