情况描述

使用canal1.1.7配合rocketMQ4.9.4使用来实现mysql数据同步,启动canal时一直闪退,查log日志发现报错信息如下:

2024-01-20 15:53:02.359 [main] ERROR com.alibaba.otter.canal.deployer.CanalLauncher - ## Something goes wrong when starting up the canal Server:
java.lang.IllegalStateException: Extension instance(name: rocketmq, class: interface com.alibaba.otter.canal.connector.core.spi.CanalMQProducer)  could not be instantiated: class could not be found
	at com.alibaba.otter.canal.connector.core.spi.ExtensionLoader.createExtension(ExtensionLoader.java:169)
	at com.alibaba.otter.canal.connector.core.spi.ExtensionLoader.getExtension(ExtensionLoader.java:121)
	at com.alibaba.otter.canal.deployer.CanalStarter.start(CanalStarter.java:69)
	at com.alibaba.otter.canal.deployer.CanalLauncher.main(CanalLauncher.java:124)

解决方法

从log来看判断是CanalMQProducer这个类无法实例化,于是开始检查canal中关于rocketMQ的设置,最后发现原来是需要把plugin文件夹中的jar包拷到lib文件夹下,问题解决。

好无语的bug

GitHub 加速计划 / ca / canal
25
8
下载
alibaba/canal: Canal 是由阿里巴巴开源的分布式数据库同步系统,主要用于实现MySQL数据库的日志解析和实时增量数据订阅与消费,广泛应用于数据库变更消息的捕获、数据迁移、缓存更新等场景。
最近提交(Master分支:4 个月前 )
923675aa - 5 天前
ebb54100 - 5 天前
Logo

旨在为数千万中国开发者提供一个无缝且高效的云端环境,以支持学习、使用和贡献开源项目。

更多推荐