В Кафке разделы являются единицей параллелизма.
Не зная нашего точного варианта использования и требований, сложно придумать точные рекомендации, но есть несколько вариантов.
Во-первых, вы должны подумать о том, чтобы иметь больше разделов. 6 разделов относительно малы, вы можете легко иметь 60, 120 или даже больше разделов (и соответствующее количество потребителей). Внезапно объем работы каждого потребителя значительно сокращается.
Кроме того, если позволяют ваши требования, вы также можете быстро потреблять и распределять обработку записей среди множества работников. В подобных решениях сложнее поддерживать порядок, но если он вам не нужен, вы можете рассмотреть его.
Я не уверен, как маршрутизация сообщений через MQ Queue действительно помогла бы в этом сценарии. Если вы по-прежнему читаете медленнее, чем записываете, объем данных в очереди будет расти, пока у вас не останется свободного места на диске.
Kafka лучше спроектирован, чтобы служить буфером между вашими производителями и потребителями, поэтому просто убедитесь, что у вас есть ограничения по хранению ваших тем, которые обеспечивают некоторую гибкость на стороне потребителя без потери данных.