Andy Bryant created KAFKA-9390:
----------------------------------

             Summary: Non-key joining of KTable not compatible with confluent 
avro serdes
                 Key: KAFKA-9390
                 URL: https://issues.apache.org/jira/browse/KAFKA-9390
             Project: Kafka
          Issue Type: Bug
          Components: streams
    Affects Versions: 2.4.0
            Reporter: Andy Bryant


I was trying out the new one-to-many KTable joins against some CDC data in Avro 
format and kept getting serialisation errors.

 
{code:java}
org.apache.kafka.common.errors.SerializationException: Error registering Avro 
schema: 
{"type":"record","name":"Key","namespace":"dbserver1.inventory.orders","fields":[

{"name":"order_number","type":"int"}

],"connect.name":"dbserver1.inventory.orders.Key"}
 Caused by: 
io.confluent.kafka.schemaregistry.client.rest.exceptions.RestClientException: 
Schema being registered is incompatible with an earlier schema; error code: 409
  
{code}
Both tables have avro keys of different types (one is an order key, the other a 
customer key).

This looks like it will cause issues.

[https://github.com/apache/kafka/blob/2.4/streams/src/main/java/org/apache/kafka/streams/kstream/internals/foreignkeyjoin/CombinedKeySchema.java#L57-L60]

 They will both attempt to register schemas with the same subject to the schema 
registry which will fail a backward compatibility check.

I also noticed in the schema registry there were some subjects that didn't have 
the application id prefix. This is probably caused by this...

 
[https://github.com/apache/kafka/blob/2.4/streams/src/main/java/org/apache/kafka/streams/kstream/internals/foreignkeyjoin/ForeignJoinSubscriptionSendProcessorSupplier.java#L88]

Where here {{repartitionTopicName}} doesn't have the application prefix.

 

 

 

 

 



--
This message was sent by Atlassian Jira
(v8.3.4#803005)

Reply via email to