数据库重启导致 CDC 中间件无法继续受到 CDC 消息该如何处理?
資深大佬 : SachinBeyond 3
( 1 )贵公司使用的 cdc 开源框架是哪个 canal /debezium? (2)贵公司的业务场景是怎样的 ( 3 )我们公司用到的是 Debezium,目前遇到几个问题,其中有一个问题:Debezium 提供了一个 EmbeddedEngine,这个 Engine 的工作流程可以大致简单描述未
run (){
step1:Engine 内部会 启动一个线程 A,连接 mysql 数据库 读取 binlog 日志,将读取到的数据放置到某一个队列中 step2: while(xxxx){ data=queue.take(); //交给项目的业务类处理 }
}
问题:重启了 mysql 服务器之后,线程 A 抛出了异常导致 无法继续从 mysql 服务器读取 binlog 日志。 然后这个时候 Engine 感知不到,就会一直阻塞在 take 处。
然后我们的业务代码就收不到 CDC 消息了,这个该如何处理?
大佬有話說 (3)