Flink 整合 Nacos,动态更改作业配置!

       我们知道 Flink 作业的配置一般都是通过在作业启动的时候通过参数传递的,或者通过读取配置文件的参数,在作业启动后初始化了之后如果再想更新作业的配置一般有两种解决方法:

  1.  改变启动参数或者改变配置文件,重启作业,让作业能够读取到修改后的配置
  2.  通过读取配置流(需要自定义 Source 读取配置),然后流和流连接起来

       这两种解决方法一般是使用的比较多,对于第一种方法,其实是不太建议的,重启作业会带来很多影响,Flink 作业完整的重启流程应该是:当作业停掉的时候需要去做一次 Savepoint(相当于把作业的状态做一次完整的快照),启动的时候又需要将作业从 Savepoint 启动,整个流程如果状态比较大的话,做一次 Savepoint 和从 Savepoint 初始化的时间会比较久,然而流处理的场景下通常数据量都是比较大的,那么在这段时间内,可能会造成不少的数据堆积(可能分钟内就上千万或者更多),当作业启动后再去追这千万量级的数据,对作业来说压力自然会增大。

       对于第二种方法也是一种用的很多的方式,是比较推荐的。

 

案例一:

import com.alibaba.nacos.api.NacosFactory;
import com.alibaba.nacos.api.config.ConfigService;
import com.alibaba.nacos.api.config.listener.Listener;
import com.alibaba.nacos.api.naming.NamingFactory;
import com.alibaba.nacos.api.naming.NamingService;
import org.apache.flink.api.java.utils.ParameterTool;
import org.apache.flink.configuration.Configuration;
import org.apache.flink.streaming.api.environment.StreamExecutionEnvironment;
import org.apache.flink.streaming.api.functions.source.RichSourceFunction;
import java.util.Properties;
import java.util.concurrent.Executor;

/**
 * flink nacos 整合测试
 */
public class FlinkNacosTest {
    public static void main(String[] args) throws Exception {
        StreamExecutionEnvironment env =  StreamExecutionEnvironment.getExecutionEnvironment();
        env.getConfig().setGlobalJobParameters(ParameterTool.fromArgs(args));
        env.setParallelism(1);

        env.addSource(new RichSourceFunction<String>() {
            ConfigService configService;
            String config;
            String dataId = "cbsp-data-platform-service.yaml";
            String group = "cbsp-data-platform-service-group";

            @Override
            public void open(Configuration parameters) throws Exception {
                super.open(parameters);
                String serverAddr = "192.168.2.51";
                String namespaceId = "0b416873-252c-4792-9464-c88da4da72a2";
                Properties properties = new Properties();
                properties.put("serverAddr", serverAddr);
                properties.put("namespace", namespaceId);

                configService = NacosFactory.createConfigService(properties);
                config = configService.getConfig(dataId, group, 5000);
                configService.addListener(dataId, group, new Listener() {
                    @Override
                    public Executor getExecutor() {
                        return null;
                    }

                    @Override
                    public void receiveConfigInfo(String configInfo) {
                        config = configInfo;
                    }
                });
            }

            @Override
            public void run(SourceContext<String> ctx) throws Exception {

                while (true) {
                    Thread.sleep(3000);
                    System.out.println("run config = " + config);
                    ctx.collect(String.valueOf(System.currentTimeMillis()));
                }
            }

            @Override
            public void cancel() {

            }
        }).print();


        env.execute();
    }
}

 

案例二:

import com.alibaba.nacos.api.NacosFactory;
import com.alibaba.nacos.api.config.ConfigService;
import com.alibaba.nacos.api.config.listener.Listener;
import org.apache.flink.api.java.tuple.Tuple2;
import org.apache.flink.api.java.utils.ParameterTool;
import org.apache.flink.streaming.api.CheckpointingMode;
import org.apache.flink.streaming.api.environment.CheckpointConfig;
import org.apache.flink.streaming.api.environment.StreamExecutionEnvironment;
import org.apache.flink.streaming.api.functions.source.SourceFunction;
import java.util.Properties;
import java.util.concurrent.Executor;

/**
 * Desc: 测试 nacos 动态更改配置后,Flink 是否可以获取到更改后的值,并生效?
 *
 * 结论是:不生效,因为 Flink 是 Lazy Evaluation(延迟执行),当程序的 main 方法执行时,数据源加载数据和数据转换等算子不会立马执行,
 * 这些操作会被创建并添加到程序的执行计划中去,只有当执行环境 env 的 execute 方法被显示地触发执行时,整个程序才开始执行实际的操作,所以
 * 在一开始初始化后等程序执行 execute 方法后再修改 env 的配置其实就不起作用了。
 */
public class FlinkNacosTest2 {
    public static void main(String[] args) throws Exception {
        StreamExecutionEnvironment env = StreamExecutionEnvironment.getExecutionEnvironment();
        env.getConfig().setGlobalJobParameters(ParameterTool.fromArgs(args));
        env.setParallelism(1);

        String serverAddr = "192.168.2.51";
        String dataId = "cbsp-data-platform-service.yaml";
        String group = "cbsp-data-platform-service-group";
        String namespaceId = "0b416873-252c-4792-9464-c88da4da72a2";
        Properties properties = new Properties();
        properties.put("serverAddr", serverAddr);
        properties.put("namespace", namespaceId);
        ConfigService configService = NacosFactory.createConfigService(properties);
        final String[] content = {configService.getConfig(dataId, group, 5000)};
        configService.addListener(dataId, group, new Listener() {
            @Override
            public Executor getExecutor() {
                return null;
            }

            @Override
            public void receiveConfigInfo(String configInfo) {

                content[0] = configInfo;

            }
        });

      

        env.addSource(new SourceFunction<Tuple2<String, Long>>() {
            @Override
            public void run(SourceContext<Tuple2<String, Long>> ctx) throws Exception {
                while (true) {
                    ctx.collect(new Tuple2<>(content[0], System.currentTimeMillis()));
                    Thread.sleep(1000);
                }
            }

            @Override
            public void cancel() {

            }
        }).print();


        env.execute();
    }
}

 

 

Flink 配置 Nacos 主要用于动态管理 Flink 集群中的配置信息。Nacos 是一个更易于构建云原生应用的动态服务发现、配置管理和服务管理平台。通过将 Flink 配置信息存储在 Nacos 中,可以实现配置动态更新而无需重启集群。 以下是使用 Nacos 管理 Flink 配置的基本步骤: 1. 首先需要在 Nacos 中创建相应的配置文件,包括 Flink配置项,如任务管理器(TaskManager)的数量、资源等。 2. 在 Flink配置文件 `flink-conf.yaml` 中添加 Nacos 相关的配置项,例如 Nacos 的地址、命名空间、配置分组以及数据ID等。 3. Flink 程序启动时会读取 `flink-conf.yaml` 中的配置,并连接到 Nacos 服务器拉取配置信息。 4. 当需要更新配置时,可以直接在 Nacos 控制台中修改配置Flink 集群会实时感知到配置的变化,并自动加载新的配置。 这里是一个简化的 `flink-conf.yaml` 文件配置示例: ```yaml # Nacos 配置nacos.server-addr: 127.0.0.1:8848 nacos.namespace: f28a599b-7733-4e7f-b787-76e6c8d5d5d5 nacos.group: DEFAULT_GROUP nacos.dataId: flink-config ``` 在程序中,可以通过 Flink配置对象 `Configuration` 来访问这些配置: ```java Configuration config = new Configuration(); String nacosServerAddr = config.getString("nacos.server-addr"); String nacosNamespace = config.getString("nacos.namespace"); String nacosGroup = config.getString("nacos.group"); String nacosDataId = config.getString("nacos.dataId"); // 使用获取到的 Nacos 配置信息连接到 Nacos 服务器获取实时配置 ``` 通过以上步骤,Flink 集群的配置就可以通过 Nacos 进行动态管理了。
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值