简体   繁体   English

Flink 在使用表 API 时触发检查点失败

[英]Flink failed to trigger checkpoint when using table API

My flink streaming application (v1.14.4) contain JDBC connector used for initial fetch data from MySQL server Logic:我的 flink 流应用程序 (v1.14.4) 包含 JDBC 连接器,用于从 MySQL 服务器逻辑初始获取数据:

  1. JDBC table source -> select.where() -> convert to datastream JDBC 表源 -> select.where() -> 转换为数据流
  2. Kafka datastream join jdbc table -> further computation Kafka datastream加入jdbc表->进一步计算

When I run the application locally I can see following exception当我在本地运行应用程序时,我可以看到以下异常

14:52:00.401 [Source: TableSourceScan(table=[[default_catalog, default_database, asset, project=[id, status]]], fields=[id, status]) -> Calc(select=[CAST(_UTF-16LE'sergey-test-asset-id':VARCHAR(2147483647) CHARACTER SET "UTF-16LE") AS id, status], where=[(id = _UTF-16LE'sergey-test-asset-id')]) -> TableToDataSteam(type=ROW<`id` STRING, `status` STRING> NOT NULL, rowtime=false) -> Sink: Print to Std. Out (4/4)#0] INFO  o.a.flink.runtime.taskmanager.Task - Source: TableSourceScan(table=[[default_catalog, default_database, asset, project=[id, status]]], fields=[id, status]) -> Calc(select=[CAST(_UTF-16LE'sergey-test-asset-id':VARCHAR(2147483647) CHARACTER SET "UTF-16LE") AS id, status], where=[(id = _UTF-16LE'sergey-test-asset-id')]) -> TableToDataSteam(type=ROW<`id` STRING, `status` STRING> NOT NULL, rowtime=false) -> Sink: Print to Std. Out (4/4)#0 (e8870cf296ac770346384fe2529b325f) switched from RUNNING to FINISHED.
...

14:57:52.963 [Checkpoint Timer] INFO  o.a.f.r.c.CheckpointCoordinator - Failed to trigger checkpoint for job 8303c423dd7b9e3f303f0b299d7d37bb because Some tasks of the job have already finished and checkpointing with finished tasks is not enabled. Failure reason: Not all required tasks are currently running.

I do understand that after SQL select statement flink mark jdbc operator to FINISHED state, but I need to continue run the streaming application and have checkpoints during runtime我明白在 SQL select 语句 flink 标记 jdbc 操作符到 FINISHED state 之后,但我需要继续运行流应用程序并在运行时有检查点

Do I need to use execution.checkpointing.checkpoints-after-tasks-finish.enabled: true property to fix my issue OR do I need to change my application graph?我是否需要使用execution.checkpointing.checkpoints-after-tasks-finish.enabled: true属性来解决我的问题,或者我是否需要更改我的应用程序图?

Yes, you need to use是的,你需要使用

execution.checkpointing.checkpoints-after-tasks-finish.enabled: true

so that the job can checkpoint despite the fact that the jdbc source tasks have completed.这样尽管 jdbc 源任务已经完成,作业仍可以检查点。

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM