orcFile split和读数据原理总结(hive0.13)

本文详细介绍了Hive ORCFile的优化特性,包括按列存储、索引支持、行组跳过等,分析了split读取原理,探讨了不同配置如hive.optimize.index.filter和hive.exec.orc.zerocopy对性能的影响,并通过测试结果展示了在不同条件下split和读取数据的优缺点。
摘要由CSDN通过智能技术生成

官网关于orcfile的介绍

背景

Hive的rcfile格式已经使用多年,但是,它会将所有的列都当做二进制来处理,没有与类型挂钩。因此,Hive0.11版本引入orcFile。OrcFile有以下几点好处:

  • 每个task只生成一个文件,减轻hdfs压力
  • 保存列类型,支持datetime, decimal和负责类型(struct, list, map, and union)
  • 文件中保存轻量级索引
    • 跳过不需的row group
    • seek到指定的row
  • 根据列类型进行压缩
    • 整数类型:run-length encoding
    • string类型:dictionary encoding
  • 不同的recordReader并发读同一文件
  • split时,无需扫描标记
  • 可以限制读写占用的内存
  • 使用pb存放元数据,支持添加和移除列

结构

这里写图片描述
(图片来源:https://cwiki.apache.org/confluence/display/Hive/LanguageManual+ORC

orc dump工具

// Hive version 0.11 through 0.14:
hive --orcfiledump <location-of-orc-file>

// Hive version 0.15 and later:
hive --orcfiledump [-d] [--rowindex <col_ids>] <location-of-orc-file>

// Hive version 1.2.0 and later:
hive --orcfiledump [-d] [-t] [--rowindex <col_ids>] <location-of-orc-file>

// Hive version 1.3.0 and later:
hive --orcfiledump 
  • 1
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值