开发者社区 > 大数据与机器学习 > 实时计算 Flink > 正文

有没有大佬知道这个设置该怎么用

839问.png

展开
收起
游客3oewgrzrf6o5c 2022-07-03 18:15:28 283 0
1 条回答
写回答
取消 提交回答
  • 十分耕耘,一定会有一分收获!

    楼主你好,这段代码是阿里云的Flink程序中的一个设置。它的作用是在Flink作业执行环境中注册自定义的JobListeners,该JobListeners不能具有带有参数的构造函数。

    具体的用法是:

    1. 在Flink作业中定义一个JobListener的实现类,该实现类必须没有带有参数的构造函数。
    2. 在阿里云的Flink作业配置中设置该ConfigOption,将JobListener的类名添加到list中。
    3. 启动Flink作业时,该JobListener就会被注册到作业执行环境中,从而可以监听Flink作业的运行状态。

    例如,假设我们有一个自定义的JobListener实现类MyJobListener,它的类名为com.example.MyJobListener。那么,在阿里云的Flink作业中,我们可以这样设置:

    public static final ConfigOption<List<String>> JOB_LISTENERS = 
        ConfigOptions.key("job.listeners")
            .stringType()
            .asList()
            .noDefaultValue()
            .withDescription("Custom JobListeners to be registered with the execution environment, "
                + "The registered listeners cannot have constructors with arguments.");
    
    List<String> jobListeners = new ArrayList<>();
    jobListeners.add("com.example.MyJobListener");
    
    StreamExecutionEnvironment env = StreamExecutionEnvironment.getExecutionEnvironment();
    env.getConfig().set(JOB_LISTENERS, jobListeners);
    

    这样,启动Flink作业时,MyJobListener就会被注册到作业执行环境中,从而可以监听Flink作业的运行状态。

    2023-08-22 16:55:32
    赞同 展开评论 打赏

实时计算Flink版是阿里云提供的全托管Serverless Flink云服务,基于 Apache Flink 构建的企业级、高性能实时大数据处理系统。提供全托管版 Flink 集群和引擎,提高作业开发运维效率。

相关电子书

更多
Python第五讲——关于爬虫如何做js逆向的思路 立即下载
QQ移送页面框架优化实践 立即下载
QQ移动页面框架优化实践 立即下载