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

相关推荐
cur1es8 分钟前
【JVM类加载&双亲委派模型&垃圾回收机制】
java·jvm·gc·垃圾回收·类加载·双亲委派模型
Mr.朱鹏14 分钟前
JVM-GC垃圾回收案例
java·jvm·spring boot·算法·spring·spring cloud·java-ee
焦糖玛奇朵婷37 分钟前
实测扭蛋机小程序:开发简单,互动有趣
java·大数据·程序人生·小程序·软件需求
Nan_Shu_61438 分钟前
学习: 尚硅谷Java项目之小谷充电宝(3)
java·后端·学习
wzqllwy41 分钟前
8 大经典排序算法(Java 实现):原理 + Demo + 核心分析
java·算法·排序算法
智能工业品检测-奇妙智能41 分钟前
AIFlowy如何实现与现有Spring Boot项目的无缝集成?
java·spring boot·后端
從南走到北44 分钟前
JAVA无人共享无人健身房物联网结合系统源码支持小程序+公众号+APP+H5
java·物联网·小程序
Nuopiane1 小时前
MyPal3(3)
java·开发语言
Chan161 小时前
LeetCode 热题 100 | 矩阵
java·开发语言·数据结构·算法·spring·java-ee·intellij-idea
瓦中空花1 小时前
大数据工具-Flink
大数据·flink