SpringBoot集成flink

Spring Boot 整合 Flink 主要涉及到以下几个步骤:

  1. 添加 Flink 依赖到 Spring Boot 项目的 pom.xml 文件中。
  2. 配置 Flink 环境相关的属性。
  3. 创建 Flink 的 StreamExecutionEnvironment 和其他需要的组件,例如 StreamTableEnvironment。
  4. 在 Spring 容器中初始化 Flink 组件。
  5. 编写 Flink 作业并运行。

以下是一个简单的示例:

pom.xml 添加 Flink 依赖:




<dependencies>
    <!-- 添加 Flink 支持 -->
    <dependency>
        <groupId>org.apache.flink</groupId>
        <artifactId>flink-java</artifactId>
        <version>1.11.0</version>
    </dependency>
    <dependency>
        <groupId>org.apache.flink</groupId>
        <artifactId>flink-streaming-java_2.11</artifactId>
        <version>1.11.0</version>
    </dependency>
</dependencies>

application.properties 配置 Flink 属性:




# Flink 相关配置
flink.job-manager-ip=localhost
flink.job-manager-port=8081
flink.parallelism=1

Flink 配置类:




import org.apache.flink.api.java.utils.ParameterTool;
import org.apache.flink.streaming.api.environment.StreamExecutionEnvironment;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
 
@Configuration
public class FlinkConfig {
 
    @Bean
    public StreamExecutionEnvironment env(ParameterTool parameterTool) {
        final StreamExecutionEnvironment env = StreamExecutionEnvironment.getExecutionEnvironment();
        env.getConfig().setGlobalJobParameters(parameterTool);
        env.setParallelism(parameterTool.getInt("flink.parallelism", 1));
        return env;
    }
}

Flink 作业类:




import org.apache.flink.api.common.functions.MapFunction;
import org.apache.flink.api.java.tuple.Tuple2;
import org.apache.flink.streaming.api.datastream.DataStream;
import org.apache.flink.streaming.api.environment.StreamExecutionEnvironment;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Component;
 
@Component
public class FlinkStreamingJob {
 
    private final StreamExecutionEnvironment env;
 
    @Autowired
    public FlinkStreamingJob(StreamExecutionEnvironment env) {
        this.env = env;
    }
 
    public void run() throws Exception {
        DataStream<Tuple2<String, Integer>> dataStream = env
                .fromElements(Tuple2.of("hello", 1), Tuple2.of("world", 2))
                .map(new MapFunction<Tuple2<String, Integer>, Tuple2<String, Integer>>() {
                    @Override
                    public Tuple2<String, Integer> map
最后修改于:2024年09月05日 09:20

评论已关闭

推荐阅读

DDPG 模型解析,附Pytorch完整代码
2024年11月24日
DQN 模型解析,附Pytorch完整代码
2024年11月24日
AIGC实战——Transformer模型
2024年12月01日
Socket TCP 和 UDP 编程基础(Python)
2024年11月30日
python , tcp , udp
如何使用 ChatGPT 进行学术润色?你需要这些指令
2024年12月01日
AI
最新 Python 调用 OpenAi 详细教程实现问答、图像合成、图像理解、语音合成、语音识别(详细教程)
2024年11月24日
ChatGPT 和 DALL·E 2 配合生成故事绘本
2024年12月01日
omegaconf,一个超强的 Python 库!
2024年11月24日
【视觉AIGC识别】误差特征、人脸伪造检测、其他类型假图检测
2024年12月01日
[超级详细]如何在深度学习训练模型过程中使用 GPU 加速
2024年11月29日
Python 物理引擎pymunk最完整教程
2024年11月27日
MediaPipe 人体姿态与手指关键点检测教程
2024年11月27日
深入了解 Taipy:Python 打造 Web 应用的全面教程
2024年11月26日
基于Transformer的时间序列预测模型
2024年11月25日
Python在金融大数据分析中的AI应用(股价分析、量化交易)实战
2024年11月25日
AIGC Gradio系列学习教程之Components
2024年12月01日
Python3 `asyncio` — 异步 I/O,事件循环和并发工具
2024年11月30日
llama-factory SFT系列教程:大模型在自定义数据集 LoRA 训练与部署
2024年12月01日
Python 多线程和多进程用法
2024年11月24日
Python socket详解,全网最全教程
2024年11月27日