Flink状态应用测试程序示例

Flink状态应用测试程序示例

1. 创建执行环境
c 复制代码
        // 1. 创建执行环境
        StreamExecutionEnvironment env = StreamExecutionEnvironment.getExecutionEnvironment();
        env.setParallelism(1);   

2. 创建数据流
c 复制代码
        // 2. 创建数据流
        DataStream<Tuple2<String, Integer>> inputStream = env.fromElements(
                Tuple2.of("a", 1),
                Tuple2.of("b", 2),
                Tuple2.of("c", 3),
                Tuple2.of("a", 4),
                Tuple2.of("b", 5),
                Tuple2.of("c", 6)
        ).uid("source").name("source");

3. 对数据流进行keyBy()操作
c 复制代码
        // 3. 对数据流进行keyBy()操作
        DataStream<Tuple2<String, Integer>> keyedStream = inputStream.keyBy(new KeySelector<Tuple2<String, Integer>, String>() {
            @Override
            public String getKey(Tuple2<String, Integer> stringIntegerTuple2) throws Exception {
                return stringIntegerTuple2.f0;
            }
        });

4. 使用RichFlatMapFunction来实现状态的维护
c 复制代码
        // 4. 使用RichFlatMapFunction来实现状态的维护
        keyedStream.flatMap(new RichFlatMapFunction<Tuple2<String, Integer>, Tuple2<String, Integer>>() {
            // 定义状态变量
            private ValueState<Integer> countState;
            @Override
            public void open(Configuration parameters) throws Exception {
                // 初始化状态变量
                ValueStateDescriptor<Integer> descriptor = new ValueStateDescriptor<>("count", Integer.class);
                countState = getRuntimeContext().getState(descriptor);
            }

            @Override
            public void flatMap(Tuple2<String, Integer> input, Collector<Tuple2<String, Integer>> out) throws Exception {
                // 获取状态变量的值
                Integer currentCount = countState.value();

                // 更新状态变量的值
                if (currentCount == null) {
                    currentCount = 0;
                }
                currentCount++;
                countState.update(currentCount);

                // 输出结果
                out.collect(Tuple2.of(input.f0, currentCount));
            }
        }).print(); 

5.执行任务
c 复制代码
        // 5.执行任务
        env.execute("Flink State Test"); 

6.执行结果
c 复制代码
(a,1)
(b,1)
(c,1)
(a,2)
(b,2)
(c,2)

Process finished with exit code 0

相关推荐
贫民窟的勇敢爷们6 小时前
SpringBoot整合AOP切面编程实战,实现日志统一记录+接口权限校验
java·spring boot·spring
AC赳赳老秦7 小时前
供应链专员提效:OpenClaw自动跟踪物流信息、更新库存数据,异常自动提醒
java·大数据·服务器·数据库·人工智能·自动化·openclaw
迈巴赫车主7 小时前
Java基础:list、set、map一遍过
java·开发语言
QYR-分析7 小时前
高功率飞秒激光器行业发展现状、市场机遇及未来趋势分析
大数据·人工智能
微擎应用7 小时前
全渠道批发订货商城小程序管理系统
大数据·小程序
灵犀学长7 小时前
基于 Spring ThreadPoolTaskScheduler + CronTrigger 实现的动态定时任务调度系统
java·数据库·spring
卷毛迷你猪8 小时前
快速实验篇(A1)干旱气象数据上传至HDFS
大数据·hadoop·hdfs
好家伙VCC9 小时前
【无标题】
java
小碗羊肉9 小时前
【JavaWeb | 第十一篇】文件上传(本地&阿里云OSS)
java·阿里云·servlet
吾疾唯君医9 小时前
Java SpringBoot集成积木报表实操记录
java·spring boot·spring·导出excel·积木报表·数据文件下载