Hadoop最常用的工具(SQL on Hadoop):Hive

  • 认识Hive

    对十Hadoop的出现,无论是业界还是学术界对其都给予了极高的关注度,Hadoop及其生态圈提供了一个成熟高效的处理海量数据集的解决方案。随着Hadoop越来越流行,一个问题也随之产生:用户如何从现有的数据基础架构转移到Hadoop上,而所谓的数据基础架构大都基于传统关系型数据库(RMDBS )和结构化查询语言(SQL )。这就是Hive出现的原因,Hive的设训目的是为了让那些精通SQL技能而Java技能较弱的数据分析师能够利用Hadoop进行各种数据分析,对于前文的WordCount例子,Java代码大概在80行左右,这对于经验丰富的Java开发工程师来说也不是易事,但如果用Hive的查询语言(即HiveQL)来完成的话,只有区区几行代码:

CREATE TABLE text (line STRING);
LOAD DATA INPATH’a.txt’OVERWRITE INTO  TABLE text;
CREATE TABLE word_count AS SELECT word,COUNT(1) AS count FROM
(SELECT EXPLODE (SPLIT(line,’\s’)))AS word FROM text) w
GROUP BY word
ORDER BY word;
 


    可以看出HiveQL的语法和SQL常类似,实际上HiveQL是基本实现了SQL-92标准的。
    Hive是由Facebook开发的海量数据查询工具,目前己经捐献给Apache软件基金会,是Apache的顶级项目。
    在实际开发中,80%的操作都不会由MapReduce程序直接完成,而是由Hive来完成,所以说Hive本身实践性非常强,并,1.使用频率}I常高,它没有高深的原理,只需要用户对SQL熟练即可。掌握Hive对于使用Hadoop来说非常重要。

  • 从MapReduce到SQL

    Hive显著地降低了使用Hadoop来做数据分析的学习成本,对于那些精通Java的人来说,Hive仍然是首选,因为Hive稳定,代码精简并且易于维护。
    从前面介绍的MapReduce编程实例可以看出,常见的count,  group by,  order by,  join等SQL操作都可以由MapReduce来完成,在某种意义上,Hive可以说是HiveQL ( SQL)到MapReduce的映射器,如下图所示。



    Hive可以将用户输入的HiveQL脚本转化为一个或多个MapReduce作业并在集群上运行。同样的,Hadoop生态圈里还有一个叫Pig的组件,它的作用和Hive类似,但Pig提供的不是SQL接口而是一种叫做Pig Latin的语言接口,如下图所示。


    和SQL相比,Pig Latin更加灵活但是学习成本更高,在生产环境下没有Hive普遍。Pig Latin和HiveQL都是对MapReduce进行了一种封装,使用户不必直接编写MapReduce程序,所以它们可以说是Hadoop的“高级语言”。

可以在Hive安装的节点输入hive进入Hive命令行:

Hive history file=/tmp/hadoop/hive_job_log_hadoop_201407010908_503992358.txt hive>

可以对己有的表进行查询操作:

hive> select count(*)from test;

这时控制台会输出日志:

Total MapReduce jobs=1
Launching Job 1 out of 1
Number of reduce tasks determined atcompile time:1
In order to change the average load for a reducer (in bytes):
        set hive .exec.reducers.bytes.per.reducer=<number>
      In orderto limit the maximum number of reducers:
          set hive.exec.reducers.max=<number>
        In order to set a constant number of reducers:
        set mapred.reduce.tasks=<number>
      Starting Job=job-201407010902_0002,Tracking ORL=http://master:50030/jobdetails.
jsp?jobid=job-201907010902_0002
      Kill Command=/home/hadoop/hadoop-0.20.2一cdh3u6/bin/hadoop job一Dmapred.job.tracker=master:9001-kill job_201407010902_0002
      2019一07一01 09:11:91,334 Stage-1 map=0%,  reduce = 0%.
      2019一07一01 09:11:97,370 Stage-1 map=0%,  reduce=100%.
      2014一07一01 09:11:50,397 Stage一1 map=100%,  reduce=100%
      Ended Job=job_ 201907010902_ 0002
        OK
        0
        Time taken:14 .889 seconds

    从日志可以发现该条HiveQL(以下简称HQL)被转化为一个MapReduce作业执行,执行时与普通MapReduce作业一样,也是分为map和reduce部分,还可以通过Hadoop的Web UI查看作业,日志已经将作业链接打印出来:

通过链接可以看到该作业的详细信息,如图所示。




值得一提的是,并不是所有HQL 都会转化为MapReduce任务,例如下面这种查询操作。
hive> select*from test:
    这种HQL是不会被Hive转化为MapReduce作业执行的,Hive只会将该表所分布在各个,DataNode的数据拉到Hive所在节点并依次输出。


本文参考书籍------Hadoop海量数据处理 技术详解与项目实战



posted @ 2017-05-10 16:41  keepgoon  阅读(319)  评论(0编辑  收藏  举报