Flink SideOutput怎么使用
发表于:2025-12-03 作者:千家信息网编辑
千家信息网最后更新 2025年12月03日,这篇文章主要介绍"Flink SideOutput怎么使用",在日常操作中,相信很多人在Flink SideOutput怎么使用问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家
千家信息网最后更新 2025年12月03日Flink SideOutput怎么使用
这篇文章主要介绍"Flink SideOutput怎么使用",在日常操作中,相信很多人在Flink SideOutput怎么使用问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答"Flink SideOutput怎么使用"的疑惑有所帮助!接下来,请跟着小编一起来学习吧!
SideOutput方法:(侧输出)从主数据流中根据outputTag获取额外的输出流(分流场景下使用)
示例环境
java.version: 1.8.xflink.version: 1.11.1
示例数据源 (项目码云下载)
Flink 系例 之 搭建开发环境与数据
SideOutput.java
import com.flink.examples.DataSource;import org.apache.flink.api.java.tuple.Tuple3;import org.apache.flink.api.java.tuple.Tuple4;import org.apache.flink.streaming.api.datastream.DataStream;import org.apache.flink.streaming.api.datastream.SingleOutputStreamOperator;import org.apache.flink.streaming.api.environment.StreamExecutionEnvironment;import org.apache.flink.streaming.api.functions.ProcessFunction;import org.apache.flink.util.Collector;import org.apache.flink.util.OutputTag;import java.util.List;/** * @Description SideOutput方法:(侧输出)从主数据流中根据outputTag获取额外的输出流(分流场景下使用) */public class SideOutput { /** * 遍历集合,将数据流切分成多个流并打印 * @param args * @throws Exception */ public static void main(String[] args) throws Exception { final StreamExecutionEnvironment env = StreamExecutionEnvironment.getExecutionEnvironment(); env.setParallelism(1); List> tuple3List = DataSource.getTuple3ToList(); //Datastream DataStream> dataStream = env.fromCollection(tuple3List); //自定义man和girl两个性别tag OutputTag> manTag = new OutputTag>("man"){}; OutputTag> girlTag = new OutputTag>("girl"){}; //将所有流数据输入到process做处理 SingleOutputStreamOperator> output = dataStream.process(new ProcessFunction, Tuple4>() { @Override public void processElement(Tuple3 value, Context ctx, Collector> out) throws Exception { //将数据流按不同的性别划分,创建新的Tuple4,分别绑定到不同性别的tag if (value.f1.equals("man")){ ctx.output(manTag, Tuple4.of(value.f0, value.f1, value.f2, "男")); }else { ctx.output(girlTag, Tuple4.of(value.f0, value.f1, value.f2, "女")); } } }); //获取指定tag的数据流 DataStream> dataStream1 = output.getSideOutput(manTag); DataStream> dataStream2 = output.getSideOutput(girlTag); //打印 dataStream1.print(); dataStream2.print(); env.execute("flink Split job"); }} 打印结果
(张三,man,20,男)(李四,girl,24,女)(王五,man,29,男)(刘六,girl,32,女)(伍七,girl,18,女)(吴八,man,30,男)
到此,关于"Flink SideOutput怎么使用"的学习就结束了,希望能够解决大家的疑惑。理论与实践的搭配能更好的帮助大家学习,快去试试吧!若想继续学习更多相关知识,请继续关注网站,小编会继续努力为大家带来更多实用的文章!
数据
数据流
学习
输出
性别
方法
不同
场景
更多
环境
示例
帮助
实用
接下来
两个
多个
数据源
文章
理论
知识
数据库的安全要保护哪些东西
数据库安全各自的含义是什么
生产安全数据库录入
数据库的安全性及管理
数据库安全策略包含哪些
海淀数据库安全审计系统
建立农村房屋安全信息数据库
易用的数据库客户端支持安全管理
连接数据库失败ssl安全错误
数据库的锁怎样保障安全
网络安全教程视频调色
对企业网络安全而言
软件开发公司的激励方案
计算机网络技术是学什么技术
婺城区软件开发部
服务器主板值钱吗
asp写入sql数据库
广西网络安全培训服务机构
2021年网络安全工作要点
欢乐颂小说软件开发
博兴纺织软件开发价格
网络安全应急演练有哪些方式
数据库学习需要的电脑性能
车联网 网络安全公司
东莞移动软件开发咨询
北京中房信网络技术有限公司
互联网衍生的科技
软件开发发流程图
软件开发的行业发展情况
菏泽分销软件开发哪家靠谱
食品安全承保数据库
我的世界阿里云服务器
saas一般用啥数据库
生死狙击怎么找玩过的服务器
数据库日志简介
服务器的运转是人工还是机器
数据库权限的适用场合
宁夏思杰网络技术有限公司
炉石app查看卡牌数据库
对网络安全共同体的看法