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

flink keyed window 会因为下游BackPressure 导致数据被扔掉吗

flink keyed window 会因为下游BackPressure 导致数据被扔掉吗,window late,最近发现一个sideOutputLateData不规律的收到了一些数据

展开
收起
游客6vdkhpqtie2h2 2022-09-21 11:17:07 684 0
12 条回答
写回答
取消 提交回答
  • 公众号:网络技术联盟站,InfoQ签约作者,阿里云社区签约作者,华为云 云享专家,BOSS直聘 创作王者,腾讯课堂创作领航员,博客+论坛:https://www.wljslmz.cn,工程师导航:https://www.wljslmz.com

    在阿里云实时计算 Flink中,如果下游BackPressure 严重,可能会导致窗口数据被丢弃。因为当下游处理能力无法消耗窗口中的数据时,Flink会将窗口中未被消耗的数据暂存在状态后端中,等待下游处理能力恢复后再次提交数据。如果下游处理能力一直无法恢复,那么可能会导致这部分暂存在状态后端中的数据被删除。这种情况下,可能需要调整下游处理能力或者增加更多的资源来提高处理能力。

    另外,在使用Flink的Keyed Window时,如果窗口延迟数据被丢弃,可以通过使用Side Output Late Data来获取这些延迟数据。Side Output Late Data是Flink窗口处理中提供的一种机制,可以在窗口关闭时,将延迟数据输出到一个新的输出流中,从而避免数据被丢弃。如果您发现使用Side Output Late Data接收到的数据不规律,请检查您的代码是否正确实现了Side Output Late Data机制,并且是否有其他可以影响数据输出的因素。

    2023-05-05 20:40:21
    赞同 展开评论 打赏
  • 如果下游的操作出现 BackPressure(后压)问题,可能会导致窗口延迟数据丢失。这是由于窗口延迟数据在存储时需要占用一定的系统资源,如果下游操作的速度无法跟上窗口延迟数据的产生速度,就可能会出现数据被丢弃的情况。另外一种可能的情况是,如果网络延迟等原因导致 Late Data 到达时已经超过了允许的延迟时间,那么这些 Late Data 也会被丢弃。建议您检查下游操作的并行度和资源配置是否合理,可以考虑适当增加资源或增加下游操作的并行度。同时,调整窗口的允许延迟时间,确保不会因为 Late Data 过多而导致丢失数据。如果问题仍然存在,可以采用 Flink 提供的 SideOutputStream 机制将延迟数据路由到另外的 Output 方便后续处理。此外,可以通过监控 Flink 的 BackPressure 指标来排查下游操作是否存在 BackPressure 问题。

    2023-05-05 18:23:02
    赞同 展开评论 打赏
  • flink keyed window在计算过程中,如果下游算子BackPressure严重,可能会导致某些数据被丢弃或部分数据延迟提交。窗口延迟数据(window late data)一般是指在窗口关闭后到提交数据之间的那段时间内的数据。这段时间即为允许窗口延迟的时间(allowed lateness)。如果窗口延迟时间内下游的算子处理能力不足,可能会导致窗口内的某些延迟数据被丢弃,这取决于窗口的触发机制和最终的Side Output操作。

    因此,为了避免数据丢失或被延迟过久而造成的计算偏差,可以尝试以下一些方案:

    1、调整窗口规则和参数。根据实际场景,调整窗口的大小、滑动速率和allowed lateness等参数,以提高窗口执行效率和保证窗口正确触发,尽量避免窗口延迟数据的产生。

    2、调整算子组件的并行度和资源分配。如果下游算子的Back Pressure导致数据丢失,可以适当增加其所需的资源数,如内存、CPU、网络带宽等,也可以再增加下游算子的并行度,提升整个算子组件的处理能力。

    3、增加Side Output操作。Flink提供了Side Output机制来处理延迟数据,可以将窗口延迟数据分流到另一个Output中单独处理,以避免影响主流程的执行和计算结果。可以通过使用Flink提供的侧输出(Side Output)机制来处理延迟数据,这样可以使得算子不会因为Side Output操作而被阻塞,做到异步的处理。

    在实际开发和部署过程中,需要根据不同的应用场景,选择合适的处理策略,以确保计算的正确性和数据的可靠性。

    2023-05-03 08:05:07
    赞同 展开评论 打赏
  • 在Flink中,当一个窗口被触发时,所有的关联窗口数据都会被处理,无论下游是否存在背压问题。如果下游存在背压问题,则处理过程可能会放慢,但窗口中的数据不会被丢弃。当下游消费者再次变得可用时,Flink会继续处理被保留的数据并将其发送给下游。因此,Flink的窗口处理不会因为下游背压而丢失数据。

    2023-04-28 20:03:28
    赞同 展开评论 打赏
  • 值得去的地方都没有捷径

    通常情况下,Flink的keyed window会因为下游BackPressure而导致数据被扔掉,这可能会导致window late。但是,当Flink的下游无法跟上window的处理速度时,Flink会向上游发送BackPressure信号,以减慢或停止数据的发送。如果Flink无法根据BackPressure信号适当减缓window的数据发送速度,则会导致数据被丢弃。

    针对这种情况,建议考虑以下解决方案:

    改进操作:优化window操作,提高处理速度,减少延迟。 提高下游处理速度:可以使用Flink的backpressure机制对下游进行管控,以确保下游可以跟上window的速度。 调整窗口大小:如果看到窗口数据被扔掉的情况,可以考虑调整窗口大小,以使窗口不会过大而导致资源浪费和数据丢失,也不会太小而导致数据延迟。 另外,针对窗口处理的延迟,可以使用Flink的侧输出流功能,将延迟的数据发送到侧输出流中,以便后续处理或持久化。可以通过在window操作的参数中设置allowedLateness,来允许late数据的进一步处理。同时也可以使用触发器(trigger)来触发window操作,以提高延迟数据的处理速度。

    2023-04-26 12:49:27
    赞同 展开评论 打赏
  • 天下风云出我辈,一入江湖岁月催,皇图霸业谈笑中,不胜人生一场醉。

    在 Flink 中,Keyed Window 是在 KeyedStream 上进行的窗口操作,它们允许在流中为每个 Key 定义不同的窗口。当执行 Keyed Window 操作时,会将具有相同 Key 值的元素分组并放入同一个窗口中,然后对窗口中的元素进行聚合运算。

    如果下游 BackPressure 严重导致数据消费速度无法跟上数据生产速度,则 Flink 中的窗口机制可能会出现缓存区溢出、超时等问题。一旦缓存区满了,新的数据就不能被写入,这会导致数据被丢弃或者窗口操作被中断,这可能会影响 Keyed Window 的结果。

    但是,Flink 实现了基于反压的流控制机制,即使用了BackPressure,可以通过调整配置参数,如bufferTimeout来解决 BackPressure 问题。例如,可以设置 bufferTimeout 参数来控制在数据产生速度超过数据消费速度时,缓存区中数据的最大保留时间。如果数据过期仍未被消费,则会从缓存区中删除。

    2023-04-26 10:48:57
    赞同 展开评论 打赏
  • 十分耕耘,一定会有一分收获!

    楼主你好,造成这个情况的原因就是上下游处理速度不一致造成的,可以通过设置ExecutionConfig中的autoWatermarkInterval属性来调整Flink窗口操作的缓冲区大小解决上述问题。

    2023-04-24 23:15:46
    赞同 展开评论 打赏
  • Flink Keyed Window 在下游 BackPressure 导致数据被扔掉的情况下是可能发生的。当下游的处理任务处理速度跟不上上游数据的产生速度时,下游就会出现 BackPressure,这时上游的数据就会积压在缓存区中,如果窗口过期时间已到,但是数据还没有被处理完,那么就会产生 Window Late Data,这些数据会被发送到 SideOutput 中,如果 SideOutput 的处理任务也处于 BackPressure 状态,那么就有可能会出现数据被扔掉的情况。因此,针对这种情况,建议采取一些措施,如增大窗口大小、调整下游处理任务的并行度、增加下游任务的资源等,以提高数据的处理能力和稳定性。同时,可以开启 Flink 的 BackPressure 监控功能,及时发现和解决 BackPressure 问题。

    2023-04-24 18:20:24
    赞同 展开评论 打赏
  • 全栈JAVA领域创作者

    是的,如果下游处理器无法及时处理窗口中的数据,会导致数据被丢弃。当窗口触发时,Flink会将窗口内的所有数据发送给下游处理器进行处理。如果下游处理器无法跟上生产者的速度,就会导致生产者产生Back Pressure,最终可能会丢失部分数据。为了解决这个问题,可以考虑调整窗口大小或调整下游处理器的吞吐量,或者使用Flink的水位线机制来控制事件时间窗口的结束时间,确保下游处理器有足够的时间来处理窗口内的数据。另外,可以考虑使用侧输出流(Side Output)来捕捉窗口内未被及时处理的数据。

    2023-04-23 23:27:47
    赞同 展开评论 打赏
  • 热爱开发

    在阿里云Flink中,如果下游的处理速度跟不上上游的生产速度,可能会导致BackPressure. 如果您使用的是keyed window操作,那么在发生BackPressure时,Flink会根据配置中的backpressure behavior来处理窗口中的数据。默认情况下,当BackPressure发生时,Flink将保留所有窗口元素,并等待下游恢复正常处理速度。但是,如果您希望及时释放资源并避免OOM等问题,可以通过设置ExecutionConfig中的autoWatermarkInterval属性来调整Flink窗口操作的缓冲区大小。这样,即使发生BackPressure,也可以尽快地释放资源并避免数据丢失。

    2023-04-23 17:41:53
    赞同 展开评论 打赏
  • 存在即是合理

    Flink 的 Keyed Window 操作会在窗口关闭之后触发计算,然后将计算结果发送到下游算子进行处理。如果下游算子出现 BackPressure,也就是处理速度跟不上数据输入速度,那么就会导致数据被丢弃。

    在 Flink 中,如果窗口关闭时还有一些延迟到达的数据,这些数据会被认为是迟到数据(Late Data),可以使用 window 的 sideOutputLateData 方法将这些迟到的数据发送到另一个流中进行处理。但是,如果由于下游算子 BackPressure 等原因导致数据被丢弃,那么这些数据就无法发送到 side output 流中。

    因此,如果您发现 sideOutputLateData 收到的数据不规律,可能是由于下游算子 BackPressure 导致数据被丢弃。为了避免数据丢失,可以考虑使用更高效的算子或增加下游算子的并行度,以提高处理速度。另外,也可以考虑调整窗口的大小、间隔和允许的延迟时间等参数,以更好地适应数据处理需求。

    2023-04-23 17:09:17
    赞同 展开评论 打赏
  • Flink keyed window 在处理数据时会根据键(key)将数据分组,将每个键对应的数据分配到不同的窗口进行处理。在窗口的触发时刻,Flink 会将各窗口中的数据交给下游算子进行处理。而如果下游算子的处理能力不足,没有及时处理完所有数据,那么就有可能会导致数据丢失。

    具体来说,如果下游算子的 backpressure 非常大,导致数据积压,而窗口触发的频率很高,那么有些窗口可能会触发了但是没有及时处理完,这时窗口中的部分数据就会成为延迟数据,即 late data。如果过多的数据被认为是延迟数据,则有可能会导致在一定时间后数据被丢弃,这样就会影响程序的正确性。

    2023-04-23 17:09:14
    赞同 展开评论 打赏
滑动查看更多

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

相关产品

  • 实时计算 Flink版
  • 相关电子书

    更多
    Flink CDC Meetup PPT - 覃立辉 立即下载
    Flink CDC Meetup PPT - 孙家宝 立即下载
    Flink CDC Meetup PPT - 徐榜江 立即下载