-
Bug
-
Resolution: Duplicate
-
Major
-
None
-
1.5.0.Final, 1.6.0.Alpha1
-
None
-
False
-
False
-
Undefined
-
When a DELETE operation is mined as
delete from \"DBO\".\"CHANNELS\" where ROWID = 'AAA0DUABEAAHxMoAAH'
will lead to
{"exception":"org.apache.kafka.connect.errors.DataException: Invalid value: null used for required field: \"CHANNELID\", schema type: INT32\n\tat org.apache.kafka.connect.data.ConnectSchema.validateValue(ConnectSchema.java:220)\n\tat org.apache.kafka.connect.data.Struct.validate(Struct.java:233)\n\tat org.apache.kafka.connect.data.ConnectSchema.validateValue(ConnectSchema.java:253)\n\tat org.apache.kafka.connect.data.Struct.put(Struct.java:216)\n\tat org.apache.kafka.connect.data.Struct.put(Struct.java:203)\n\tat io.debezium.data.Envelope.delete(Envelope.java:341)\n\tat io.debezium.relational.RelationalChangeRecordEmitter.emitDeleteRecord(RelationalChangeRecordEmitter.java:140)\n\tat io.debezium.relational.RelationalChangeRecordEmitter.emitChangeRecords(RelationalChangeRecordEmitter.java:54)\n\tat io.debezium.pipeline.EventDispatcher.dispatchDataChangeEvent(EventDispatcher.java:202)\n\t... 12 common frames omitted\nWrapped by: org.apache.kafka.connect.errors.ConnectException: Error while processing event at offset {commit_scn=26432350098, transaction_id=null, scn=26432406569}\n\tat io.debezium.pipeline.EventDispatcher.dispatchDataChangeEvent(EventDispatcher.java:232)\n\tat io.debezium.connector.oracle.logminer.LogMinerQueryResultProcessor.lambda$processResult$0(LogMinerQueryResultProcessor.java:230)\n\tat io.debezium.connector.oracle.logminer.TransactionalBuffer.commit(TransactionalBuffer.java:154)\n\t... 10 common frames omitted\nWrapped by: org.apache.kafka.connect.errors.ConnectException: An exception occurred in the change event producer. This connector will be stopped.\n\tat io.debezium.pipeline.ErrorHandler.setProducerThrowable(ErrorHandler.java:42)\n\tat io.debezium.connector.oracle.logminer.TransactionalBuffer.commit(TransactionalBuffer.java:168)\n\tat io.debezium.connector.oracle.logminer.TransactionalBuffer.commit(TransactionalBuffer.java:141)\n\tat io.debezium.connector.oracle.logminer.LogMinerQueryResultProcessor.processResult(LogMinerQueryResultProcessor.java:145)\n\tat io.debezium.connector.oracle.logminer.LogMinerStreamingChangeEventSource.execute(LogMinerStreamingChangeEventSource.java:187)\n\tat io.debezium.pipeline.ChangeEventSourceCoordinator.streamEvents(ChangeEventSourceCoordinator.java:140)\n\tat io.debezium.pipeline.ChangeEventSourceCoordinator.lambda$start$0(ChangeEventSourceCoordinator.java:113)\n\tat java.base/java.util.concurrent.Executors$RunnableAdapter.call(Executors.java:515)\n\tat java.base/java.util.concurrent.FutureTask.run(FutureTask.java:264)\n\tat java.base/java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1128)\n\tat java.base/java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:628)\n\tat java.base/java.lang.Thread.run(Thread.java:834)\n","level":"ERROR","logger":"io.debezium.embedded.EmbeddedEngine","thread":"pool-19-thread-1","message":"Error while trying to run connector class 'io.debezium.connector.oracle.OracleConnector'","mdc":{"DEBEZIUM_PRODUCT_KEY":"core-bt-dev-bt-alpha-1"},"timestamp":"2021-05-18T20:17:36.529Z"} Tue May 18 20:17:36 2021 datalake-debezium-service datalake-debezium-service alpha alpha 10-64-17-36 cvt_alpha ERROR 1 io.debezium.embedded.EmbeddedEngine io.debezium.embedded.EmbeddedEngine /services/cvt/alpha/alpha/datalake-debezium-service/logs/json/datalake-debezium.0ecdd3da1bed.log json mg01-spkidx-102.core.cvent.org
This is because the connector isn't able to resolve any before state and therefore the event is emitted without specifying any values, including the primary key. The connector already logs a warning about this use case but we likely might want to avoid emitting an event for this use case so that the validation that failed isn't triggered since we have no state to provide.
See https://gitter.im/debezium/user?at=60a42323233397424dce812e
- duplicates
-
DBZ-3322 Oracle connector does not correctly handle partially committed transactions
- Closed