一篇文章搞定一个大数据组件:kudu知识点全集

MemRowSet flush下来的数据,按列存储,按主键有序。

UndoFile

基于BaseData之前时间的历史数据,通过在BaseData上applyUndoFile中的记录,可以获得历史数据。

RedoFile

基于BaseData之后时间的变更(mutation)记录,通过在BaseData上applyRedoFile中的记录,可获得较新的数据。

DeltaMem

用于DiskRowSet中数据的变更mutation,先写到内存中,写满后flush到磁盘形成RedoFile。

3.1 储存架构:Tablet


分区策略

Writes

Reads

Tablet Growth

Range

所有写入都会落到最新分区

可以通过分区键提高读能力

可添加新tablets

Hash

在tablets上均匀分布

可以通过分区键提高读能力

tablets会无限增长

Hash分区有利于提高写吞吐量Range分区可避免tablet无限增长问题,所以我们可以使用多级分区,组合这两种分区方式

3.2 储存架构:RowSets


Tablet在底层被进一步细分成了一个称之为RowSets的单元

图片

MemRowSet

用于新数据insert及已在MemRowSet中的数据的更新,一个MemRowSet写满后会将数据刷到磁盘形成若干个DiskRowSet。(默认是1G或者或者120S)

DiskRowSet

用于老数据的变更(mutation),后台定期对DiskRowSet做compaction,以删除没用的数据及合并历史数据,减少查询过程中的IO开销。

3.3 储存架构:DiskRowSets


DiskRowSet分为了两部分:basedata、deltastores。basedata 负责存储基础数据,deltastores负责存储 basedata 中的变更数据

图片

4、kudu工作原理

==============

4.1 Compaction


由于所有插入的数据都是先写入memRowSet,到达一定条件后再写入DiskRowSet,而且DiskRowSet中的basedata是不变的,这就导致会出现数据重叠的现象,导致写或查询时需要搜索大量的DiskRowSet

图片

三种Compaction策略:

DiskRowSet Compaction:减少DiskRowSet数量,优化insert、update和scans时间。

Minor Delta Compaction:只减少delta file数量,优化scans时间。

Major Delta Compaction:对base data和delta file进行compaction,优化scans时间

4.2 Tablet切分规则


建表时指定分区策略

Hash Partitioning:哈希分区通过哈希值将行分配到某一个bucket,每个bucket对应一个tablet,建表时设置bucket的数量。

Range Partitioning:range partition使用完全有序的分区键来分配行,分区键必须是kudu表主键的子集。

DEMO:

CREATE TABLE cust_behavior (

_id BIGINT PRIMARY KEY,

skuSTRING,

rating INT,

fulfilled_dateBIGINT

)

PARTITION BY RANGE(_id)

(

PARTITION VALUES< 1439560049342,

PARTITION1439560049342 <= VALUES < 1439566253755,

PARTITION1439566253755 <= VALUES < 1439572458168,

PARTITION1439572458168 <= VALUES < 1439578662581,

PARTITION1439578662581 <= VALUES < 1439584866994,

PARTITION1439584866994 <= VALUES < 1439591071407,

PARTITION1439591071407 <= VALUES

)

STORED AS KUDU;

4.3 kudu写过程:insert


Kudu与HBase不同,Kudu将写入操作分为两种:一种是插入新数据,另一种是更新数据

图片

1、客户端连接Master获取表的相关信息,包括分区信息,表中所有tablet的信息;

2、客户端找到负责处理读写请求的tablet所负责维护的TServer。Kudu接受客户端的请求,检查请求是否符合要求(表结构);

3、Kudu在Tablet中的所有rowset(memrowset,diskrowset)中进行查找,看是否存在与待插入数据相同主键的数据,如果存在就返回错误,否则继续;

4、Kudu在MemRowset中写入一行新数据,在MemRowset数据达到一定大小时,MemRowset将数据落盘,并生成一个diskrowset用于持久化数据,还生成一个memrowset继续接收新数据的请求。

4.4 kudu写过程:update


图片

4.5 Kudu读过程


图片

1、客户端连接Master获取表的相关信息,包括分区信息,表中所有tablet的信息;

2、客户端找到需要读取的数据的tablet所在的TServer,Kudu接受读请求,并记录timestamp信息,如果没有显式指定,那么表示使用当前时间;

img
img
img

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,涵盖了95%以上大数据知识点,真正体系化!

由于文件比较多,这里只是将部分目录截图出来,全套包含大厂面经、学习笔记、源码讲义、实战项目、大纲路线、讲解视频,并且后续会持续更新

需要这份系统化资料的朋友,可以戳这里获取

-FTeyw74b-1714462656402)]
[外链图片转存中…(img-aOh6QMaC-1714462656403)]

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,涵盖了95%以上大数据知识点,真正体系化!

由于文件比较多,这里只是将部分目录截图出来,全套包含大厂面经、学习笔记、源码讲义、实战项目、大纲路线、讲解视频,并且后续会持续更新

需要这份系统化资料的朋友,可以戳这里获取

  • 19
    点赞
  • 29
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
以下是一个示例的Shell脚本,用于在Kudu和HDFS上执行一些常见的操作: ```bash #!/bin/bash # 定义Hadoop和Kudu的安装路径以及相关命令 HADOOP_HOME=/path/to/hadoop KUDU_HOME=/path/to/kudu HDFS_BIN=$HADOOP_HOME/bin/hdfs KUDU_BIN=$KUDU_HOME/bin/kudu # 启动Hadoop集群 start_hadoop() { $HADOOP_HOME/sbin/start-dfs.sh } # 停止Hadoop集群 stop_hadoop() { $HADOOP_HOME/sbin/stop-dfs.sh } # 启动Kudu集群 start_kudu() { $KUDU_BIN master start $KUDU_BIN tserver start } # 停止Kudu集群 stop_kudu() { $KUDU_BIN tserver stop $KUDU_BIN master stop } # 创建HDFS目录 create_hdfs_dir() { $HDFS_BIN dfs -mkdir /path/to/directory } # 创建Kudu表格 create_kudu_table() { $KUDU_BIN table create table_name \ --schema "column_name:data_type, ..." \ --partitioning "column_name:hash(num_partitions)" } # 运行示例命令 start_hadoop # 启动Hadoop集群 start_kudu # 启动Kudu集群 create_hdfs_dir # 创建HDFS目录 create_kudu_table # 创建Kudu表格 # 根据需要执行其他操作 stop_kudu # 停止Kudu集群 stop_hadoop # 停止Hadoop集群 ``` 请注意,此脚本仅提供了一些基本的操作示例,并且需要根据您的实际环境和需求进行修改。确保将`/path/to/hadoop`和`/path/to/kudu`替换为您的Hadoop和Kudu的安装路径,并根据您的需求自定义其他命令和参数。 此外,您还可以根据需要添加其他操作,例如数据导入导出、查询等。确保在执行脚本之前,您已经正确配置了Hadoop和Kudu的环境,并具备足够的权限执行所需的操作。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值