-
Notifications
You must be signed in to change notification settings - Fork 77
Open
Description
Short intro
We're running a platform that's effectively just a bunch of microservices written in Python, Java and Go which are communicating through Kafka. Currently we're considering moving from Kafka to Pulsar.
However, one of the main features we need is key-based message routing for solving concurrency problems. Pulsar has that option with KeyShared subscription mode.
The problem
In Python, KeyShared subscription works only if producer disables batching. I ran some tests in my local environment and disabling batching results in high decrease of throughput (~25k/s with batching vs ~9k/s without).
Features that would've solved the problem
- Key-based batching for Python client
- HashingScheme parameter when creating producer so all of our services (Java, Python and Go) could have the same hashing scheme
mjuraj, lbenc135, TheMainGuy, Lolchek, farbanas and 1 more
Metadata
Metadata
Assignees
Labels
No labels