Canal解析数据报错:column size is not match for table xxxx 59 vs 57

起因: 本人修改了meta.dat 文件的position,想让canal跳过中间的binlog,直接从最新位置开始同步,改完之后重启canal,接收到的新数据全都报错了

在这里插入图片描述

问题原因: canal接收到的event解析后有59个字段,但是本地缓存的表结构只有57个字段,导致校验不通过。

但是我已经改了position,从最新的数据开始同步,怎么会有字段不一致的情况

解决问题: 把meta.dat 的 timestamp 时间戳也改成最新时间即可。

canal启动的时候,会根据timestamp时间戳,从数据库快照加载表结构。也就是说,历史表结构是57个字段,我们后面加了2个字段,导致表结构跟读到的数据不匹配。只要把timestamp改成最新时间,让canal加载最新的表结构就行了。

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

°Fuhb

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值