从confluent-kafka-python repoAvroProducer
中的示例来看,键/值模式似乎是从文件中加载的。也就是说,从这段代码:
from confluent_kafka import avro
from confluent_kafka.avro import AvroProducer
value_schema = avro.load('ValueSchema.avsc')
key_schema = avro.load('KeySchema.avsc')
value = {"name": "Value"}
key = {"name": "Key"}
avroProducer = AvroProducer({'bootstrap.servers': 'mybroker,mybroker2', 'schema.registry.url': 'http://schem_registry_host:port'}, default_key_schema=key_schema, default_value_schema=value_schema)
avroProducer.produce(topic='my_topic', value=value, key=key)
似乎这些文件是独立于 Avro Schema Registry 加载的ValueSchema.avsc
。KeySchema.avsc
这是正确的吗?引用 Avro 模式注册表的 URL,然后从磁盘加载模式以获取键/值有什么意义?
请说清楚。