Kafkit¶
Kafkit helps you write Kafka producers and consumers in Python with asyncio:
- Kafkit integrates aiokafka consumers and producers with the Confluent Schema Registry. The - Deserializerclass can deserialize messages with any schema that’s registered in a Confluent Schema Registry. The- Serializerclass can serialize Python objects against a single Avro schema, while the- PolySerializerclass is flexible enough to handle multiple schemas.
- Kafkit provides Python APIs for working with the Confluent Schema Registry’s HTTP API. The - RegistryApiclient includes high-level methods that manage subjects and their schemas in a registry. These methods are cached so that the- RegistryApiclient can be an integral part of your application’s schema management. Additionally,- RegistryApiincludes low-level HTTP methods (GET, POST, PUT, PATCH, DELETE) so you can work directly with the Confluent Schema Registry API if you want.
- kafkit.registry.aiohttp.RegistryApiis implemented with aiohttp, but that’s not the only implementation. Kafkit subscribes to the sans IO architecture (gidgethub is a popular example) meaning that you can subclass- kafkit.registry.sansio.RegistryApito integrate with your favorite HTTP client library. The- kafkit.registry.sansio.MockRegistryApiis a mock client that you can use in your app’s unit tests.
User guide¶
API reference¶
Developer guide¶
Project information¶
Kafkit is developed on GitHub at https://github.com/lsst-sqre/kafkit.