实践数据湖iceberg 第三十四课 基于数据湖icerberg的流批一体架构-流架构测试

系列文章目录

实践数据湖iceberg 第一课 入门
实践数据湖iceberg 第二课 iceberg基于hadoop的底层数据格式
实践数据湖iceberg 第三课 在sqlclient中,以sql方式从kafka读数据到iceberg
实践数据湖iceberg 第四课 在sqlclient中,以sql方式从kafka读数据到iceberg(升级版本到flink1.12.7)
实践数据湖iceberg 第五课 hive catalog特点
实践数据湖iceberg 第六课 从kafka写入到iceberg失败问题 解决
实践数据湖iceberg 第七课 实时写入到iceberg
实践数据湖iceberg 第八课 hive与iceberg集成
实践数据湖iceberg 第九课 合并小文件
实践数据湖iceberg 第十课 快照删除
实践数据湖iceberg 第十一课 测试分区表完整流程(造数、建表、合并、删快照)
实践数据湖iceberg 第十二课 catalog是什么
实践数据湖iceberg 第十三课 metadata比数据文件大很多倍的问题
实践数据湖iceberg 第十四课 元数据合并(解决元数据随时间增加而元数据膨胀的问题)
实践数据湖iceberg 第十五课 spark安装与集成iceberg(jersey包冲突)
实践数据湖iceberg 第十六课 通过spark3打开iceberg的认知之门
实践数据湖iceberg 第十七课 hadoop2.7,spark3 on yarn运行iceberg配置
实践数据湖iceberg 第十八课 多种客户端与iceberg交互启动命令(常用命令)
实践数据湖iceberg 第十九课 flink count iceberg,无结果问题
实践数据湖iceberg 第二十课 flink + iceberg CDC场景(版本问题,测试失败)
实践数据湖iceberg 第二十一课 flink1.13.5 + iceberg0.131 CDC(测试成功INSERT,变更操作失败)
实践数据湖iceberg 第二十二课 flink1.13.5 + iceberg0.131 CDC(CRUD测试成功)
实践数据湖iceberg 第二十三课 flink-sql从checkpoint重启
实践数据湖iceberg 第二十四课 iceberg元数据详细解析
实践数据湖iceberg 第二十五课 后台运行flink sql 增删改的效果
实践数据湖iceberg 第二十六课 checkpoint设置方法
实践数据湖iceberg 第二十七课 flink cdc 测试程序故障重启:能从上次checkpoint点继续工作
实践数据湖iceberg 第二十八课 把公有仓库上不存在的包部署到本地仓库
实践数据湖iceberg 第二十九课 如何优雅高效获取flink的jobId
实践数据湖iceberg 第三十课 mysql->iceberg,不同客户端有时区问题
实践数据湖iceberg 第三十一课 使用github的flink-streaming-platform-web工具,管理flink任务流,测试cdc重启场景
实践数据湖iceberg 第三十二课 DDL语句通过hive catalog持久化方法
实践数据湖iceberg 第三十三课 升级flink到1.14,自带functioin支持json函数
实践数据湖iceberg 第三十四课 基于数据湖icerberg的流批一体架构-流架构测试
实践数据湖iceberg 更多的内容目录


文章目录

  • 系列文章目录
  • 前言
  • 一、基于数据湖icerberg的流批一体架构
  • 二、创建表
  • 三、创建topic
  • 四. 测试:
    • 1.测试count
    • 4.2 测试group by count
    • 4.3 参考官网配置流模式
    • 4.4 流模式group by测试
  • 总结


前言

lambda架构中, kafka->flink中支持 各种流函数,
数据入iceberg后,如何对icberg进行流操作,实现类似流函数的结果?
基于数据湖的流批一体是什么意思?


一、基于数据湖icerberg的流批一体架构

整体思路:
实践数据湖iceberg 第三十四课 基于数据湖icerberg的流批一体架构-流架构测试_第1张图片
批计算,很好理解,跟原来hive的离线任务一样。
流计算:基于iceberg能否支持想操作kafka一样的流计算? 有什么特点?

流计算测试三种语法: 1.select * ,2.select count 3.group by count语法,如下图
实践数据湖iceberg 第三十四课 基于数据湖icerberg的流批一体架构-流架构测试_第2张图片

二、创建表

创建表:

CREATE TABLE IF NOT EXISTS KafkaTableSource_XXZH (
    `log` STRING,
	`date` STRING
) WITH (
    'connector' = 'kafka',
    'topic' = 'test_xxzh',
    'properties.bootstrap.servers' = 'hadoop101:9092,hadoop102:9092,hadoop103:9092',
    'properties.group.id' = 'testGroup',
    'scan.startup.mode' = 'earliest-offset',
    'format' = 'csv'
);


CREATE CATALOG hive_iceberg_catalog WITH (
    'type'='iceberg',
    'catalog-type'='hive',
    'uri'='thrift://hadoop101:9083',
    'clients'='5',
    'property-version'='1',
    'warehouse'='hdfs:///user/hive/warehouse/hive_iceberg_catalog'
);
use catalog hive_iceberg_catalog;
CREATE TABLE IF NOT EXISTS ods_base.IcebergSink_XXZH (
    `log` STRING,
	`dt` STRING
)with(
    'write.metadata.delete-after-commit.enabled'='true',
    'write.metadata.previous-versions-max'='5',
    'format-version'='2'
 );
 
 insert into  ods_base.IcebergSink_XXZH select * from default_catalog.default_database.KafkaTableSource_XXZH;

实践数据湖iceberg 第三十四课 基于数据湖icerberg的流批一体架构-流架构测试_第3张图片
上面sql意义:
实践数据湖iceberg 第三十四课 基于数据湖icerberg的流批一体架构-流架构测试_第4张图片

三、创建topic

[root@hadoop101 hadoop]# kafka-console-producer.sh --broker-list hadoop10192,hadoop102:9092,hadoop103:9092 --topic test_xxzh

四. 测试:

1.测试count

实践数据湖iceberg 第三十四课 基于数据湖icerberg的流批一体架构-流架构测试_第5张图片

观察结果
在这里插入图片描述
结果: 多生产一条,count的结果,增加1
在这里插入图片描述
结论: count能实时随数据变化

4.2 测试group by count

对source 表测试,没用
在这里插入图片描述
没有变化,生产者不断加数据,groupBy结果没变化
实践数据湖iceberg 第三十四课 基于数据湖icerberg的流批一体架构-流架构测试_第6张图片
失败原因: 是没有使用流模式,下面使用流模式测试

4.3 参考官网配置流模式

SET execution.type = streaming ;
SET table.dynamic-table-options.enabled=true;
select `date`,count(*) from KafkaTableSource_XXZH /*+ OPTIONS('streaming'='true', 'monitor-interval'='1s')*/ group by `date`  ;

参考官网语法: https://iceberg.apache.org/docs/latest/flink/
实践数据湖iceberg 第三十四课 基于数据湖icerberg的流批一体架构-流架构测试_第7张图片

4.4 流模式group by测试

对数据湖表测试:
select dt,count(1) from icebergsink_xxzh /+ OPTIONS(‘streaming’=‘true’, ‘monitor-interval’=‘1s’)/ group by dt;

Flink SQL>  select dt,count(1) from icebergsink_xxzh  /*+ OPTIONS('streaming'='true', 'monitor-interval'='1s')*/  group by dt;

实践数据湖iceberg 第三十四课 基于数据湖icerberg的流批一体架构-流架构测试_第8张图片

实践数据湖iceberg 第三十四课 基于数据湖icerberg的流批一体架构-流架构测试_第9张图片
实践数据湖iceberg 第三十四课 基于数据湖icerberg的流批一体架构-流架构测试_第10张图片
结果加1
实践数据湖iceberg 第三十四课 基于数据湖icerberg的流批一体架构-流架构测试_第11张图片

总结

测试结果:对iceberg操作, 基于批的sql,也能实现update的效果! 流批一体,就是使用一套sql实现流批语义,摆脱原来流批两套语义的语法。
实践数据湖iceberg 第三十四课 基于数据湖icerberg的流批一体架构-流架构测试_第12张图片

你可能感兴趣的:(iceberg,flink,架构,kafka)