Consumer Rebalance Protocol
Overview
Starting from Apache Kafka 4.0, the Next Generation of the Consumer Rebalance Protocol (KIP-848) is Generally Available (GA), ready for production workloads. It improves the scalability of consumer groups while simplifying consumers. It also decreases rebalance times, thanks to its fully incremental design, which no longer relies on a global synchronization barrier.
There are now two types of consumer groups, named depending upon whether the consumers are using the new “consumer” group protocol or the earlier “classic” group protocol.
Server
The new consumer protocol is automatically enabled on the server since Apache Kafka 4.0. Enabling and disabling the protocol on the server side is controlled by the group.version feature flag.
The consumer heartbeat interval and the session timeout are controlled by the server now with the following configs:
group.consumer.heartbeat.interval.msgroup.consumer.session.timeout.ms
The assignment strategy is also controlled by the server. The group.consumer.assignors configuration can be used to specify the list of available assignors for Consumer groups.
uniformandrangeassignors are provided by defaultuniformis the default one (first assignor in the list ofgroup.consumer.assignors) unless the Consumer selects a different one (via the client configgroup.remote.assignor)- it is possible to implement custom assignment strategies on the server side, by implementing the
ConsumerGroupPartitionAssignorinterface and specifying the full class name in thegroup.consumer.assignorsconfiguration.
Migrating from Client-side Assignors
The following table shows the mapping from client-side assignors to the new server-side assignors:
| Client-side Assignor | Server-side Assignor |
|---|---|
| RangeAssignor | range |
| CooperativeStickyAssignor | uniform |
| StickyAssignor | uniform |
| RoundRobinAssignor | uniform |
Consumer
Since Apache Kafka 4.0, the Consumer fully supports the new Consumer rebalance protocol. However, the protocol is not enabled by default. The group.protocol configuration must be set to consumer to enable it. When enabled, the new consumer protocol is used alongside an improved threading model.
The subscribe(SubscriptionPattern) and subscribe(SubscriptionPattern, ConsumerRebalanceListener) methods have been added to subscribe to a regular expression with the new Consumer rebalance protocol. With these methods, the regular expression uses the RE2J format and is now evaluated on the server side.
New metrics have been added to the Consumer when using the new rebalance protocol, mainly providing visibility over the improved threading model. See New Consumer Metrics.
When the new rebalance protocol is enabled, the following configurations and APIs are no longer usable:
heartbeat.interval.mssession.timeout.mspartition.assignment.strategyenforceRebalance(String)andenforceRebalance()
Upgrade & Downgrade
Offline
Consumer groups are automatically converted from Classic to Consumer and vice versa when they are empty. Hence, it is possible to change the protocol used by the group by shutting down all the consumers and bringing them back up with the group.protocol=consumer configuration. The downside is that it requires taking the consumer group down.
Online
Consumer groups can be upgraded without downtime by rolling out the consumer with the group.protocol=consumer configuration. When the first consumer using the new Consumer rebalance protocol joins the group, the group is converted from Classic to Consumer, and the Classic rebalance protocol is interoperated to work with the new Consumer rebalance protocol. This is only possible when the classic group uses an assignor that does not embed custom metadata.
Consumer groups can be downgraded using the opposite process. In this case, the group is converted from Consumer to Classic when the last consumer using the new Consumer rebalance protocol leaves the group.
Evolution Timeline
The evolution timeline of the Consumer rebalance protocol is described in KIP-1274, and expected to be as follows:
- Apache Kafka 3.7: Early Access
- Apache Kafka 4.0: GA (production-ready).
- Apache Kafka 5.0:
KafkaConsumerdefaults toConsumerprotocol, while still supportingClassic - Apache Kafka 6.0:
KafkaConsumeronly supportsConsumeras rebalance protocol, while the broker still supportsClassicfor backward compatibility.
Limitations
- Client-side assignors are not supported and not in scope at the moment. Use KAFKA-18327 to provide feedback if you have custom assignment strategies that may not be covered.
- Rack-aware assignment strategies are not fully supported yet (work is in progress, see KAFKA-19387).