Kafka connect: 使用JDBC connector同步无主键的表时,如何处理无法执行delete操作的问题?

环境:
kafka 2.8.0
debezium 1.9.0

我们主要实现使用debezium采集oracle的数据,将数据通过jdbc connector写到mysql,但是由于有一些oracle数据表没有主键,导致使用jdbc connector sink的时候不能正常地执行delete操作, 原因如下:

debezium采集数据发送到kafka, kafka的消息体的key默认是所采集的表的主键,如果表没有主键,则消息体的key为空。
由于源表有delete的操作,我们为了保持两边数据同步,使用jdbc connector sink的时候,需要设置"delete.enabled": "true", 但是这个设置要求"pk.mode": "record_key", 又因为没有主键,消息体中key为空,设置不了"pk.mode": "record_key",所以我们只能从源头出发,在source上处理对应的key。

具体操作如下:

Source端配置:

{
 
    "name": "oracle-source-connector",
    "config": {
        "connector.class" : "io.debezium.connector.oracle.OracleConnector",
        "tasks.max" : "1",
        "database.server.name" : "ORCL",
        "tasks.max" : "1",
	    "database.server.name" : "orcl_server",
	    "database.hostname" : "oracl_地址",
	    "database.port" : "1521",
	    "database.user" : "user_name",
	    "database.password" : "passwd",
	    "database.dbname" : "db名称",
        "table.include.list": "DB2.STUDENT",
        "message.key.columns": "DB2.STUDENT:SNAME",
        "database.history.kafka.bootstrap.servers" : "kafka:9092",
        "database.history.kafka.topic": "schema-changes.source",
        "event.processing.failure.handling.mode": "skip",
        "log.mining.strategy": "online_catalog",
        "database.history.skip.unparseable.ddl": "true",
        "database.history.store.only.captured.tables.ddl": "true",
        "time.precision.mode" : "connect",
     	"database.serverTimezone":"UTC+8",
     	"decimal.handling.mode": "string"
    }
}

主要配置:
"message.key.columns": "DB2.STUDENT:SNAME", 无主键的表 设置指定主键 可以指定多个列,也可以设置多个表 如:inventory.customers:pk1,pk2;(.*).purchaseorders:pk3,pk4

sink端配置

{
    "name":"oracle-sink-connector",
    "config":{
        "topics": "orcl_server.DB2.STUDENT",
        "connector.class": "io.confluent.connect.jdbc.JdbcSinkConnector",
        "connection.url": "jdbc:mysql://localhost:3306/orcl_source",
        "connection.user": "user_name",
        "connection.password": "pass_wd",
        "tasks.max": "1",
        "auto.create": "true",
        "auto.evolve": "true",
        "insert.mode":"upsert",
        "delete.enabled": "true",
        "batch.size": "3000",
        "pk.mode": "record_key",
        "transforms":"ExtractField,repTopic",
   "transforms.ExtractField.type":"org.apache.kafka.connect.transforms.ExtractField$Value",
        "transforms.ExtractField.field":"after",
        "transforms.repTopic.type":"org.apache.kafka.connect.transforms.RegexRouter",
        "transforms.repTopic.regex":"(.*).(DB2.(.*))",
        "transforms.repTopic.replacement":"$2"
  }
}

总结

自此,就可以完成对应的操作了,好的,就到这里,希望对你有所帮助,希望感兴趣的小伙伴能够点个关注,一起交流学习~

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

雾岛与鲸

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

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

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

打赏作者

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

抵扣说明:

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

余额充值