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

相关推荐
FrankYoou25 分钟前
Jenkins 与 GitLab CI/CD 的核心对比
java·docker
永洪科技26 分钟前
永洪科技荣获商业智能品牌影响力奖,全力打造”AI+决策”引擎
大数据·人工智能·科技·数据分析·数据可视化·bi
麦兜*1 小时前
Spring Boot启动优化7板斧(延迟初始化、组件扫描精准打击、JVM参数调优):砍掉70%启动时间的魔鬼实践
java·jvm·spring boot·后端·spring·spring cloud·系统架构
weixin_307779131 小时前
Hive集群之间迁移的Linux Shell脚本
大数据·linux·hive·bash·迁移学习
KK溜了溜了1 小时前
JAVA-springboot 整合Redis
java·spring boot·redis
天河归来1 小时前
使用idea创建springboot单体项目
java·spring boot·intellij-idea
weixin_478689762 小时前
十大排序算法汇总
java·算法·排序算法
码荼2 小时前
学习开发之hashmap
java·python·学习·哈希算法·个人开发·小白学开发·不花钱不花时间crud
IT_10242 小时前
Spring Boot项目开发实战销售管理系统——数据库设计!
java·开发语言·数据库·spring boot·后端·oracle
ye902 小时前
银河麒麟V10服务器版 + openGuass + JDK +Tomcat
java·开发语言·tomcat