前言
我们在IDE中编写Flink代码,我们希望在IEDA中运行程序便能够查看到Web-UI,从而快速的了解Flink程序的运行情况(而无需自己手动安装Flink,以及打包提交任务)
一、添加依赖
本示例是基于Flink1.12 进行演示的
<dependency>
<groupId>org.apache.flink</groupId>
<artifactId>flink-runtime-web_2.12</artifactId>
<version>1.12.2</version>
<scope>compile</scope>
</dependency>
二、代码中启用本地WEB-UI
Configuration configuration = new Configuration();
configuration.setInteger(RestOptions.PORT, 8082);
StreamExecutionEnvironment env = StreamExecutionEnvironment.getExecutionEnvironment(configuration);
完整示例
data:image/s3,"s3://crabby-images/e4488/e44886116c06b32ed9daeab3ee13c10bb584086c" alt="image-20210714082532795"
三、IDEA运行Flink JOB;本地WEB-UI查看
我们于浏览器中输入localhost:8082 便会看到如下情况的 Flink-WEB-UI
查看
data:image/s3,"s3://crabby-images/445fc/445fce06e6abfb23727407d65a1f8abd0a44b53e" alt="image-20210714082758564"
Task详情
data:image/s3,"s3://crabby-images/db970/db970ff0d71472afc37df9c60331a3f4b7921a4f" alt="image-20210714083453739"
Task详情解释
自定义source 是implements SourceFunction 其并行度只能为1
Window 、Apply 、Sink并行度均为4
keyBy算子将DataStream转换成一个KeyedStream;通过countWindow,最终变为 WindowedStream
最终形成两个算子,一个算子并行度为1,一个算子并行度为4,总共5个subTask
data:image/s3,"s3://crabby-images/deaf2/deaf22befef1f5a16f52844a80e50bf2cd46da1b" alt="image-20210714083757519"
注意点:
- 当前flink-web-ui 仅是当前主类(main 类/flink -job)有关,其余主类如需使用,必须重复上边代码操作
- 这种模式TaskManger有且只会有一个,总taskSlot根据代码中的并行度动态增加,例如我现在代码中并行度为4则WEB-UI中会显示total Task Slot4,不设置就会默认使用当前机构cpu核心数数量的并行度
- ex:不设置并行度 (显示total Task Slot8)
data:image/s3,"s3://crabby-images/6308c/6308cbd48cef43f7186a0ad7e17f58c020b209fa" alt="image-20210714084417005"
|