1.hive中的四种排序

  1.1 order by :对全局进行排序,只能有一个reduce

    select * from hive.employee order by id;

    

  1.2 sort by :对每一个reduce内部数据进行排序,全局结果集没有排序

    set mapreduce.job.reduces=3;设置reduce的个数为3

    

    insert overwrite local directory '/opt/data/employee_sort_by'
      row format delimited fields terminated by '\t' collection items terminated by '\n'
      select * from hive.employee sort by dept_id;

    

  1.3 distribute by :对数据进行分区,结合sort by进行合并使用,类似于mapreduce中的mapreduce中的partition,必须在sort by 之前

    insert overwrite local directory '/opt/data/employee_distribute_by'
      row format delimited fields terminated by '\t' collection items terminated by '\n'
      select * from hive.employee distribute by dept_id sort by id asc;

    

  1.4 cluster by:当distribute by 和 sort by 的字段相同时,可以使用cluster by 代替

2.使用udf自定义函数

  2.1 编写udf函数

    继承extends UDF

    编写evaluate 方法  

  2.2 导入自定义函数到hive函数库

    方法一:

      add jar /opt/data/jars/my_lower.jar;
      create temporary function my_lower as "com.ibeifeng.hive.udf.LowerUdf";

      

      

    方法二:

      create function self_lower as 'com.ibeifeng.hive.udf.LowerUdf' using jar 'hdfs://life-hadoop.life.com:8020/user/yanglin/data/jars/my_lower.jar';

      

      

3.hiveserver2的使用

  3.1 启动hiveserver2  bin/hiveserver2

    

  3.2 使用beeline进行连接

    !connect jdbc:hive2://life-hadoop.life.com:10000 yanglin life@one

    

4.数据压缩

  4.1 map 输出结果的压缩

      set mapreduce.map.output.compress =true

      set mapreduce.map.output.compress.codec=org.apache.hadoop.io.compress.SnappyCodec

  4.2 reduce 输出结果的压缩

      set mapreduce.output.fileoutputformat.compress=true

      set mapreduce.output.fileoutputformat.compress.codec=org.apache.hadoop.io.compress.SnappyCodec

  4.3 map 输入数据的压缩

      以压缩格式的文件存储数据(例如:orc,parquet)

      create table if not exists hive.employee_orc_snappy (id int,name string,job string,manager_id int,apply_date string,salary double,
        reward double,dept_id int)

         row format delimited fields terminated by '\t'
        stored as orc tblproperties("orc.compress"="SNAPPY");

      其中该表的数据存储格式为orc,文件压缩格式为snappy

5.hive调优

  5.1 修改 hive.fetch.task.conversion参数,使尽可能少用mapreduce

    <!--尽可能的少用mapreduce-->
        <property>
          <name>hive.fetch.task.conversion</name>
          <value>more</value>
        </property>

  5.2 使用大表拆分为小表和子表

  5.3 使用外部表分区表

  5.4 对表的数据的存储格式使用orc和parquet,并使用snappy压缩

  5.5 对sql进行优化

    common join / shuffle join / reduce join : 连接发生在reduce task 阶段

      使用于大表和大表之间,每个表中的数据都从文件中读取

    map join : 连接发生在map task 阶段

      使用于小表和大表之间,大表的数据从文件中读取,小表的数据通过distributedCache加载到内存中

    注:可以通过设置 hive.auto.convert.join = true 让程序自动识别使用map join还是reduce join。

    SMB join :sort-merge-bucket join 是对reduce join 的一种优化

      在创建表时声明[CLUSTERED BY (col_name, col_name, ...) [SORTED BY (col_name [ASC|DESC], ...)] INTO num_buckets BUCKETS],且两个表的分区字段要一致。

      set hive.auto.convert.sortmerge.join=true;

      set hive.optimize.bucketmapjoin = true;

      set hive.optimize.bucketmapjoin.sortedmerge = true;

  5.6 设置job并行执行

    set hive.exec.parallel = true

    set hive.exec.parallel.thread.number = 8    建议10~20,一般不用超过20

  5.7 设置jvm重用

    set mapreduce.job.jvm.numtasks = 1   一般不用超过9

  5.8 设置reduce的个数

    set mapreduce.job.reduces = 1

  5.9 设置推测执行

    set hive.mapred.reduce.tasks.speculative.execution = true

    set mapreduce.map.speculative = true

    set mapreduce.reduce.speculative = true

  5.10 设置map的个数

    set hive.merge.size.per.task = 256000000

  

  

hive的使用03的更多相关文章

  1. Flume1.9.0的安装、部署、简单应用(含分布式、与Hadoop3.1.2、Hbase1.4.9的案例)

    目录 目录 前言 什么是Flume? Flume的特点 Flume的可靠性 Flume的可恢复性 Flume的一些核心概念 Flume的官方网站在哪里? Flume在哪里下载以及如何安装? 设置环境变 ...

  2. CDH quick start VM 中运行wordcount例子

    需要注意的事情: 1. 对于wordcount1.0 ,按照http://www.cloudera.com/content/cloudera/en/documentation/HadoopTutori ...

  3. Hive 笔记

    DESCRIBE EXTENDED mydb.employees  DESCRIBE EXTENDED mydb.employees DESCRIBE EXTENDED mydb.employees ...

  4. Hive函数大全

    一.关系运算: 1. 等值比较: = 语法:A=B 操作类型:所有基本类型 描述: 如果表达式A与表达式B相等,则为TRUE:否则为FALSE 举例: hive> select 1 from l ...

  5. 【转】Hive 基础之:分区、桶、Sort Merge Bucket Join

    Hive 已是目前业界最为通用.廉价的构建大数据时代数据仓库的解决方案了,虽然也有 Impala 等后起之秀,但目前从功能.稳定性等方面来说,Hive 的地位尚不可撼动. 其实这篇博文主要是想聊聊 S ...

  6. Hive时间操作[转]

    时间字段格式化 from_unixtime(unix_timestamp(VisitTime),'yyyy-MM-dd') 日期函数UNIX时间戳转日期函数: from_unixtime语法:   f ...

  7. hive修改 表/分区语句

    参考 https://cwiki.apache.org/confluence/display/Hive/LanguageManual+DDL#LanguageManualDDL-AlterTable% ...

  8. 调用javaAPI访问hive

    jdbc远程连接hiveserver2 2016-04-26 15:59 本站整理 浏览(425)     在之前的学习和实践Hive中,使用的都是CLI或者hive –e的方式,该方式仅允许使用Hi ...

  9. Spark入门实战系列--5.Hive(上)--Hive介绍及部署

    [注]该系列文章以及使用到安装包/测试数据 可以在<倾情大奉送--Spark入门实战系列>获取 .Hive介绍 1.1 Hive介绍 月开源的一个数据仓库框架,提供了类似于SQL语法的HQ ...

随机推荐

  1. Windowns 10打开此电脑缓慢问题的一种解决办法

    上个月刚配的台式,i7 6700K + 16GB + PM961用起来爽得不行. 不过最近两天突然发现,打开"此电脑"总会卡住,窗口里面也不显示磁盘.地址栏缓慢刷新. 一般此类问题 ...

  2. 简单理解js的prototype属性

    在进入正文之前,我得先说说我认识js的prototype这个东西的曲折过程. 百度js的prototype的文章,先看看,W3School关于prototype的介绍: 你觉得这概念适合定义js的pr ...

  3. Programming pearls 编程珠玑的题目

    Programming pearls 编程珠玑的题目 这段时间有空都在看编程珠玑,很经典的一本书,一边看一边用 python 做上面的题目,我做的都放到 github 上了 https://githu ...

  4. iOS,信息加解密

    1.AES加解密 AES加解密 // //  AESEncryptAndDecrypt.h //  NSData扩展方法,用于处理aes加解密 // //  Created by Vie on 16/ ...

  5. ios 配置https

    一般来讲如果app用了web service , 我们需要防止数据嗅探来保证数据安全.通常的做法是用ssl来连接以防止数据抓包和嗅探 其实这么做的话还是不够的 . 我们还需要防止中间人攻击(不明白的自 ...

  6. 浏览器桌面通知--Notification

    前言 最近项目上要用到浏览器桌面通知,之前虽然知道有这个东西,但是一直没有用过,借此机会了解下桌面通知的机制,在此分享下. 1.权限 首先需要明确的是,不是所有网页都可以发桌面通知的,不然不得烦死,那 ...

  7. gedit 没有preference项,使preference回归,并用命令行设置行号,text wrapping等

    1.最简单的,使preference选项回来: gsettings set org.gnome.settings-daemon.plugins.xsettings overrides '@a{sv} ...

  8. Linux系统安装

    http://soft.chinabyte.com/os/447/12439447.shtml     磁盘分区 http://www.huaweigold.com/doc/ServerDOC-201 ...

  9. kali 下文件操作

    记得看到一片文章中说要学习linux 不要用kali.. 不感兴趣的东西,还指望我去搞个Ubuntu.... Ctrl+I 清屏 CD命令: cd 进入用户主目录: cd ~ 进入用户主目录: cd ...

  10. 总结ThinkPHP使用技巧经验分享(一)

    约定:1.所有类库文件必须使用.class.php作为文件后缀,并且类名和文件名保持一致2.控制器的类名以Action为后 缀3.模型的类名以Model为后缀,类名第一个字母须大写4.数据库表名全部采 ...