Hadoop中的SequenceFile

SequenceFile是在Hadoop中常用的一种文件格式。文件中存储的是一个个的Key-Value对。根据是否使用压缩以及压缩内容的不同,SequenceFile提供三种Key-Value对存储方式。

1)不压缩。文件结构为:文件头 + 顺序出现的各个未经压缩的Key-Value对(每隔若干Key-Value对插入一个16字节的同步标记)。

2)分记录压缩。文件结构为:文件头  + 顺序出现的各个压缩了Value部分的Key-Value对(每隔若干Key-Value对插入一个16字节的同步标记)。

3)分数据块压缩。文件结构为:文件头 + 顺序出现的各个数据块(每隔若干数据块插入一个16字节的同步标记),每个数据块包含多个Key-Value对,其中各个Key-Value对的Key部分和Value部分分别被集中起来统一压缩。

以上三种存储方式使用相同结构的文件头。文件头中存储的信息包括:文件类型标记、Key的类型、Value的类型、压缩标记、压缩方式、压缩算法、元数据、同步标记。

使用了同步标记的SequenceFile适合划分为多个分片并行处理,但是每个并行任务需要自行根据同步标记识别分片边界,避免数据重叠。

评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值