起因: 本人修改了meta.dat 文件的position,想让canal跳过中间的binlog,直接从最新位置开始同步,改完之后重启canal,接收到的新数据全都报错了
问题原因: canal接收到的event解析后有59个字段,但是本地缓存的表结构只有57个字段,导致校验不通过。
但是我已经改了position,从最新的数据开始同步,怎么会有字段不一致的情况
解决问题: 把meta.dat 的 timestamp 时间戳也改成最新时间即可。
canal启动的时候,会根据timestamp时间戳,从数据库快照加载表结构。也就是说,历史表结构是57个字段,我们后面加了2个字段,导致表结构跟读到的数据不匹配。只要把timestamp改成最新时间,让canal加载最新的表结构就行了。