​编辑

Hive文件存储格式及优缺点

textfile

默认的文件格式,行存储。建表时不指定存储格式即为textfile,导入数据时把数据文件拷贝至hdfs不进行处理。

优点:最简单的数据格式,便于和其他工具(pig, grep, sed, awk)共享数据、便于查看和编辑;加载较快。

缺点:耗费存储空间,I/O性能较低;Hive不进行数据切分合并,不能进行并行操作,查询效率低。

适用于小型查询,查看具体数据内容的测试操作。

sequencefile

行存储,含有键值对的二进制文件。

优点:可压缩、可分割,优化磁盘利用率和I/O;可并行操作数据,查询效率高。

缺点:存储空间消耗最大;对于Hadoop生态系统之外的工具不适用,需要通过text文件转化加载。

rcfile

行列式存储。先将数据按行分块,同一个record在一个块上,避免读一条记录需要读多个block;然后块数据列式存储。

优点:可压缩,高效的列存取;查询效率较高。

缺点:加载时性能消耗较大,需要通过text文件转化加载;读取全量数据性能低。

orcfile

​编辑

优化后的rcfile,行列式存储。优缺点与rcfile类似,查询效率最高。适用于Hive中大型的存储、查询。

parquet

​编辑

列式存储,以二进制方式存储。

优点:可压缩,高效的列存取;优化I/O。

缺点:不支持upadate操作(数据写入后不可更改),不支持ACID。

Hive压缩算法对比

Hive压缩算法包含6种,其中包含default、gzip、bzip2、lzo、lz4、snappy等压缩格式,具体采用压缩算法及比对详细如下:

编辑

检查Hadoop本地库支持压缩格式

检查命令:hadoop checknative

hadoop checknative 命令检查本地库是否支持压缩,若不支持,需要进行源码编译将native library编译进Hadoop。

native library checking:

hadoop:  true /opt/cloudera/parcels/cdh-6.1.0-1.cdh6.1.0.p0.770702/lib/hadoop/lib/native/libhadoop.so.1.0.0

zlib:     true /lib64/libz.so.1

zstd:     true /opt/cloudera/parcels/cdh-6.1.0-1.cdh6.1.0.p0.770702/lib/hadoop/lib/native/libzstd.so.1

snappy:  true /opt/cloudera/parcels/cdh-6.1.0-1.cdh6.1.0.p0.770702/lib/hadoop/lib/native/libsnappy.so.1

lz4:     true revision:10301

bzip2:   true /lib64/libbz2.so.1

openssl:  true /lib64/libcrypto.so

isa-l:   true /opt/cloudera/parcels/cdh-6.1.0-1.cdh6.1.0.p0.770702/lib/hadoop/lib/native/libisal.so.2

Hive压缩算法设置

default压缩格式

​编辑

set hive.exec.compress.output=true;

set mapred.output.compress=true;

set mapred.output.compression.codec=org.apache.hadoop.io.compress.defaultcodec;

gzip压缩格式

​编辑

set hive.exec.compress.output=true;

set mapred.output.compress=true;

set mapred.output.compression.codec=org.apache.hadoop.io.compress.gzipcodec;

bzip2压缩格式

​编辑

set hive.exec.compress.output=true;

set mapred.output.compress=true;

set mapred.output.compression.codec=org.apache.hadoop.io.compress.bzip2codec;

lzo压缩格式

​编辑

set hive.exec.compress.output=true;

set mapred.output.compress=true;

set mapred.output.compression.codec=com.hadoop.compression.lzo.lzopcodec;

lz4压缩格式

​编辑

set hive.exec.compress.output=true;

set mapred.output.compress=true;

set mapred.output.compression.codec= org.apache.hadoop.io.compress.lz4pcodec;

snappy压缩格式

​编辑

set hive.exec.compress.output=true;

set mapred.compress.map.output=true;

set mapred.output.compress=true;

set mapred.output.compression=org.apache.hadoop.io.compress.snappycodec;

set mapred.output.compression.codec=org.apache.hadoop.io.compress.snappycodec;

set io.compression.codecs=org.apache.hadoop.io.compress.snappycodec;

压缩算法测试及结果比对

测试案例

​编辑

测试一个Hive在不同的压缩格式下进行对压缩比、查询效率、插入效率进行结果比对。

测试环境

​编辑

大数据平台产品:CDH6.1

节点个数:2+6

内存:256G

CPU:64核

测试数据

​编辑

表名称:ods.o_cor_test

源文件大小:3.8G

查询速度:19.41S

建表语句:

CREATE TABLE ODS.O_COR_TEST

(  BOOK_ID                 STRING,

EVENT_ID                 STRING,

TRX_ID_IN                STRING,

TRX_ID_OUT               STRING,

LINE_ID                  STRING,

HEADER_ID                STRING,

BATCH_ID                 STRING,

BOOK_TYPE                STRING,

ASSET_TYPE               STRING,

CATEGORY_ID              STRING,

INTERFACE_CONTROL_ID_IN  STRING,

INTERFACE_CONTROL_ID_OUT STRING,

EFFECTIVE_DATE           DATE,

INEFFECTIVE_DATE         DATE,

DATA_DATE                DATE,

ACCOUNTING_DATE          DATE,

EVENT_TYPE               STRING,

ACTIVE_CODE              STRING,

AMORTIZED_COST           STRING,

FAIR_COST                STRING,

CONTACT_IN               STRING,

CONTACT_OUT              STRING,

COST                     STRING,

INT                      STRING,

INT_ADJUST               STRING,

EVALUATION_ADJUST        STRING,

FAIR_COST_ADJUST         STRING,

CV_RESERVE               STRING,

RV_RESERVE               STRING,

HV_RESERVE               STRING,

RA_COST                  STRING,

LEASE_COST               STRING,

LEASE_CV_RESERVE         STRING,

LEASE_RV_RESERVE         STRING,

LEASE_HV_RESERVE         STRING,

INVESTMENT_INCOME        STRING,

INVESTMENT_LOSS          STRING,

FAIR_COST_GAIN_LOSS      STRING,

V_LOSS                   STRING,

OTHER_INCOME             STRING,

ORIGINAL                 STRING,

TRANS_INT_IN             STRING,

TRANS_INT_OUT            STRING,

INT_ACCRUED              STRING,

EXPENSE                  STRING,

RECOV_ORIGINAL           STRING,

RECOV_TRANS_INT_IN       STRING,

RECOV_TRANS_INT_OUT      STRING,

RECOV_INT_ACCRUED        STRING,

RECOV_EXPENSE            STRING,

LOSS_ORIGINAL            STRING,

LOSS_TRANS_INT_IN        STRING,

LOSS_TRANS_INT_OUT       STRING,

LOSS_INT_ACCRUED         STRING,

LOSS_EXPENSE             STRING,

LEASE_ORIGINAL           STRING,

GUARANTEE1               STRING,

GUARANTEE2               STRING,

GUARANTEE3               STRING,

BALANCE_OUT              STRING,

LY_INVESTMENT_INCOME     STRING,

LY_INVESTMENT_LOSS       STRING,

LY_FAIR_COST_GAIN_LOSS   STRING,

LY_V_LOSS                STRING,

LAST_UPDATE_DATE         DATE,

LAST_UPDATED_BY          STRING,

CREATION_DATE            DATE,

CREATED_BY               STRING,

LAST_UPDATE_LOGIN        STRING,

ATTRIBUTE_CATEGORY       STRING,

ATTRIBUTE1               STRING,

ATTRIBUTE2               STRING,

ATTRIBUTE3               STRING,

ATTRIBUTE4               STRING,

ATTRIBUTE5               STRING,

ATTRIBUTE6               STRING,

ATTRIBUTE7               STRING,

ATTRIBUTE8               STRING,

ATTRIBUTE9               STRING,

ATTRIBUTE10              STRING,

INT_AMORTIZED            STRING,

START_DATE               DATE,

END_DATE                 DATE,

DEL_FLAG                 STRING

)

测试方法

本测试采用每次开启Hive压缩模式并设置Hive的压缩算法,对于Hive每种文件存储格式新建Hive表,并向不同分区插入数据,测试并记录各种压缩算法的压缩效率、查询速率、插入速度。

注:每次设置终端退出后设置无效。

查询速率测试sql语句:

select count(*) from ods.o_cor_test where etl_date=

压缩算法对比

编辑

编辑

编辑

编辑

测试结果

当应用场景多为查询时,建议使用orcfile存储格式且压缩格式为default。

当应用场景多为存储时,建议使用orcfile存储格式且压缩格式为bzip2。

当应用场景多为插入时,建议使用sequencefile存储格式且压缩格式为snappy。

一般常用存储格式为orcfile且压缩格式为default。

实用干货分享(5)- Hive存储格式及压缩算法测试比对分析的更多相关文章

  1. 逆向实用干货分享,Hook技术第一讲,之Hook Windows API

    逆向实用干货分享,Hook技术第一讲,之Hook Windows API 作者:IBinary出处:http://www.cnblogs.com/iBinary/版权所有,欢迎保留原文链接进行转载:) ...

  2. 逆向实用干货分享,Hook技术第二讲,之虚表HOOK

    逆向实用干货分享,Hook技术第二讲,之虚表HOOK 正好昨天讲到认识C++中虚表指针,以及虚表位置在反汇编中的表达方式,这里就说一下我们的新技术,虚表HOOK 昨天的博客链接: http://www ...

  3. 【腾讯优测干货分享】Android内存泄漏的简单检查与分析方法

    本文来自于Dev Club 开发者社区,非经作者同意,请勿转载,原文地址:http://dev.qq.com/topic/57d14047603a5bf1242ad01b 导语 内存泄漏问题大约是An ...

  4. 【腾讯优测干货分享】安卓专项测试之GPU测试探索

    本文来自于Dev Club 开发者社区,非经作者同意,请勿转载,原文地址:http://dev.qq.com/topic/57c7ffdc0569a1191bce8a63 作者:章未哲——腾讯SNG质 ...

  5. 【干货分享】Google 的设计准则,素材和资源

    在谷歌,他们说, “专注于用户,所有其它的就会水到渠成 ”.他们遵循设计原则,寻求建立让用户惊喜的用户体验.谷歌一直挑战自己,为他们的用户创造一种视觉语言,综合优秀设计的经典原则和创新.谷歌设计规范是 ...

  6. APP运营干货分享

    从移动互联网市场总监岗位出发,从几个方面来阐述移动互联网部门如何制定一份运营推广策划案,至于关于移动互联网,移动电商是大趋势这些虚的.空泛的文字,不展开说了. 一.竞品分析 1.选择竞品,做好定位(选 ...

  7. Hive存储格式之RCFile详解,RCFile的过去现在和未来

    我在整理Hive的存储格式和压缩格式,本来打算一篇发出来,结果其中一小节就有很多内容,于是打算写成Hive存储格式和压缩格式系列. 本节主要讲一下Hive存储格式最早的典型的列式存储格式RCFile. ...

  8. Hive存储格式之ORC File详解,什么是ORC File

    目录 概述 文件存储结构 Stripe Index Data Row Data Stripe Footer 两个补充名词 Row Group Stream File Footer 条纹信息 列统计 元 ...

  9. 干货分享:SQLSERVER使用裸设备

    干货分享:SQLSERVER使用裸设备 这篇文章也适合ORACLE DBA和MYSQL DBA 阅读 裸设备适用于Linux和Windows 在ORACLE和MYSQL里也是支持裸设备的!! 介绍 大 ...

  10. iOS - GitHub干货分享(APP引导页的高度集成 - DHGuidePageHUD - ②)

    距上一篇博客"APP引导页的高度集成 - DHGuidePageHUD - ①"的发布有一段时间了, 后来又在SDK中补充了一些新的内容进去但是一直没来得及跟大家分享, 今天来跟大 ...

随机推荐

  1. Camera 冷启动阶段分解

    目录 一.Camx trace 调试开关设置 1.设置 camxoverridesettings trace开关 2. 重启后设置开启camx trace 开关 二.Camera 冷启动阶段分解分析 ...

  2. 分布式缓存 - 缓存服务器 - redis

    如果一般的缓存可以解决问题,就不必使用分布式缓存 : 一般使用分布式缓存 都是使用 redis : 使用教程: 1. 安装包 Microsoft.Extensions.Caching.StackExc ...

  3. 在 Debian 12 上安装 KubeSphere 实战入门

    老 Z,运维架构师,云原生爱好者,目前专注于云原生运维,云原生领域技术栈涉及 Kubernetes.KubeSphere.DevOps.OpenStack.Ansible 等. 前言 知识点 定级:入 ...

  4. C++版的Mc

    非常垃圾的c++版Mc. #include<bits/stdc++.h> #include<windows.h> #include<conio.h> using n ...

  5. cxv文件合并

    1.新建bat脚本 @echo off setlocal enabledelayedexpansion copy *.csv new.csv echo @@@@@@@@@@@@@合并成功!@@@@@@ ...

  6. URL是什么

    URL是什么 URL(Uniform Resource Locator,统一资源定位器) URL的组成: 协议://{域名|主机名|IP}:端口/路径/文件名?参数#锚点 协议 Scheme/Prot ...

  7. Windows 如何启用 Administrator 账户

    Windows 默认安装的时候需要自己定义一个账户,不是管理员账户,不能操作某些目录,有时很不方便.不过我们可以手动打开,像盗版一样默认使用 Administrator  账户: 按下Win + R, ...

  8. [图像处理] 基于CleanVision库清洗图像数据集

    CleanVision是一个开源的Python库,旨在帮助用户自动检测图像数据集中可能影响机器学习项目的常见问题.该库被设计为计算机视觉项目的初步工具,以便在应用机器学习之前发现并解决数据集中的问题. ...

  9. Go语言创建Web服务器

    因为Go语言自带高性能服务器,且支持http.TCP/UDP,这得益于内置了net/http包,这个包提供了HTTP客户端和服务端的实现, 所以用Go语言创建Web服务器,代码很简洁. 说明: 1.导 ...

  10. Rust 的静态网站生成器「GitHub 热点速览」

    如果你做过个人博客网站,那么一定对静态网站生成器不陌生.无论是 Ruby 语言的 Jekyll.Go 语言的 Hugo.还是基于 React 的 Gatsby,这些工具都有庞大的用户群体.对于喜欢的人 ...