一幅长文细学华为MRS大数据开发(三)——Hive

文章目录

  • 3 HIVE
    • 3.1 Hive概述
      • Hive简介
      • Hive应用场景
      • Hive与传统数据仓库比较
      • Hive优点
    • 3.2 Hive功能及架构
      • Hive运行流程
      • Hive数据存储模型
      • Hive数据存储模型-分区和分桶
      • Hive数据存储模型-托管表和外部表
      • Hive支持的函数
    • 3.3 Hive基本操作
      • Hive使用
      • DDL操作
      • DML操作
      • DQL操作

3 HIVE

Apache Hive数据仓库软件有助于使用SQL读取,写入和管理驻留在分布式存储中的大型数据集。可以将结构投影到已经存储的数据上。提供了命令行工具和JDBC驱动程序以将用户连接到Hive上。

3.1 Hive概述

Hive简介

Hive:Hive是基于Hadoop的数据仓库软件,可以查询和管理PB级别的分布式数据。

Hive特性

  • 灵活方便的ETL(extract/transform/load)。
  • 支持Tez,Spark等多种引擎
  • 可直接访问HDFS文件以及HBase
  • 易用易编程

Hive应用场景

image-20220819114329694


Hive与传统数据仓库比较

Hive传统数据仓库
存储HDFS,理论上有无限拓展的可能集群存储,存在容量上限,而且随着容量的增长,计算速度急剧下降,只能适应与数据量比较小的商业应用,对于超大规模数据无能为力
执行引擎默认执行引擎Tez可以选择更加高效的算法来查询,也可以进行更多的优化措施来提高速度
使用方式HQLSQL
灵活性元数据存储独立于数据存储之外,从而解耦合元数据和数据低,数据用途单一
分析速度计算依赖于集群规模,易拓展,在数据容量较小时非常快速,数据容量较大时,急剧下降
索引效率较低高效
易用性需要自行开发应用模型,灵活度较高,但易用性较低集成一整套成熟的报表解决方案,可以较为方便的进行数据的分析
可靠性数据存储在HDFS,可靠性高、容错性高可靠性较低,一次查询失败需要重新开始。数据容错依赖于硬件Raid
依赖环境依赖硬件较低,可适应一般的普通机器依赖于高性能的商业服务器
价格开源产品商用比较昂贵

Hive优点

  • 高可靠、高容错:HiveServer采用集群模式,双MetaStore,超时重试机制
  • 类SQL:指HQL,其类似于SQL语法,内置了大量函数
  • 可扩展:自定义存储格式和函数
  • 多接口:Beeline、JDBC、Thrift、Python、ODBC

3.2 Hive功能及架构

Hive运行流程

  1. Client提交HQL命令
  2. Tez执行查询
  3. YARN为集群中的应用程序分配资源,并未YARN队列中的Hive作业启用授权
  4. Hive根据表类型更新HDFS或Hive仓库的数据
  5. Hive通过JDBC连接返回查询结果

Hive数据存储模型

表中可分区或分桶,分区还可继续分区或分桶。

image-20220819115750466


Hive数据存储模型-分区和分桶

分区:数据表可以按照某个字段的值划分分区。我们可以这么理解:将一个表的数据拆分出来放在不同的文件夹(目录)下。这样的话,分区的本质就是目录,分区数量也不固定,分区下可再有分区或者桶。

:数据可以根据桶的方式将不同数据放入不同的桶中。我们可以这么理解:一个表的数据拆分出来后肯定不是说直接放在文件夹下,而是放在文件中,至于这个文件是在根目录还是某个分区目录我们就不得而知了,我们称这个文件为。桶中基本的原理遵循数据结构中的桶排序,建表时可以指定桶个数,桶内可排序。数据按照某个字段的值Hash后放入某个桶中。


Hive数据存储模型-托管表和外部表

托管表:创建表若不指定表的类型即默认为托管表,Hive会将创建后的表移动到仓库目录。

外部表:若指定创建外部表,则Hive会到数据仓库目录以外的位置访问该表的数据。

说明:如果所有处理都有Hive完成,建议使用托管表。如果要用Hive和其他工具搭配使用来处理同一个数据集,建议使用外部表。

托管表外部表
CREATE/LOAD数据移动仓库目录数据位置不移动
DROP元数据和数据会被一起删除只删除元数据

Hive支持的函数

内置函数

  • 数学函数:如round(),floor(),abs(),rand()等
  • 日期函数:如to_date(),month(),day()等
  • 字符串函数:如trim(),length(),substr()等

用户自定义函数(UserDefinedFunction)


3.3 Hive基本操作

Hive使用

打开服务器

$HIVE_HOME/bin/hiveserver2
//通过beeline连接
$HIVE_HOME/bin/beeline -u jdbc:hive2://$HS2_HOST:$HS2_PORT

向其他大数据组件公开自己元数据

$HIVE_HOME/hcatalog/sbin/hcat_server.sh

从Hive发行版0.11.0及更高版本的shell中运行WebHCat服务器

$HIVE_HOME/hcatalog/sbin/webhhcar_server.sh

DDL操作

创建表

create table pokes(foo int,bar string);
//指定分区
create table invites(foo int,bar string) partitioned by (ds string);

浏览表

show tables

描述表

describe invites

修改表

alter table events rename to 3koobecaf;
alter table pokes add columns (new_col int)

DML操作

向表里加载数据

load datalocal inpath './exaples/files/kv1.txt' overwrite into table pokes;
load data local inpath './examples/files/kv2.txt' overwrite into table invites partition (ds='2008-08-15')

导入数据出HDFS

export table invites to '/department'

DQL操作

selects and filters

select a.foo from invites a where a.ds = '2008-08-15';
insert overwrite directory '/tmp/hdfs_out' select a.* from invires a where a.ds='2008-08-15';

group by

from invites a insert overwrite table events select a.bar,count(*) where a.foo > 0 group by a.bar;
insert overwrite table events select a.bar,count(*) from invites a where a.foo>0 group by a.bar;

多次插入

from src
insert overwrite table dest1 select src.* where src.key<100
insert overwrite table dest2 select src.key,src.value where src.key >= 100 and src.key<200;

多表联查

from pokes t1 join invites t2 on (t1.bar == t2.bar) insert overwrite table events select t1.bar,t1.foo,t2.foo;

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/398438.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Huffman树进行编码和译码

//编码 #include<iostream> #include<cstdio> #include<cstring> #include<cstdlib> #include<algorithm> #include<queue> #include<fstream> #include<map> using namespace std;typedef struct HuffmanNode{int w;//节点…

更相减损法和辗转相除法(GCD)求最小公倍数和最大公约数

更相减损法和辗转相除法&#xff08;GCD&#xff09;求最小公倍数和最大公约数 标签&#xff08;空格分隔&#xff09;&#xff1a; 算法 算法竞赛 这两种算法平时经常听到&#xff0c;听起来也很装逼&#xff0c;但是我老是忘了他们的原理&#xff0c;今天好好想想&#xff0c…

一幅长文细学JavaScript(五)——ES6-ES11新特性

5 ES版本 摘要 ES5的先天不足致使ES后续版本的发展&#xff0c;这也是前端人员绕不开的一个点。如果我们想要在工作和面试中轻松解决问题&#xff0c;那么了解ES6-ES11是必不可少的。 在本文中&#xff0c;我将采用一种更加通俗的方式来讲述这一块知识点&#xff0c;而不是照搬…

Python自动化运维工具fabric的安装

使用shell命令进行复杂的运维时&#xff0c;代码往往变得复杂难懂&#xff0c;而使用python脚本语言来编写运维程序&#xff0c;就相当于开发普通的应用一样&#xff0c;所以维护和扩展都比较简单&#xff0c;更重要的是python运维工具fabric能自动登录其他服务器进行各种操作&…

项目开发一些注意事项

项目开发一些注意事项 1、一些简单的方法可以让你的代码看起来更明了&#xff0c;如函数或者方法&#xff0c;尽量的写的小一些&#xff0c;如果太冗长&#xff0c;尝试抽出一块写成一个函数&#xff1b;2、如果业务逻辑比较复杂&#xff0c;判断选项较多&#xff0c;可以把判断…

一幅长文细学Vue(一)——Webpack打包工具

1 项目开发工具 摘要 ​ 在本文中&#xff0c;我们会详细讨论webpack是如何打包发布项目&#xff0c;不过对于Vue来说&#xff0c;Vite可以做到和webpack一样的功能。 声明&#xff1a;如果想要看懂此文章&#xff0c;需具备node.js中npm的知识。 作者&#xff1a;来自ArimaMis…

I00005 打印直角三角形字符图案

曾经的计算机&#xff0c;没有显示屏&#xff0c;人们操作计算机时&#xff0c;用打印机记录执行的操作命令。 后来有了显示屏&#xff0c;不过最初的显示屏是字符频幕&#xff0c;输出只能是字符。 即使是今日&#xff0c;计算机已经进入多窗口图形界面时代&#xff0c;有时程…

由于不能随便改路径,所以写在这里

export LD_LIBRARY_PATH/usr/local/cuda-8.0/lib64:$LD_LIBRARY_PATHexport PATH/usr/local/cuda-8.0/bin:$PATH export LD_LIBRARY_PATH/root/anaconda2/envs/LTproto261/lib export PYTHONPATH/dev/LT/SegNet/caffe-segnet/python:$PYTHONPATH转载于:https://www.cnblogs.com…

动态数组使用

1 #include<stdio.h>2 #include<stdlib.h>3 4 int main()5 {6 int i;7 int n; //用于记录输入的整数的个数 8 int *p; //用于指向动态数组的存储空间 9 int sum0,average; //用于记录输入的整数的和与平均值 10 11 scanf("%d"…

一幅长文细学Vue(二)——Vue基础入门

2 Vue基础入门 摘要 ​ 在本文中&#xff0c;我们会快速地入门Vue。主要了解的是Vue各种指令语法。 声明&#xff1a;为了文章的清爽性&#xff0c;在文章内部的代码演示中只会附上部分演示代码。 作者&#xff1a;来自ArimaMisaki创作 文章目录2 Vue基础入门2.1 概述2.1.1 Vue…

Linux下安装Redis及搭建主从

Linux下安装Redis 首先在官网下载对应版本的redis包&#xff0c;这里本人使用的是redis-4.0.8.tar.gz。然后在服务器中存放redis包的路径下执行tar –vxf redis-4.0.8.tar.gz&#xff08;这里对应下载的包&#xff09;&#xff0c;解压redis后,cd 进入 redis-4.0.8&#xff08;…

图解安装CentOS 6.6

以下是在虚拟机上安装CentOS 6.6的过程。一、安装文件:CentOS-6.6-x86_64-bin-DVD.iso二、安装步骤# 虚拟机的配置这里省略&#xff0c;在百度上有很多帖子可以参考。开启虚拟机进入安装界面&#xff0c;如下图所示选择第一个选项&#xff0c;按Enter安装程序加载完后&#xff…

phonegap安卓手机开发入门

先安装安卓开发安环境 http://www.cnblogs.com/zhangsanshi/p/3582368.html 安装phonegap 在安装ant http://www.cnblogs.com/yuzhongwusan/archive/2013/03/26/2982411.html 资源下载地址 http://pan.baidu.com/s/1mgHTNDm#path%252F 转载于:https://www.cnblogs.com/sung/p/4…

一幅长文细学Vue(三)——组件基础(上)

3 组件基础&#xff08;上&#xff09; 摘要 ​ 在本文中&#xff0c;我们将学习什么是SPA&#xff0c;以及Vue中组件的基本使用。 声明&#xff1a;为了文章的清爽性&#xff0c;在文章内部的代码演示中只会附上部分演示代码&#xff0c;main.js文件的代码通常不贴出&#xff…

综合练习:词频统计

下载一首英文的歌词或文章 将所有,.&#xff1f;&#xff01;’:等分隔符全部替换为空格 将所有大写转换为小写 生成单词列表 fopen(news.txt,r) newsf.read() f.close() sep,.!"?: for c in sep:newsnews.replace(c, )wordListnews.lower().split()for w in wordList:pr…

一幅长文细学Vue(四)——组件基础(下)

4 组件基础&#xff08;下&#xff09; 摘要 ​ 在本文中年我们会了解什么是props&#xff0c;怎么利用props在父组件和子组件之间传递数据&#xff1b;什么是计算属性&#xff0c;还有什么是事件。 声明&#xff1a;为了文章的清爽性&#xff0c;在文章内部的代码演示中只会附…

linux中fcntl()、lockf、flock的区别

fcntl()、lockf、flock的区别 ——lvyilong316 这三个函数的作用都是给文件加锁&#xff0c;那它们有什么区别呢&#xff1f;首先flock和fcntl是系统调用&#xff0c;而lockf是库函数。lockf实际上是fcntl的封装&#xff0c;所以lockf和fcntl的底层实现是一样的&#xff0c;对文…

获取.properties后缀的数据

在MyPro.properties中的数据如下&#xff1a; NameABC 测试类中&#xff1a; Properties properties new Properties(); String configFile "MyPro.properties"; //将MyPro.properties文件编译成文件流 InputStream is ConfigManager.class.getClassLoader().getR…

iOS开发拓展篇—音频处理(音乐播放器6)

一、图片处理 说明&#xff1a; Aspect表示按照原来的宽高比进行缩放。 Aspectfit表示按照原来的宽高比缩放&#xff0c;要求看到全部图片&#xff0c;后果是不能完全覆盖窗口&#xff0c;会留有空白。 Aspectfill表示按照原来的宽高比缩放&#xff0c;但只能看到部分图片。引发…

词频统计预处理之综合练习

下载一首英文的歌词或文章 news , 生成词频统计 sep,.;:"" for c in sep:newsnews.replace(c, )wordlistnews.lower().split()wordDict{} for w in wordlist:wordDict[w]wordDict.get(w,0)1wordSetset(wordlist) for w in wordSet:wordDict[w]wordlist.count(w)f…