canal配置tsdb,支持表结构修改

instance.properties的配置:

#################################################
## mysql serverId , v1.0.26+ will autoGen
# canal.instance.mysql.slaveId=0

# enable gtid use true/false
canal.instance.gtidon=false

# position info
canal.instance.master.address=127.0.0.1:3306
canal.instance.master.journal.name=
canal.instance.master.position=
canal.instance.master.timestamp=
canal.instance.master.gtid=

# rds oss binlog
canal.instance.rds.accesskey=
canal.instance.rds.secretkey=
canal.instance.rds.instanceId=

# table meta tsdb info
canal.instance.tsdb.enable=true
canal.instance.tsdb.dbUsername=zzy
canal.instance.tsdb.dbPassword=123456
#canal.instance.tsdb.dir = ${canal.file.data.dir:../conf}/${canal.instance.destination:}
canal.instance.tsdb.url = jdbc:mysql://127.0.0.1:3306/canal_tsdb

canal.instance.tsdb.spring.xml = classpath:spring/tsdb/mysql-tsdb.xml



#canal.instance.standby.address =
#canal.instance.standby.journal.name =
#canal.instance.standby.position =
#canal.instance.standby.timestamp =
#canal.instance.standby.gtid=

# username/password
canal.instance.dbUsername=zzy
canal.instance.dbPassword=123456
canal.instance.connectionCharset = UTF-8
# enable druid Decrypt database password
canal.instance.enableDruid=false
#canal.instance.pwdPublicKey=MFwwDQYJKoZIhvcNAQEBBQADSwAwSAJBALK4BUxdDltRRE5/zXpVEVPUgunvscYFtEip3pmLlhrWpacX7y7GCMo2/JM6LeHmiiNdH1FWgGCpUfircSwlWKUCAwEAAQ==

# table regex
canal.instance.filter.regex=.*\\..*
# table black regex
canal.instance.filter.black.regex=mysql\\.slave_.*
# table field filter(format: schema1.tableName1:field1/field2,schema2.tableName2:field1/field2)
#canal.instance.filter.field=test1.t_product:id/subject/keywords,test2.t_company:id/name/contact/ch
# table field black filter(format: schema1.tableName1:field1/field2,schema2.tableName2:field1/field2)
#canal.instance.filter.black.field=test1.t_product:subject/product_image,test2.t_company:id/name/contact/ch

# mq config
canal.mq.topic=example
# dynamic topic route by schema or table regex
#canal.mq.dynamicTopic=mytest1.user,mytest2\\..*,.*\\..*
canal.mq.partition=0
# hash partition config
#canal.mq.partitionsNum=3
#canal.mq.partitionHash=test.table:id^name,.*\\..*
#canal.mq.dynamicTopicPartitionNum=test.*:4,mycanal:6
#################################################

canal.instance.master.address=127.0.0.1:3306
canal.instance.dbUsername=zzy
canal.instance.dbPassword=123456
canal.instance.connectionCharset = UTF-8
这几项 canal.instance.**的配置表示需要订阅binlog的mysql的地址及用户。

canal.instance.tsdb.enable=true
canal.instance.tsdb.dbUsername=zzy
canal.instance.tsdb.dbPassword=123456
canal.instance.tsdb.url = jdbc:mysql://127.0.0.1:3306/canal_tsdb
canal.instance.tsdb.spring.xml = classpath:spring/tsdb/mysql-tsdb.xml
这几项canal.instance.tsdb.enable的配置表示是否打开tsdb开关,tsdb是为预防表结构发生变化从而在canal订阅binlog时产生问题。
canal使用数据库存储上一次的表结构信息,然后对比两次的表结构,可解决此错误。
canal.instance.tsdb.**的几项配置为存储表结构的数据库。
canal.instance.tsdb.spring.xml = classpath:spring/tsdb/mysql-tsdb.xml
不可或缺,因为tsdb默认使用的是h2数据库(java内置数据库)。部增加此配置默认还是使用内置数据库,
需要使用内置数据库的这里就不再赘述。

tsdb数据库表:
meta_history
meta_snapshot
若canal宕机后很久没启动,建议删除conf/example/meta.data
然后使用tsdb数据库的话,清空这两个表,重启canal即可

你可能感兴趣的:(数据库,mysql,数据库,java)