news 2026/6/22 22:49:20

Flink学习笔记:多流 Join

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
Flink学习笔记:多流 Join

前面我们已经了解了 Flink 几个核心概念,分别是时间、Watermark 已经窗口。今天我们来一起了解下 Flink 是怎么进行多个流的 Join 的。

我们今天从两个流的 Join 来入手,扩展到多个流也是一样的道理。Flink 中的 Join 可以分为两种:Window Join 和 Interval Join。

Window Join

Window Join 是将两个流中在相同窗口中且有相同 key 的元素进行关联。关联后,可以使用 JoinFunction 和 FlatJoinFunction 进行处理。Window Join 可以根据窗口类型分为三种:Tumbling Window Join、Sliding Window Join 和 Session Window Join。

Tumbling Window Join

首先来看Tumbling Window Join,其实就是对应的使用滚动窗口进行 Join。

TumblingWindowJoin

具体使用方法如下:

DataStream<Tuple2<String, Double>> result = source1.join(source2)

.where(record -> record.f0)

.equalTo(record -> record.f0)

.window(TumblingEventTimeWindows.of(Time.seconds(2L)))

.apply(new JoinFunction<Tuple2<String, Double>, Tuple2<String, Double>, Tuple2<String, Double>>() {

@Override

public Tuple2<String, Double> join(Tuple2<String, Double> record1, Tuple2<String, Double> record2) throws Exception {

return Tuple2.of(record1.f0, record1.f1);

}

});

其中 source1 和 source2 分别代表两个流,where 为 source1 的 join key 提取方法,equalTo 为 source2 的 join key 提取方法,最后,join 好之后的数据通过 JoinFunction 来处理。

Sliding Window Join

Sliding Window Join 和 Tumbling Window Join 的用法基本一致,只是将窗口指定为滑动窗口。

SlidingWindowJoin

Session Window Join

Session Window Join 也类似,只是指定的窗口不同,具体的处理流程都是一样的,这里也不过多解释。

Interval Join

Interval Join 是将两个流中 key 相同,且一个流的 timestamp 处于另一个流的 timestamp 上下波动范围内。

假设我们有两个流 a 和 b,Interval Join可以表达为b.timestamp ∈ [a.timestamp + lowerBound; a.timestamp + upperBound] 或 a.timestamp + lowerBound <= b.timestamp <= a.timestamp + upperBound。

需要注意的是,目前 Interval Join 仅支持 event time。

IntervalJoin

它的使用方法也很简单,只需要定义上下偏移量以及处理函数即可。

DataStream<Tuple2<String, Double>> intervalJoinResult = source1.keyBy(record -> record.f0)

.intervalJoin(source2.keyBy(record -> record.f0))

.between(Time.seconds(-2), Time.seconds(2))

.process(new ProcessJoinFunction<Tuple2<String, Double>, Tuple2<String, Double>, Tuple2<String, Double>>() {

@Override

public void processElement(Tuple2<String, Double> record1, Tuple2<String, Double> record2, ProcessJoinFunction<Tuple2<String, Double>, Tuple2<String, Double>, Tuple2<String, Double>>.Context context, Collector<Tuple2<String, Double>> out) throws Exception {

out.collect(Tuple2.of(record1.f0, record1.f1 + record2.f1));

}

});

CoGroup

前面介绍的两种 Join 都是 inner join,那么 Flink 有没有办法支持 left join 呢?答案是肯定的,我们可以使用 coGroup 来实现。

coGroup 的通用用法如下:

stream.coGroup(otherStream)

.where(<KeySelector>)

.equalTo(<KeySelector>)

.window(<WindowAssigner>)

.apply(<CoGroupFunction>);

我们通过自定义 CoGroupFunction 来实现 left join。

private static class LeftJoinFunction implements CoGroupFunction<Tuple2<String, Double>, Tuple2<String, Double>, Tuple2<String, Double>> {

@Override

public void coGroup(Iterable<Tuple2<String, Double>> iterable1, Iterable<Tuple2<String, Double>> iterable2, Collector<Tuple2<String, Double>> collector) throws Exception {

for (Tuple2<String, Double> record1 : iterable1) {

boolean match = false;

for (Tuple2<String, Double> record2 : iterable2) {

match = true;

collector.collect(Tuple2.of(record1.f0, record1.f1 + record2.f1));

}

if (!match) {

System.out.println("没有join的元素 key:" + record1.f0);

collector.collect(Tuple2.of(record1.f0, record1.f1));

}

}

}

}

在 coGroupFunction 中,需要实现 coGroup 方法,方法的参数包括两个输入流的 Iterable 和输出的 collector。如果第二个流中没有匹配的元素,那么就直接输出第一个流的元素。

总结

最后来总结一下,Flink 中有两种 Join 方法,分别为 Window Join 和 Interval Join,Window Join 是依赖窗口来执行,对窗口内的元素进行 join,Interval Join 不依赖窗口,是根据 event time 的范围来进行 join。最后还介绍了 CoGroup,我们可以使用 CoGroup 来实现 left join 和 right join。

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/6/23 10:07:02

AI产品经理必读:构建智能交互系统的终极指南!

简介 文章介绍了构建智能交互系统的关键要点&#xff1a;需求分析需考虑环境特征、用户状态和任务目标&#xff1b;技术选型应平衡成本与效果&#xff0c;避免盲目追求大模型&#xff1b;交互设计要消除歧义&#xff0c;关注情感交互&#xff1b;建立数据闭环实现持续优化&…

作者头像 李华
网站建设 2026/6/23 13:05:01

谷歌浏览器性能面板使用指南

谷歌浏览器性能面板使用指南一、打开性能面板的方法1. 访问方式按 F12 或 CtrlShiftI (Windows/Linux) / CmdOptionI (Mac) 打开开发者工具选择 "Performance" 选项卡或使用快捷键 CtrlShiftE (Windows/Linux) / CmdShiftE (Mac)2. 录制配置刷新页面录制: 点击刷新按…

作者头像 李华
网站建设 2026/6/23 15:18:12

警惕绿色积分陷阱!一分钟揭秘消费骗局

绿色消费积分爆火,但背后暗藏风险&#xff01;提醒身边人 别让“绿色”变“血色”&#xff01;正规模式&#xff1a;国家鼓励积分兑换&#xff0c;需有实体支撑&#xff0c;用户消费获积分&#xff0c;逐步释放兑换商品&#xff0c;三方共建保障价值。但骗局套路更需警惕&#…

作者头像 李华
网站建设 2026/6/23 16:13:42

13、CentOS网络管理全攻略

CentOS网络管理全攻略 在CentOS系统中,网络管理是系统管理的重要组成部分。本文将详细介绍多种网络管理命令和工具的使用方法,帮助你更好地管理和维护CentOS系统的网络。 路由表管理 在CentOS中,可以使用 ip route 和 route 命令来管理路由表。 使用 ip route 命令…

作者头像 李华
网站建设 2026/6/19 18:05:37

技术实践:用大模型平台重构医疗数据分析Pipeline

各位技术同仁&#xff0c;大家好。我所在团队长期负责支持医院的临床科研数据分析项目。过去&#xff0c;我们为每一个研究课题搭建定制化的数据分析Pipeline&#xff1a;数据提取 → 清洗 → 特征工程 → 模型训练/统计分析 → 可视化报告。这套模式存在诸多痛点&#xff1a;开…

作者头像 李华
网站建设 2026/6/23 11:03:19

智元AGIBOT荣登具身智能机器人技术研发排行榜TOP1

当前&#xff0c;全球具身智能机器人产业正进入技术创新发展的关键期。随着数据采集、模型训练、仿真验证等基础技术体系的不断完善&#xff0c;具身智能机器人的技术壁垒正在被逐步突破。本文将从多个维度&#xff0c;为您解析当前在技术研发方面最具实力的5家具身智能机器人公…

作者头像 李华