Flink1.18 Transfrom - RichFunction
1.Flink1.18环境代码编写2.Flink1.18传统批处理代码编写3.flink1.18传统流处理环境编写4.flink1.18流批一体DataStream代码编写5.Flink1.18 Source - FileSource6.Flink1.18 Source - fromElements7.Flink1.18 Source - KafkaSource8.Flink1.18 Source - 数据生成器9.Flink1.18 Transfrom - Map10.Flink1.18 Transfrom - flatMap11.Flink1.18 Transfrom - Filter12.Flink1.18 Transfrom - KeyBy
13.Flink1.18 Transfrom - RichFunction
14.Flink1.18 Transfrom - SimpleAggregate简单聚合算子15.Flink1.18 Transfrom - Reduce16.Flink1.18 Transfrom - 分区器【7种现成】17.Flink1.18 Transfrom - CustomPartition自定义分区器18.Flink1.18 Transfrom - 分流【Filter】19.Flink1.18 Transfrom - 分流【侧输出流 ProcessFunction】20.Flink1.18 Transfrom - 合流【Union】21.Flink1.18 Transfrom - 合流【Connect, 并行度为1的情况】22.Flink1.18 Transfrom - 合流【Connect 两个流数据进行关联】23.Flink1.18 Sink - 到文件 新版本写法sinkToFile24.Flink1.18 Sink - 到Kafka 新版本写法sinkTo的使用25.Flink1.18 Sink - 到Kafka自定义序列化类 新版本写法sinkTo的使用26.Flink1.18 Sink - 到JDBC 使用新依赖【因返回值是sinkFunction, 故目前只支持addSink使用, 1.18版本不支持sinkTo】27.Flink1.18 Sink - 精确一次ExactlyOnce到JDBC 使用新依赖【因返回值是sinkFunction, 故目前只支持addSink使用, 1.18版本不支持sinkTo】28.Flink1.18 Sink - 自定义sink29.大数据之路Week10_day07 (JavaAPI 操作Redis 与Hbase建立索引,通过查询redis中的索引查询Hbase数据)30.大数据之路Week10_day07 (JavaAPI 操作Redis 模拟将redis当作缓存,从Mysql数据库中查询数据)package com.xiaohu.transfrom;
import com.xiaohu.bean.WaterSensor;
import org.apache.flink.api.common.functions.RichFilterFunction;
import org.apache.flink.configuration.Configuration;
import org.apache.flink.streaming.api.datastream.DataStreamSource;
import org.apache.flink.streaming.api.environment.StreamExecutionEnvironment;
/*
富函数与普通的function的区别在于多了一个算子运行前执行方法open()和一个算子结束后执行方法close()
所有的算子都有一个对应的RichXxxFunction
注意:
正常退出【算子执行结束或命令页面中cancel】,close方法会执行,cancel后会close方法执行且也会报错提示
但是若异常退出【手动,突然宕机】,close方法不会执行
*/
public class RichFunctionDemo {
public static void main(String[] args) throws Exception {
StreamExecutionEnvironment env = StreamExecutionEnvironment.getExecutionEnvironment();
env.setParallelism(1);
DataStreamSource<WaterSensor> senorDS = env.fromElements(
new WaterSensor("s1", 1L, 5),
new WaterSensor("s2", 2L, 2),
new WaterSensor("s3", 3L, 3),
new WaterSensor("s1", 4L, 4),
new WaterSensor("s2", 5L, 5),
new WaterSensor("s1", 6L, 6)
);
// senorDS.filter(new FilterFunction<WaterSensor>() {
// @Override
// public boolean filter(WaterSensor value) throws Exception {
// return "s1".equals(value.getId());
// }
// }).print();
//使用富函数
senorDS.filter(new RichFilterFunction<WaterSensor>() {
@Override
public void open(Configuration parameters) throws Exception {
System.out.println("我来了。。。。");
}
@Override
public boolean filter(WaterSensor value) throws Exception {
return "s1".equals(value.getId());
}
@Override
public void close() throws Exception {
System.out.println("我结束了。。。。");
}
}).print();
env.execute();
}
}
分类:
Flink
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 无需6万激活码!GitHub神秘组织3小时极速复刻Manus,手把手教你使用OpenManus搭建本
· C#/.NET/.NET Core优秀项目和框架2025年2月简报
· 一文读懂知识蒸馏
· Manus爆火,是硬核还是营销?
· 终于写完轮子一部分:tcp代理 了,记录一下