Flink系列:setParallelism 并行度使用方法示例Demo

本文详细介绍了Apache Flink中设置并行度的方法,包括算子层面的并行度调整,深入讲解了Slots的概念及其优先级,并通过示例Demo展示了如何在实践中配置并行度。

并行度

一个任务(Source、Transformation、Sink)的并行实例(线程〉数目称为该任务的并行度

 

Slots 

Task Manager为集群提供Slots,一个Task Manager节点的Slots数通常是CPU的核数。

 

并行度优先级

一个任务的并行度设置包含下面4个层面:
• Operator Level (算子层面〉
• Execution Environment Level (执行环境层面〉

 

• Client Level (客户 层面〉
• System Level (系统层面)

 

Flink 中,Checkpoint 是一种机制,用于实现流处理的容错和恢复。Checkpoint 会将流处理任务的状态信息保存到持久化存储中,以便在出现故障时可以恢复任务并继续处理数据。而并行度和Checkpoint之间的关系是,每个并行任务都会独立地生成和管理自己的Checkpoint。 下面是一个简单的示例,展示了如何在 Flink 中设置并行度和Checkpoint: ```java // 创建 ExecutionEnvironment StreamExecutionEnvironment env = StreamExecutionEnvironment.getExecutionEnvironment(); // 设置并行度为 4 env.setParallelism(4); // 开启Checkpoint,设置Checkpoint间隔为 10 秒 env.enableCheckpointing(10000); // 设置Checkpoint模式为 Exactly Once env.getCheckpointConfig().setCheckpointingMode(CheckpointingMode.EXACTLY_ONCE); // 设置Checkpoint超时时间为 1 分钟 env.getCheckpointConfig().setCheckpointTimeout(60000); // 设置同时进行的最大Checkpoint数量为 2 env.getCheckpointConfig().setMaxConcurrentCheckpoints(2); // 设置Checkpoint存储的位置 env.setStateBackend(new FsStateBackend("file:///tmp/checkpoints")); // 定义数据源,执行计算操作 DataStream<String> input = env.socketTextStream("localhost", 9999); input.flatMap(new FlatMapFunction<String, String>() { @Override public void flatMap(String s, Collector<String> collector) throws Exception { collector.collect(s.toUpperCase()); } }).print(); // 启动任务 env.execute("Flink Checkpoint Demo"); ``` 在这个示例中,我们首先创建了一个 `StreamExecutionEnvironment` 实例,并设置了并行度为 4。接着开启了Checkpoint,并设置了Checkpoint间隔为 10 秒,Checkpoint模式为 Exactly Once,Checkpoint超时时间为 1 分钟,同时进行的最大Checkpoint数量为 2,Checkpoint存储的位置为本地文件系统 `/tmp/checkpoints`。最后定义了一个数据源,并执行计算操作。 总之,Flink 中的并行度和Checkpoint是密切相关的,每个并行任务都需要独立地生成和管理自己的Checkpoint,以保证流处理任务的容错和恢复能力。
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

NIO4444

如果对您有帮助,欢迎打赏支持!

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值