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

相关推荐
Themberfue3 分钟前
基础算法之双指针--Java实现(下)--LeetCode题解:有效三角形的个数-查找总价格为目标值的两个商品-三数之和-四数之和
java·开发语言·学习·算法·leetcode·双指针
深山夕照深秋雨mo12 分钟前
在Java中操作Redis
java·开发语言·redis
努力的布布17 分钟前
SpringMVC源码-AbstractHandlerMethodMapping处理器映射器将@Controller修饰类方法存储到处理器映射器
java·后端·spring
xujinwei_gingko18 分钟前
Spring MVC 常用注解
java·spring·mvc
PacosonSWJTU22 分钟前
spring揭秘25-springmvc03-其他组件(文件上传+拦截器+处理器适配器+异常统一处理)
java·后端·springmvc
PacosonSWJTU24 分钟前
spring揭秘26-springmvc06-springmvc注解驱动的web应用
java·spring·springmvc
原野心存1 小时前
java基础进阶——继承、多态、异常捕获(2)
java·java基础知识·java代码审计
进阶的架构师1 小时前
互联网Java工程师面试题及答案整理(2024年最新版)
java·开发语言
黄俊懿1 小时前
【深入理解SpringCloud微服务】手写实现各种限流算法——固定时间窗、滑动时间窗、令牌桶算法、漏桶算法
java·后端·算法·spring cloud·微服务·架构
木子02041 小时前
java高并发场景RabbitMQ的使用
java·开发语言