美文网首页数据库同步
【Canal源码分析】TableMetaTSDB

【Canal源码分析】TableMetaTSDB

作者: 端木轩 | 来源:发表于2018-05-31 13:48 被阅读163次

    这是Canal在新版本引入的一个内容,主要是为了解决由于历史的DDL导致表结构与现有表结构不一致,导致的同步失败的问题。采用的是Druid和Fastsql,来记录表结构到DB中,如果需要进行回滚时,得从DB中根据时间点去查到对应的库表结构,然后进行业务的处理。也就是,如果我们想要这样的效果,需要开启TSDB的功能,同时要新增库表来记录表结构的变更。

    这个基本上是在parser启动时,寻找位点时需要的。当然在系统启动的时候,会将库表的信息写入到DB中,然后定时24小时写入一次。另外就是在发生了DDL时,会更新表结构。

    我们来看下他的类图。

    TSDB.png

    一张表记录的是表结构,加上了时间,另一张记录的是当时的DDL语句。在进行回溯的时候,直接根据时间戳和binlog文件名来进行寻找即可找到。当然这些数据也会在内存中保存一份,加快速度。

    具体的介绍可以见这个链接https://github.com/alibaba/canal/wiki/TableMetaTSDB

    相关文章

      网友评论

        本文标题:【Canal源码分析】TableMetaTSDB

        本文链接:https://www.haomeiwen.com/subject/hnsqsftx.html