写点什么

大数据培训 Flink 高频面试题

作者:@零度
  • 2022 年 6 月 09 日
  • 本文字数:1696 字

    阅读完需:约 6 分钟

1、Flink 怎么做压力测试和监控?

参考答案:我们一般碰到的压力来自以下几个方面:

(1)产生数据流的速度如果过快,而下游的算子消费不过来的话,会产生背压。背压的监控可以使用 FlinkWebUI(localhost:8081)来可视化监控,一旦报警就能知道。一般情况下背压问题的产生可能是由于 sink 这个操作符没有优化好,做一下优化就可以了。比如如果写入 ElasticSearch,那么可以改成批量写入,可以调大 ElasticSearch 队列的大小等等策略。

(2)设置 watermark 的最大延迟时间这个参数,如果设置的过大,可能会造成内存的压力。可以设置最大延迟时间小一些,然后把迟到元素发送到侧输出流中去。晚一点更新结果。或者使用类似于 RocksDB 这样的状态后端,RocksDB 会开辟堆外存储空间,但 IO 速度会变慢,需要权衡。

(3)还有就是滑动窗口的长度如果过长,而滑动距离很短的话,Flink 的性能会下降的很厉害。我们主要通过时间分片的方法,将每个元素只存入一个“重叠窗口”,这样就可以减少窗口处理中状态的写入。



2、你是怎么合理的评估 Flink 任务的并行度?

参考答案:Flink 任务并行度合理行一般根据峰值流量进行压测评估,并且根据集群负载情况留一定量的 buffer 资源。

1.如果数据源已经存在,则可以直接消费进行测试

2.如果数据源不存在,需要自行造压测数据进行测试_大数据培训

对于一个 Flink 任务来说,一般可以按照以下方式进行细粒度设置并行度:

1.source 并行度配置:以 kafka 为例,source 的并行度一般设置为 kafka 对应的 topic 的分区数

2.transform(比如 flatmap、map、filter 等算子)并行度的配置:这些算子一般不会做太重的操作,并行度可以和 source 保持一致,使得算子之间可以做到 forward 传输数据,不经过网络传输

3.keyby 之后的处理算子:建议最大并行度为此算子并行度的整数倍,这样可以使每个算子上的 keyGroup 是相同的,从而使得数据相对均匀 shuffle 到下游算子,如下图为 shuffle 策略



4.sink 并行度的配置:sink 是数据流向下游的地方,可以根据 sink 的数据量及下游的服务抗压能力进行评估。如果 sink 是 kafka,可以设为 kafka 对应 topic 的分区数。注意 sink 并行度最好和 kafkapartition 成倍数关系,否则可能会出现如到 kafkapartition 数据不均匀的情况。但是大多数情况下 sink 算子并行度不需要特别设置,只需要和整个任务的并行度相同就行。

3、Flink 是如何保证 Exactly-once 语义的?

参考答案:Flink 通过实现两阶段提交和状态保存来实现端到端的一致性语义。分为以下几个步骤:

  • 开始事务(beginTransaction):创建一个临时文件夹,来写把数据写入到这个文件夹里面

  • 预提交(preCommit):将内存中缓存的数据写入文件并关闭

  • 正式提交(commit):将之前写完的临时文件放入目标目录下。这代表着最终的数据会有一些延迟

  • 丢弃(abort):丢弃临时文件

若失败发生在预提交成功后,正式提交前。可以根据状态来提交预提交的数据,也可删除预提交的数据_大数据视频

4、Flink 对于迟到数据是怎么处理的

参考答案:Flink 中 WaterMark 和 Window 机制解决了流式数据的乱序问题,对于因为延迟而顺序有误的数据,可以根据 eventTime 进行业务处理,对于延迟的数据 Flink 也有自己的解决办法,主要的办法是给定一个允许延迟的时间,在该时间范围内仍可以接受处理延迟数据:

  • 设置允许延迟的时间是通过 allowedLateness(lateness:Time)设置

  • 保存延迟数据则是通过 sideOutputLateData(outputTag:OutputTag[T])保存

  • 获取延迟数据是通过 DataStream.getSideOutput(tag:OutputTag[X])获取

5、Flink 的重启策略了解吗?

参考答案:Flink 支持不同的重启策略,这些重启策略控制着 job 失败后如何重启:

1、固定延迟重启策略

固定延迟重启策略会尝试一个给定的次数来重启 Job,如果超过了最大的重启次数,Job 最终将失败。在连续的两次重启尝试之间,重启策略会等待一个固定的时间。

2、失败率重启策略

失败率重启策略在 Job 失败后会重启,但是超过失败率后,Job 会最终被认定失败。在两个连续的重启尝试之间,重启策略会等待一个固定的时间。

3、无重启策略

Job 直接失败,不会尝试进行重启。

文章来源于大数据研习社


推荐阅读:

大数据开发之 Flink sql 的基础用法

大数据培训 Flink 基础知识分享

大数据培训 Flink 面试宝典

大数据培训面试 Flink 八股文分享


用户头像

@零度

关注

关注尚硅谷,轻松学IT 2021.11.23 加入

IT培训 www.atguigu.com

评论

发布
暂无评论
大数据培训Flink高频面试题_flink_@零度_InfoQ写作社区